- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Google Fit API。我有一个 WearOS 模拟器连接到我的实际设备 (Samsung Galaxy)。当我运行该应用程序时,我很确定我应该弹出一个屏幕来询问权限,但我没有看到这样的屏幕。我完成了在 Google API 控制台中获取 token 的过程。
public class GoalsListActivity extends WearableActivity {
public static final String TAG = "BasicRecordingApi";
private static final int REQUEST_OAUTH_REQUEST_CODE = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.goals_screen_layout);
accessGoogleFit();
// Enables Always-on
setAmbientEnabled();
}
/**
* Check if the user has permissions to talk to Fitness APIs; otherwise authetnciate the user and request required permissions
*/
private void accessGoogleFit() {
FitnessOptions fitnessOptions = getFitnessSignInOptions();
if (!hasOAuthPermission()) {
GoogleSignIn.requestPermissions(this, REQUEST_OAUTH_REQUEST_CODE, GoogleSignIn.getLastSignedInAccount(this), fitnessOptions);
} else {
subscribeToRecordingApi();
}
}
/**
* Create a FitnessOptions instance, declaring the Fit API data types and access required by the app
*
* @return FitnessOptions object
*/
private FitnessOptions getFitnessSignInOptions() {
FitnessOptions fitnessOptions = FitnessOptions.builder()
.addDataType(DataType.TYPE_STEP_COUNT_DELTA, FitnessOptions.ACCESS_READ)
.addDataType(DataType.AGGREGATE_STEP_COUNT_DELTA, FitnessOptions.ACCESS_READ)
.build();
return fitnessOptions;
}
/**
* Check if user's account has OAuth permission to Fit API
*
* @return true if user has OAuth permission
*/
private boolean hasOAuthPermission() {
FitnessOptions fitnessOptions = getFitnessSignInOptions();
//Check if the user has previously granted the necessary data access, and if not, inititate the authroization flow
boolean hasAuthO = GoogleSignIn.hasPermissions(GoogleSignIn.getLastSignedInAccount(this), fitnessOptions);
return hasAuthO;
}
//If the user does not have necessary data access, inititate the authorization flow
private void requestOAuthPermission() {
FitnessOptions fitnessOptions = getFitnessSignInOptions();
GoogleSignIn.requestPermissions(
this, //our activity
REQUEST_OAUTH_REQUEST_CODE,
GoogleSignIn.getLastSignedInAccount(this),
fitnessOptions);
}
/**
* SUBSCRIBE TO FITNESS DATA
* To record data from the sensors, we need to first create a subscription.
* To create a subscription, invoke the Recording API. As soon as the subscription is active, fitness data will start recording
*/
private void subscribeToRecordingApi() {
Fitness.getRecordingClient(this, GoogleSignIn.getLastSignedInAccount(this))
.subscribe(DataType.TYPE_ACTIVITY_SAMPLES)
.addOnSuccessListener(new OnSuccessListener<Void>() {
@Override
public void onSuccess(Void aVoid) {
Log.i(TAG, "Successfully subscribed!");
}
})
.addOnFailureListener(new OnFailureListener() {
@Override
public void onFailure(@NonNull Exception e) {
Log.i(TAG, "There was a problem subscribing");
}
});
}
/**
* Get a list of all active subscriptions
*/
private void getAllActiveSubscriptions() {
Fitness.getRecordingClient(this, GoogleSignIn.getLastSignedInAccount(this))
.listSubscriptions(DataType.TYPE_ACTIVITY_SAMPLES)
.addOnSuccessListener(new OnSuccessListener<List<Subscription>>() {
@Override
public void onSuccess(List<Subscription> subscriptions) {
for (Subscription sc : subscriptions) {
DataType dt = sc.getDataType();
Log.i(TAG, "Active subscription for data type: " + dt.getName());
}
}
});
}
/**
* UNSUBSCRIBE - STOP COLLECTING SENSOR DATA IN THE APP
* Cancels the ACTIVITY_SAMPLE subscription on that {@link DataType}
*/
public void stopRecording() {
final String dataTypeStr = DataType.TYPE_ACTIVITY_SAMPLES.toString();
Log.i(TAG, "Unsubscribing from data type: " + dataTypeStr);
//Invoke the Recording API to unsubscribe from the data type and specify a callback that will check the result
Fitness.getRecordingClient(this, GoogleSignIn.getLastSignedInAccount(this))
.unsubscribe(DataType.TYPE_ACTIVITY_SAMPLES)
.addOnSuccessListener(new OnSuccessListener<Void>() {
@Override
public void onSuccess(Void aVoid) {
Log.i("TAG", "Successfully unsubscribed for data type: " + dataTypeStr);
}
})
.addOnFailureListener(new OnFailureListener() {
@Override
public void onFailure(@NonNull Exception e) {
//The subscription was not removed
Log.i(TAG, "Failed to unsubscribe for data type: " + dataTypeStr);
}
});
}
}
代码基本来自enter link description here ,这是谷歌自己的示例代码。我有 API key 。出于某种原因,我无法让它工作。谢谢。
最佳答案
你能把你所有的都换掉吗
GoogleSignIn.getLastSignedInAccount(this)
与
GoogleSignIn.getAccountForExtension(this, fitnessOptions);
关于android - 无法将 Google Fit OAuth 2.0 链接到 WearOS App,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51252795/
我正在尝试让 ProgressBar 在 WearOS watch 上绕过整个屏幕的边缘,如下所示: 我原以为这样的布局会奏效,但这只会在屏幕中央形成一个很大的 ProgressBar:
我想显示一些通知,但我只看到一个通知,我这样做了; public void showNotification(int i){ NotificationManager notificationM
我正在寻找我的 Wear OS 应用程序数据,以使用 php 和 mysql 发送到我的外部 apache 服务器。 最终我需要在 MySQL 数据库中观察传感器数据,所以我使用 php 创建了一个
Developer.android 说: void setDefaultSystemComplicationProvider (int watchFaceComplicationId, int 系统提
我目前正在开发一个支持环境 mjode 的应用程序。那没什么难的。现在,我的应用程序有两个需要每秒更新一次的计时器。所以我去找谷歌文档here .我已经尝试了很多次,我已经检查了文档建议的每一行代码,
我已使用 Google Play 控制台 Multi-APK delivery method 将我的 Android 和 WearOS 应用程序作为单独的 APK 发布. 从各自的设备浏览时可以发现这
我开发了一个与 HTTP API 通信的 wear os 2.0+ 应用程序。我正在使用 Volley 连接到这个 API,但它似乎只有在我关闭蓝牙时才有效。我用蓝牙发出的任何请求都会超时。另一端通常
我有一个包含多个模块的 Android 项目,手机应用程序模块和一些库模块。它们都适用于 CoposeCompiler 1.2.0 和 Kotlin 版本 1.7.0。现在,我想添加一个 WearOS
我正在为 Android Wear-OS 开发一个实时聊天应用程序。我正在使用 Tic Watch Pro 4G 进行开发测试。我的应用程序已在 Wear-OS Play 商店中发布,名称为“IoSi
我正在尝试使用 Google Fit API。我有一个 WearOS 模拟器连接到我的实际设备 (Samsung Galaxy)。当我运行该应用程序时,我很确定我应该弹出一个屏幕来询问权限,但我没有看
我是一名优秀的程序员,十分优秀!