Подтвердить что ты не робот

Отправка сообщений с Android Wear на хост-устройство

Я пишу специальное приложение Android Wear, которое должно запускать одноразовое сообщение на подключенное хост-устройство (телефон). Копаясь в API, я нашел следующий учебник, который должен хорошо работать: http://developer.android.com/training/wearables/data-layer/messages.html

У моего Android-приложения есть WearableListenerService, и приложение Android Wear отключает сообщения с помощью API сообщений. WearableListenerService вызывается, когда эмулятор подключается на основе регистрации следующего метода, поэтому я уверен, что услуга подключена отлично

@Override
public void onPeerConnected(Node peer) {
    super.onPeerConnected(peer);

    String id = peer.getId();
    String name = peer.getDisplayName();

    Log.d(LOG_TAG, "Connected peer name & ID: " + name + "|" + id);
}

Выход журнала:

/AndroidWearListenerService(19892): Connected peer name & ID: facdc219-37f5-4326-8fa6-1c8b8d3b6669|facdc219-37f5-4326-8fa6-1c8b8d3b6669

Однако метод onMessageReceived никогда не запускается:

@Override
public void onMessageReceived(MessageEvent messageEvent) {
    Log.d(LOG_TAG, "MessageEvent received: " + messageEvent.getData());
    //do work
}

Здесь мой код Android Wear. Я удалил большую часть кода плиты котла, оставляя только необходимые бит

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_my);

    final GoogleApiClient googleApiClient = new GoogleApiClient.Builder(this)
            .addApi(Wearable.API)
            .build();

    googleApiClient.connect();

    final WatchViewStub stub = (WatchViewStub) findViewById(R.id.watch_view_stub);
    stub.setOnLayoutInflatedListener(new WatchViewStub.OnLayoutInflatedListener() {
        @Override
        public void onLayoutInflated(WatchViewStub stub) {
            fireMessage();
        }

        private void fireMessage() {
            // Send the RPC
            PendingResult<NodeApi.GetConnectedNodesResult> nodes = Wearable.NodeApi.getConnectedNodes(googleApiClient);
            nodes.setResultCallback(new ResultCallback<NodeApi.GetConnectedNodesResult>() {
                @Override
                public void onResult(NodeApi.GetConnectedNodesResult result) {
                    for (int i = 0; i < result.getNodes().size(); i++) {
                        Node node = result.getNodes().get(i);
                        String nName = node.getDisplayName();
                        String nId = node.getId();
                        Log.d(TAG, "Node name and ID: " + nName + " | " + nId);

                        Wearable.MessageApi.addListener(googleApiClient, new MessageApi.MessageListener() {
                            @Override
                            public void onMessageReceived(MessageEvent messageEvent) {
                                Log.d(TAG, "Message received: " + messageEvent);
                            }
                        });

                        PendingResult<MessageApi.SendMessageResult> messageResult = Wearable.MessageApi.sendMessage(googleApiClient, node.getId(),
                                PATH, null);
                        messageResult.setResultCallback(new ResultCallback<MessageApi.SendMessageResult>() {
                            @Override
                            public void onResult(MessageApi.SendMessageResult sendMessageResult) {
                                Status status = sendMessageResult.getStatus();
                                Log.d(TAG, "Status: " + status.toString());
                                if (status.getStatusCode() != WearableStatusCodes.SUCCESS) {
                                    alertButton.setProgress(-1);
                                    label.setText("Tap to retry. Alert not sent :(");
                                }
                            }
                        });
                    }
                }
            });
        }
    });
}

Запись, похоже, указывает, что сообщение отправлено успешно, но приложение Android WearableListenerService.onMessageReceived никогда не срабатывает.

D/MyWearApp MyActivity( 2014): Node name and ID: a2ba665d-a559-4a95-91d2-c16fc7873e28 | a2ba665d-a559-4a95-91d2-c16fc7873e28
D/MyWearApp MyActivity( 2014): Status: Status{statusCode=SUCCESS, resolution=null}

Любые идеи?

4b9b3361

Ответ 1

Вы гарантировали, что " applicationId" одинаково для обоих приложений, то есть для приложения на Android Wear и в приложении на телефоне?

Ответ 2

У меня была такая же проблема, когда я добавил поддержку Android Wear для существующего приложения. Однако после нескольких часов разочарования. Я обнаружил проблему.

Я забыл добавить элементы подписи из build.gradle в приложении устройства в приложении для изнашивания. Поэтому убедитесь, что часть buildTypes и часть signedConfigs одинаковы в обоих приложениях.

Ответ 3

У меня была аналогичная проблема, как обсуждалось здесь https://plus.google.com/116088533685577893615/posts/deCyoF6ALvV. Основываясь на моих экспериментах, кажется (хотя и не документировано), что имя пакета приложения для часов должно быть таким же, как и у портативного приложения. Я создал пример проекта для сообщения api здесь https://github.com/petrnalevka/wear.

Ответ 4

Попробуйте добавить wait() в конце вашего метода sendMessage().

PendingResult<MessageApi.SendMessageResult> messageResult = Wearable.MessageApi.sendMessage(googleApiClient, node.getId(),
                                PATH, null).await();

Предыдущий ответ ниже для отправки сообщения, только когда активна активность на Android-устройстве (мобильном телефоне).

Поскольку вы пытаетесь отправить сообщение с Android Wear на устройство Android, слушатель сообщения должен быть добавлен в Activity на устройстве Android, а не в Android Wear, следующие коды должны быть добавлены в MainActivity на Android (мобильный)

final GoogleApiClient googleApiClient = new GoogleApiClient.Builder(this)
        .addApi(Wearable.API)
        .build();

googleApiClient.connect();

Wearable.MessageApi.addListener(googleApiClient, new MessageApi.MessageListener() {
         @Override
         public void onMessageReceived(MessageEvent messageEvent) {
                  Log.d(TAG, "Message received: " + messageEvent.getPath());
         }
});

Вы также можете попробовать более простой метод SendMessage()

SendMessageResult result = Wearable.MessageApi.sendMessage(
        mGoogleApiClient, node.getId(), "STRING TO BE SENT", null).await();
if (!result.getStatus().isSuccess()) {
    Log.e(TAG, "ERROR: failed to send Message: " + result.getStatus());
}

Ответ 5

У меня есть пример кода, в котором у меня есть сообщения, работающие от износа до устройства и устройства. https://github.com/kentarosu/AndroidWearAndLIFX

Ответ 6

Несколько месяцев назад у меня была такая же проблема во время работы с износом android. Моя проблема заключалась в различной подписке (отпечатки пальцев SHA, сгенерированные после подписания apks) обоих apk, в то время как клавиши приложения были одинаковыми. Обратитесь к ссылке ниже:

OnMessageReceived не вызван в WearableListenerService

Надеюсь, это поможет кому-то.

Ответ 7

Обычными подозреваемыми являются:

  • applicationId, как упомянули другие, и
  • используемые подписывающие сертификаты

В основном случае следующие части должны быть идентичными в конфигурациях gradle обоих приложений.

defaultConfig {
    applicationId = "com.your.domain" 
}

signingConfigs {
    debug {
        storeFile file("../debug.keystore")
    }
    release {
        storeFile file("../release.keystore")
    }
} 

Оба приложения должны использовать один и тот же файл приложения и подписываться с тем же сертификатом.