未调用WearableListenerService onMessageReceived()

时间:2015-08-10 11:03:57

标签: android wear-os google-api-client gdata-api android-wear-data-api

在手机设备上,我有一个WearableListenerService侦听来自Android Wear设备的输入。

我正在使用DataItems和Messages。 DataItems在两个设备之间同步很好,但是,我在手机上接收消息时遇到了问题。

我尝试了以下内容:

  • 已确认佩戴已发送消息
  • 检查包名是否相同
  • 检查签名是否相同(均为Android Debug)

但是,DataLayerListenerService中未调用onMessageReceived。最初,我使用的是一个活动并扩展了MessageListener,除了一个简单的工作点之外,它还没有工作。

Android Wear代码

public static void sendMessageToDevice(final String commandPath, final byte[] additionalData)
{
    // Separate thread from UI thread
    new Thread(new Runnable()
    {
        @Override
        public void run()
        {
            String nodeId = null;

            // Find first connected device id

            NodeApi.GetConnectedNodesResult result =
                    Wearable.NodeApi.getConnectedNodes(mGoogleApiClient).await();
            List<Node> nodes = result.getNodes();

            if (nodes.size() > 0)
            {
                nodeId = nodes.get(0).getId();
            }
            if (nodeId != null)
            {
                Wearable.MessageApi.sendMessage(mGoogleApiClient, nodeId,
                        commandPath, additionalData).setResultCallback(new ResultCallback<MessageApi.SendMessageResult>()
                {
                    @Override
                    public void onResult(MessageApi.SendMessageResult sendMessageResult)
                    {
                        if (!sendMessageResult.getStatus().isSuccess())
                        {
                            System.err.println("Message " + commandPath + " could not be sent.");
                        }
                    }
                });

                System.out.println("Command path is: " + commandPath);
            }
        }
    }).start();
}

Android设备代码

public class DataLayerListenerService extends WearableListenerService
{

@Override
public void onMessageReceived(MessageEvent messageEvent)
{
    System.out.println("Received command");
    String command = messageEvent.getPath();
    System.out.println("Received command is: " + command);
    if (command.contains("/mobile/input/"))
    {
        System.out.println(command);
    }
}

@Override
public void onDataChanged(DataEventBuffer dataEvents)
{
    for (DataEvent event : dataEvents)
    {
        if (event.getType() == DataEvent.TYPE_CHANGED)
        {
            DataItem item = event.getDataItem();
            DataMap dataMap = DataMapItem.fromDataItem(item).getDataMap();
            String itemPath = item.getUri().getPath();
            if (itemPath.equals("/mobile/input/level"))
            {
                int level = dataMap.getInt("level");
                MainActivity.readLevel(level);
            }
        }
    }
}
}

1 个答案:

答案 0 :(得分:0)

一个可能的问题可能如下:您正在抓取所有连接的节点,然后抓住第一个目标为您的消息。这很可能最终成为云节点(或者如果你有多个可穿戴设备),而不是你的手机。正确的方法是使用CapabilityApis找到发送消息的正确节点。在您的代码中,查看您选择用于确认它正在选择云的节点的node.toString(),以确保这是问题所在。