Integrar avaliações no app (Unity)

Este guia descreve como integrar avaliações no app usando o Unity. Há guias de integração separados se você estiver usando o Kotlin ou Java ou código nativo.

Visão geral do SDK do Unity

A API Play In-App Review faz parte da família do SDK do Play Core. A API para Unity oferece uma classe ReviewManager para solicitar e iniciar o fluxo usando os métodos RequestReviewFlow e LaunchReviewFlow. Depois que uma solicitação for feita, seu app poderá verificar o status dela usando ReviewErrorCode.

Configurar seu ambiente de desenvolvimento

OpenUPM-CLI

Se você tiver a CLI do OpenUPM instalada, poderá instalar o registro do OpenUPM com o seguinte comando:

openupm add com.google.play.review

OpenUPM

  1. Abra as configurações do gerenciador de pacotes selecionando a opção de menu do Unity Edit > Project Settings > Package Manager.

  2. Adicione o OpenUPM como um registro de escopo à janela do Gerenciador de pacotes:

    Name: package.openupm.com
    URL: https://package.openupm.com
    Scopes: com.google.external-dependency-manager
      com.google.play.common
      com.google.play.core
      com.google.play.review
    
  3. Abra o menu do gerenciador de pacotes selecionando a opção de menu do Unity Window > Package Manager.

  4. Defina o menu suspenso "Escopo do administrador" para selecionar Meus registros.

  5. Selecione o pacote Google Play Integrity plugin for Unity na lista de pacotes e pressione Install.

Importar do GitHub

  1. Faça o download da versão mais recente do .unitypackage no GitHub.

  2. Importe o arquivo .unitypackage selecionando a opção de menu do Unity Assets > Import package > Custom Package e importando todos os itens.

Criar o ReviewManager

Crie uma instância de ReviewManager que processe a comunicação entre seu app e a API.

// Create instance of ReviewManager
private ReviewManager _reviewManager;
// ...
_reviewManager = new ReviewManager();

Solicitar um objeto ReviewInfo

Siga as orientações sobre quando solicitar avaliações no app para determinar bons pontos no fluxo do usuário para solicitar uma avaliação (por exemplo, depois de um usuário dispensa a tela de resumo ao final de um nível em um jogo). Quando o app estiver perto de um desses pontos, use a instância de ReviewManager para criar uma operação assíncrona, como mostrado no exemplo a seguir:

var requestFlowOperation = _reviewManager.RequestReviewFlow();
yield return requestFlowOperation;
if (requestFlowOperation.Error != ReviewErrorCode.NoError)
{
    // Log error. For example, using requestFlowOperation.Error.ToString().
    yield break;
}
_playReviewInfo = requestFlowOperation.GetResult();

Se a chamada for bem-sucedida, a API retornará o objeto PlayReviewInfo necessário para iniciar o fluxo de avaliação no app. No exemplo, a chamada é feita dentro de uma corrotina para executar a operação assíncrona. Isso não bloqueia a linha de execução principal. Como a chamada é feita de maneira assíncrona, ela pode demorar alguns segundos. Assim, o app precisa fazer a chamada antes de chegar ao ponto no fluxo de usuários em que você quer exibir a chamada de avaliação no app.

Iniciar o fluxo de avaliação no app

Depois que o app receber a instância de PlayReviewInfo, ele poderá iniciar o fluxo de avaliação. Observe que o objeto PlayReviewInfo é válido apenas por um período limitado, de modo que seu aplicativo não pode aguardar muito tempo antes de iniciar um fluxo.

var launchFlowOperation = _reviewManager.LaunchReviewFlow(_playReviewInfo);
yield return launchFlowOperation;
_playReviewInfo = null; // Reset the object
if (launchFlowOperation.Error != ReviewErrorCode.NoError)
{
    // Log error. For example, using requestFlowOperation.Error.ToString().
    yield break;
}
// The flow has finished. The API does not indicate whether the user
// reviewed or not, or even whether the review dialog was shown. Thus, no
// matter the result, we continue our app flow.

Próximas etapas

Teste o fluxo de avaliações no app para verificar se a integração está funcionando corretamente.