WearableSensorListener onDataChanged 永远不会被调用



我最近开始在Android设备上工作,我想从Android Watch收集传感器数据。

我成功地使用了消息 API,但数据 API 对我不起作用。我已经检查过:

https://stackoverflow.com/a/34175410/2487227

从不调用 OnDataChanged

Android Wear onDataChanged 不被调用

但他们都不适合我。

我的代码在手表上:

@Override
public void onCreate() {
    super.onCreate();
    // sensor registration
    // ......
    googleApiClient = new GoogleApiClient.Builder(this)
            .addApi(Wearable.API)
            .addConnectionCallbacks(this)
            .addOnConnectionFailedListener(this)
            .build();
    googleApiClient.connect();
    Log.i(this.getClass().toString(), "Google API Client connected");
}
private void sendSensorResult(SensorEvent event) {
    if (!googleApiClient.isConnected())
        googleApiClient.connect();
    PutDataMapRequest putDataMapRequest = PutDataMapRequest.create(DATA_API_PATH);
    putDataMapRequest.getDataMap().putLong("UNIX_TIME", System.currentTimeMillis());
    putDataMapRequest.getDataMap().putInt("TYPE", event.sensor.getType());
    // nanosecond
    putDataMapRequest.getDataMap().putLong("TIME", event.timestamp);
    putDataMapRequest.getDataMap().putFloatArray("DATA", event.values);
    PutDataRequest request = putDataMapRequest.asPutDataRequest().setUrgent();
    Wearable.DataApi.putDataItem(googleApiClient, request)
            .setResultCallback(new ResultCallback<DataApi.DataItemResult>() {
                @Override
                public void onResult(@NonNull DataApi.DataItemResult dataItemResult) {
                    if (dataItemResult.getStatus().isSuccess()) {
                        Log.i(this.getClass().toString(), "Sent: " + event.toString());
                    } else {
                        Log.i(this.getClass().toString(), "FAILED TO SEND: " + event.toString());
                    }
                }
            });
}

在电话上:

public void onDataChanged(DataEventBuffer dataEvents) {
    Log.i(this.getClass().toString(), "Got data at " + System.currentTimeMillis());
    for (DataEvent dataEvent : dataEvents) {
        Log.i(this.getClass().toString(), "Got event: " + dataEvent.toString());
        if (dataEvent.getType() == DataEvent.TYPE_CHANGED) {
            DataMap dataMap = DataMapItem.fromDataItem(dataEvent.getDataItem()).getDataMap();
            String path = dataEvent.getDataItem().getUri().getPath();
            if (path.equals(DATA_API_PATH)) {
                int type = dataMap.getInt("TYPE");
                long time = dataMap.getLong("TIME");
                float[] data = dataMap.getFloatArray("DATA");
                String message = String.format(Locale.UK, "TYPE: %d, TIME: %d, DATA: %s",
                        type,
                        time,
                        Arrays.toString(data));
                showSensorResult(message);
            }
        }
    }
}

电话AndroidManifest.xml

<service
        android:name=".WearableSensorListener"
        android:enabled="true"
        android:exported="true">
    <intent-filter>
        <action android:name="com.google.android.gms.wearable.DATA_CHANGED"/>
        <data android:host="*"
              android:scheme="wear"
              android:pathPrefix="/wearable-sensor"/>
    </intent-filter>
</service>

我可以从手表中看到日志,但手机中没有显示任何内容。

可穿戴设备和手机的applicationId是一样的。

我是否需要任何其他权限才能使用数据 API?

尽可能

早地使用GooglePlayServices版本。

打开 .Sdkextrasgooglem2repositorycomgoogleandroidgmsplay-services-wearable并使用,例如,8.3.0 .查看您的穿戴设备的GooglePlayServices版本。它的数量必须大于您使用的数量。

我认为您的实施不正确。这是错误的。

private void sendSensorResult(SensorEvent event) {
    if (!googleApiClient.isConnected())
        googleApiClient.connect();
///....
Wearable.DataApi.putDataItem(googleApiClient, request)

我的意思是你必须等待连接。因此,请仅在onConnected回调后使用 putDataItem

相关内容

  • 没有找到相关文章

最新更新