我正在构建一个 Wear OS 应用程序,作为 React Native 项目的一部分。每当发生更改时,手持应用程序都应在其可穿戴节点之间发送一些数据。我正在使用 DataClient 和 DataItems 来执行此操作。在可穿戴设备方面,我实现了 DataClient.OnDataChangedListener,但这从未被调用过。
这是数据更改时调用的方法。我收到 onSucces 消息,所以我认为这有效:
@ReactMethod
public void updateData(String name, Integer age, String description){
PutDataMapRequest putDataMapReq = PutDataMapRequest.create("/data");
Long tsLong = System.currentTimeMillis() / 1000;
String timestamp = tsLong.toString();
putDataMapReq.getDataMap().putString("Timestamp", timestamp);
putDataMapReq.getDataMap().putString("Name", name);
putDataMapReq.getDataMap().putInt("Age", age);
putDataMapReq.getDataMap().putString("Description", description);
PutDataRequest dataRequest = putDataMapReq.asPutDataRequest();
dataRequest.setUrgent();
Task<DataItem> putDataTask = Wearable.getDataClient(reactContext).putDataItem(dataRequest);
putDataTask.addOnSuccessListener(new OnSuccessListener<DataItem>() {
@Override
public void onSuccess(DataItem dataItem) {
System.out.println("Great Succes!");
}
});
}
这是穿戴端DataClient的onDataChanged方法。
@Override
public void onDataChanged(DataEventBuffer dataEventBuffer) {
System.out.println("DATA CHANGED");
for (DataEvent event : dataEventBuffer) {
if (event.getType() == DataEvent.TYPE_CHANGED) {
// DataItem changed
DataItem item = event.getDataItem();
if (item.getUri().getPath().compareTo("/data") == 0) {
DataMap dataMap = DataMapItem.fromDataItem(item).getDataMap();
System.out.println(dataMap.getString("Name"));
}
} else if (event.getType() == DataEvent.TYPE_DELETED) {
// DataItem deleted
}
}
}
这些是手持设备的 gradle 文件中的依赖项:
dependencies {
implementation project(':react-native-background-timer')
implementation project(':react-native-geolocation-service')
implementation fileTree(dir: "libs", include: ["*.jar"])
implementation "com.facebook.react:react-native:+"
implementation 'com.google.android.gms:play-services-wearable:17.0.0'
if (enableHermes) {
def hermesPath = "../../node_modules/hermes-engine/android/";
debugImplementation files(hermesPath + "hermes-debug.aar")
releaseImplementation files(hermesPath + "hermes-release.aar")
} else {
implementation jscFlavor
}
wearApp project(':watch')
}
以及可穿戴设备的 gradle 文件中的依赖项:
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'androidx.wear:wear:1.0.0'
implementation 'androidx.recyclerview:recyclerview:1.1.0'
implementation 'androidx.percentlayout:percentlayout:1.0.0'
implementation 'androidx.legacy:legacy-support-v13:1.0.0'
implementation 'com.google.android.gms:play-services-wearable:17.0.0'
compileOnly 'com.google.android.wearable:wearable:2.7.0'
implementation 'com.google.android.support:wearable:2.7.0'
}
再次强调,onDataChanged 从未被调用,我找不到问题。我已经尝试了几种方法。
由于 Google 在其 DataLayer API 上进行了很多更改,因此许多有关此的信息已变得无关紧要。谢谢!
找到了!问题在于手表应用程序没有使用与手持应用程序相同的密钥进行签名。我这样做之后,立马见效了!
解决步骤
1)包名一致性:
2)清单中的权限:
3)网络连接:
4)签名密钥匹配:
验证两者的 SHA-1、MD5 和 SHA-256 密钥是否相同 模块。不匹配可能会阻止检测到数据更改。
要检查并确保密钥匹配,请按照本视频中的步骤操作:
5)更新build.gradle(手持模块):
android {
signingConfigs {
debug {
storeFile file('debug.keystore')
storePassword 'android'
keyAlias 'androiddebugkey'
keyPassword 'android'
}
}
buildTypes {
debug {
signingConfig signingConfigs.debug
}
}
}
6)更新build.gradle(WearOS模块):
android {
signingConfigs {
debug {
storeFile file('debug.keystore')
storePassword 'android'
keyAlias 'androiddebugkey'
keyPassword 'android'
}
}
buildTypes {
debug {
signingConfig signingConfigs.debug
}
}
}
注意:这可能会导致有关找不到 debug.keystore 文件的错误。
7) 将 debug.keystore 复制到穿戴模块:
在手持设备模块中找到 debug.keystore 文件(通常是 在 android -> 应用程序)中。
复制 debug.keystore 文件并将其粘贴到 WearOS 模块中。
8)生成匹配密钥:
9)重新启动Android Studio和IDE:
10) 测试和验证: