1

我已经在市场上有一个 Android Wear 应用程序大约 10 个月了,它已经停止工作(不确定它什么时候停止工作)。

我正在尝试使用我在移动应用程序中记录的一些统计数据来更新我的可穿戴应用程序。正如我所说,这曾经可以正常可靠地工作。我什至为此添加了时间戳,因此它是唯一的,因为onDataChanged只有在数据发生更改时才会调用它。这保证了这一点。

我的问题

我可以通过调用提交PutDataMapRequest罚款,Wearable.DataApi.putDataItem并在我的ResultCallback.

通常最后onDataChanged会被调用,但延迟时间比以前多了很多。更重要的是,我知道它设置正确,因为我有一个我启动的应用程序,我有一个Activity我去拿的应用程序,DataItems那里有一个积压的工作。我也有同样的onDataChanged问题Activity

我做了什么

  1. 确保两个模块build.gradle文件的 versionCode 和 versionName 匹配。
  2. 确保两个build.gradle文件使用相同版本的支持和谷歌服务库。
  3. 确保两个类都连接到GoogleApiClient
  4. 确保每次数据都不同,以强制它调用onDataChanged服务。我不需要这个,只是为了让它工作。

我的代码

移动的

if (mGoogleApiClient.isConnected()) {
            PutDataMapRequest putDataMapRequest = PutDataMapRequest.create(path);
            putDataMapRequest.getDataMap().putString("content", content);
            putDataMapRequest.getDataMap().putString("title", title);
            putDataMapRequest.getDataMap().putLong("timestamp", DateTime.now().getMillis());
            PutDataRequest request = putDataMapRequest.asPutDataRequest();    

            Wearable.DataApi.putDataItem(mGoogleApiClient, request)
                    .setResultCallback(new ResultCallback<DataApi.DataItemResult>() {
                        @Override
                        public void onResult(DataApi.DataItemResult dataItemResult) {
                            if (!dataItemResult.getStatus().isSuccess()) {
                                Log.e("WearDevice", "buildWatchOnlyNotification(): Failed to set the data, "
                                        + "status: " + dataItemResult.getStatus().getStatusCode());
                            } else {
                                    Log.d(LOG_TAG, "Notificaiton result callback returned successfully: "+dataItemResult.getDataItem().toString());//: "+node.getDisplayName());
                            }
                        }
                    });
}

穿

我有一项服务可以扩展WearableListenerService。这是在清单中声明的​​,如下所示。

<service android:name=".NotificationUpdateService">
            <intent-filter>
                <action android:name="com.google.android.gms.wearable.BIND_LISTENER"/>
            </intent-filter>
        </service>

这是我的服务。

@Override
    public void onCreate() {
        super.onCreate();

        mGoogleApiClient = new GoogleApiClient.Builder(this)
                .addApi(Wearable.API)
                .addConnectionCallbacks(this)
                .addOnConnectionFailedListener(this)
                .build();

        mGoogleApiClient.connect();
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        return super.onStartCommand(intent, flags, startId);
    }

    @Override
    public void onDataChanged(DataEventBuffer dataEvents) {
        if (MainActivity.DEBUGGING)
            Log.d(LOG_TAG, "onDataChanged");
        for (DataEvent dataEvent : dataEvents) {

            if (dataEvent.getType() == DataEvent.TYPE_CHANGED) {
                DataMap dataMap = DataMapItem.fromDataItem(dataEvent.getDataItem()).getDataMap();
                String content = dataMap.getString("content");
                String title = dataMap.getString("title");
                if ("/mydatapath".equals(dataEvent.getDataItem().getUri().getPath())) {
                    buildWearableOnlyNotification(title, content, false);
                }
            }
        }
    }

buildWearableOnlyNotification方法创建并启动前台通知,并且在实际调用时可以正常工作。

4

1 回答 1

1

如果您希望立即同步数据,您现在需要设置紧急标志,否则框架会将这些调用分批并在一个调用中执行,这意味着您最多可以看到 30 分钟的延迟;这是在最近的播放服务中进行的一项更改,以在不需要这种即时数据同步时保护电池。

于 2015-11-24T21:02:54.513 回答