Publicar e assinar

A Nearby Messages é uma API de publicação-assinatura que permite que dispositivos próximos troquem pequenos payloads de dados. Quando um dispositivo publica uma mensagem, os dispositivos próximos podem receber a mensagem. Este guia orienta você sobre todas as funcionalidades que seu app precisa implementar para publicar mensagens e se inscrever em mensagens usando a API Nearby Messages.

O conjunto de dispositivos próximos é determinado pela troca de pequenos tokens por Bluetooth. Quando um dispositivo detecta um token de um dispositivo próximo, ele envia o token ao servidor do Nearby Messages para validação e verifica se há mensagens a serem enviadas para o conjunto atual de assinaturas do aplicativo.

Um aplicativo pode controlar o conjunto de meios usados para a descoberta de dispositivos e se os meios são usados para transmitir e/ou verificar tokens. Por padrão, a transmissão e a verificação são feitas em todos os meios. Para fazer a descoberta em um subconjunto ou meios e controlar se a transmissão ou a verificação será feita, é necessário transmitir parâmetros adicionais ao criar publicações e assinaturas.

Ao publicar e assinar ativamente, uma notificação "O Nearby está em uso" é apresentada, informando aos usuários que o Nearby está ativo. Essa notificação só aparece quando um ou mais apps estão usando o recurso Por perto ativamente, aos usuários a chance de economizar a bateria se o recurso não for necessário. Ele oferece aos usuários as seguintes opções:

  • Navegue até um app para desativar o recurso "Por perto".
  • Forçar um app a parar de usar o Nearby.
  • Navegue até a tela Configurações do recurso "Por perto".

Você pode usar PublishCallback() e SubscribeCallback() para detectar casos em que um usuário força o app a parar de usar o Nearby. Quando isso acontece, o método onExpired() é acionado.

Como as APIs de mensagens do app Nearby podem afetar a duração da bateria, elas só podem ser usadas em uma atividade em primeiro plano, com exceção da assinatura em segundo plano do BLE.

Chame publish() e/ou subscribe() para usar a API Nearby Messages. O app precisa sempre unpublish() e unsubscribe() simetricamente em onStop().

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    ...
    mMessageListener = new MessageListener() {
        @Override
        public void onFound(Message message) {
            Log.d(TAG, "Found message: " + new String(message.getContent()));
        }

        @Override
        public void onLost(Message message) {
            Log.d(TAG, "Lost sight of message: " + new String(message.getContent()));
        }
    }

    mMessage = new Message("Hello World".getBytes());
}

@Override
public void onStart() {
    super.onStart();
    ...
    Nearby.getMessagesClient(this).publish(mMessage);
    Nearby.getMessagesClient(this).subscribe(mMessageListener);
}

@Override
public void onStop() {
    Nearby.getMessagesClient(this).unpublish(mMessage);
    Nearby.getMessagesClient(this).unsubscribe(mMessageListener);
    ...
    super.onStop();
}

Publicar uma mensagem

Para publicar uma mensagem, chame Nearby.getMessagesClient(Activity).publish() transmitindo a matriz de bytes da mensagem. Recomendamos manter as mensagens com menos de 3 KB, que podem ser enviadas mais rapidamente, mas podemos oferecer suporte a até 100 KB para apps que precisam. Esse serviço não é destinado a trocar objetos maiores, como fotos e vídeos.

Opcionalmente, chame PublishOptions.setStrategy() para definir a estratégia a ser usada.

O exemplo a seguir demonstra como chamar publish() para enviar uma pequena mensagem de texto:

private void publish(String message) {
    Log.i(TAG, "Publishing message: " + message);
    mActiveMessage = new Message(message.getBytes());
    Nearby.getMessagesClient(this).publish(mActiveMessage);
}

Cancelar a publicação de uma mensagem

Para cancelar a publicação de uma mensagem, chame unpublish(). No mínimo, o app precisa chamar a despublicação no método onStop(). Transmita o mesmo objeto Message usado para publicar (mActiveMessage neste exemplo).

O exemplo de código a seguir mostra como chamar unpublish():

private void unpublish() {
    Log.i(TAG, "Unpublishing.");
    if (mActiveMessage != null) {
        Nearby.getMessagesClient(this).unpublish(mActiveMessage);
        mActiveMessage = null;
    }
}

Inscrever-se para receber mensagens

Para se inscrever em mensagens de outros dispositivos, chame Nearby.getMessagesClient(Activity).subscribe(). Você precisa transmitir um MessageListener para processar o recebimento de mensagens assinadas.

Opcionalmente, chame SubscribeOptions.setStrategy() para definir a estratégia a ser usada.

O exemplo a seguir demonstra como se inscrever em mensagens:

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    ...
    mMessageListener = new MessageListener() {
        @Override
        public void onFound(Message message) {
            Log.d(TAG, "Found message: " + new String(message.getContent()));
        }

        @Override
        public void onLost(Message message) {
            Log.d(TAG, "Lost sight of message: " + new String(message.getContent()));
        }
    }
}

// Subscribe to receive messages.
private void subscribe() {
    Log.i(TAG, "Subscribing.");
    Nearby.getMessagesClient(this).subscribe(mMessageListener, options);
}

Cancelar inscrição

Para cancelar a inscrição e parar de receber mensagens do dispositivo, chame Nearby.getMessagesClient(Activity).unsubscribe(). Transmita o mesmo objeto MessageListener usado para se inscrever (mMessageListener neste exemplo).

O exemplo de código abaixo demonstra como cancelar a inscrição:

private void unsubscribe() {
    Log.i(TAG, "Unsubscribing.");
    Nearby.getMessagesClient(this).unsubscribe(mMessageListener);
}