WearableDataListener Service不会调用onDataChanged方法

问题描述 投票:4回答:3

我正在制作一个磨损应用程序,它可以在app主屏幕的启动时从数据库(手持设备上)获取数据。因此,当主页活动启动时,它会使用Wearable.MessageApi.sendMessage函数从android wear到掌上电脑发送消息。在掌上电脑中,我有WearableListenerService,它在onMessageReceived函数中接收此消息并读取数据库。在读取数据库之后,它将putDatamapRequest发送到磨损。

现在在磨损方面,我有另一个WearableListenerService。在此服务中,永远不会调用onDataChanged()函数。它有时会运行,到目前为止它运行了2-3次但是没有运行。这是随机的。此外,一旦在Wear侧收到数据,我设置了一个静态Arraylist,我用它来显示Activity中的数据。但由于并不总是调用onDataChanged函数,因此它给出了空数组列表。

这是我的AndroidManifest文件的磨损应用程序,我在其中声明了服务:

   <service
        android:name="com.example.deals.DataListenerService"
        android:enabled="true"
        android:exported="true" >
        <intent-filter>
            <action android:name="com.google.android.gms.wearable.BIND_LISTENER" />
        </intent-filter>
    </service>

这是我的代码,用于将消息从磨损发送到手持设备:

mGoogleApiClient = new GoogleApiClient.Builder(this).addConnectionCallbacks(new GoogleApiClient.ConnectionCallbacks() {

        @Override
        public void onConnected(Bundle bundle) {
                                    Wearable.NodeApi.getConnectedNodes(mGoogleApiClient).setResultCallback(new ResultCallback<NodeApi.GetConnectedNodesResult>() {
                        @Override
                        public void onResult(NodeApi.GetConnectedNodesResult getConnectedNodesResult) {
                            if(!getConnectedNodesResult.getNodes().isEmpty())
                            {
                                node = getConnectedNodesResult.getNodes().get(0);
                                System.out.println("Connected: "+ node.getId());
                                Wearable.MessageApi.sendMessage(mGoogleApiClient, node.getId(), FETCH_ALL_DEALS, null).setResultCallback(new ResultCallback<MessageApi.SendMessageResult>() {
                                    @Override
                                    public void onResult(MessageApi.SendMessageResult sendMessageResult) {
                                        if (!sendMessageResult.getStatus().isSuccess()) {
                                            Log.e("Wear:", "ERROR: failed to send Message: " + sendMessageResult.getStatus());
                                        }
                                        else
                                            System.out.println("success");
                                    }
                                });

                            }
                            else
                                System.out.println("Wear not connected to Phone");
                        }
                    });

        }

            @Override
            public void onConnectionSuspended(int i) {

            }



        })
        .addOnConnectionFailedListener(new GoogleApiClient.OnConnectionFailedListener() {
            @Override
            public void onConnectionFailed(ConnectionResult result) {
                Log.v("Phone to wear connection failed", "onConnectionFailed: " + result);
            }
        })
        .addApi(Wearable.API)
        .build();
        mGoogleApiClient.connect();

这是我在Handheld上的onMessageReceive的代码:

 public void onMessageReceived(MessageEvent messageEvent) {
    System.out.println("Message Received on Phone on launch of wear homepage");
    if(messageEvent.getPath().equals(FETCH_ALL_DEALS)) {
        sendSavedDeals(); //fetch from db and make a datamap object using PutDataRequest
        System.out.println("Message Received on Phone on launch of wear homepage");
    }
    else {
        System.out.println("Unable to recognise action for "+messageEvent.getPath());
    }

}

现在在我的磨损方面,我有一个WearableListenerService,但它的onDataChanged方法永远不会被调用。你能帮我解决吗?

wear-os android-wear-data-api
3个回答
13
投票

onDataChanged()仅在数据确实发生变化时被调用。如果多次将相同的数据放入DataApi,则只能调用一次,直到您编写不同的数据。

要在磨损方面触发操作,即使数据没有改变,也要在将数据放入DataApi后发送消息。


1
投票

应该更改或删除数据,以便在您的服装中的WearabaleListenerService中回调onDataChanged。如果你想进行更改,请从设置中打开APP-info,然后在强制停止后打开清除数据。最后在手机中启动您的应用程序..但是确保可穿戴的听众服务应该已经在你的服装中启动了..


0
投票

当没有调用onDataChanged()时:

首先,确保手持活动在开始时连接到API:


    @Override
    protected void onStart() {
        super.onStart();
        mGoogleApiClient.connect();
    }

否则,它会无声地失败。

如果它仍然不起作用,为了便于调试,在掌上电脑活动中添加此覆盖方法和此类以每5秒生成一次数据:


    @Override
    public void onResume() {
        super.onResume();
        mDataItemGeneratorFuture = mGeneratorExecutor.scheduleWithFixedDelay(
            new DataItemGenerator(), 1, 5, TimeUnit.SECONDS
        );
    }


    /** Generates a DataItem based on an incrementing count. */
    private class DataItemGenerator implements Runnable {
        private int count = 0;

        @Override
        public void run() {
        PutDataMapRequest putDataMapRequest = PutDataMapRequest.create(COUNT_PATH);
        putDataMapRequest.getDataMap().putInt(COUNT_KEY, count++);
        PutDataRequest request = putDataMapRequest.asPutDataRequest();

        Log.d("yourApp", "Generating DataItem: " + request);
        if (!mGoogleApiClient.isConnected()) {
            return;
        }
        Wearable.DataApi.putDataItem(mGoogleApiClient, request)
            .setResultCallback(new ResultCallback() {

                @Override
                public void onResult(DataItemResult dataItemResult) {
                    if (!dataItemResult.getStatus().isSuccess()) {
                        Log.e("YourApp", "ERROR: failed to putDataItem, status code: "
                            + dataItemResult.getStatus().getStatusCode());
                    }
                }
            });
        }
    }

© www.soinside.com 2019 - 2024. All rights reserved.