Wykrywanie, kiedy użytkownicy robią zrzuty ekranu na urządzeniu

Komunikat „Aplikacja Pay wykryła ten zrzut ekranu”
Rysunek 1. Przykład komunikatu systemowego, który wyświetla się, gdy użytkownik zrobi zrzut ekranu aplikacji obsługującej interfejs API do wykrywania zrzutów ekranu

Aby zapewnić bardziej ujednolicony sposób wykrywania zrzutów ekranu, Android 14 wprowadza interfejs API do wykrywania zrzutów ekranu, który zapewnia ochronę prywatności. Ten interfejs API umożliwia aplikacjom rejestrowanie wywołań zwrotnych na podstawie aktywności. Te funkcje są wywoływane i użytkownik jest powiadamiany, gdy robi zrzut ekranu, gdy ta aktywność jest widoczna.

Obsługiwane przypadki użycia

W Androidzie 14 interfejs API systemu wykrywa zrzut ekranu tylko wtedy, gdy użytkownik naciśnie określone kombinacje przycisków sprzętowych. Interfejs API nie wykrywa zrzutów ekranu wykonanych podczas wykonywania poleceń testowych związanych ze zrzutami ekranu, w tym ADB, ani w ramach testów instrumentacji, które przechwytują bieżącą zawartość ekranu urządzenia.

Etapy wdrażania

Aby dodać wykrywanie zrzutów ekranu, zadeklaruj nowe uprawnienie DETECT_SCREEN_CAPTURE dodawane w czasie instalacji:

<uses-permission android:name="android.permission.DETECT_SCREEN_CAPTURE" />

Następnie w przypadku każdej czynności w aplikacji, w której użytkownicy mogą robić zrzuty ekranu, wykonaj te czynności:

  1. Zaimplementuj wywołanie zwrotne, zastępując funkcję onScreenCapture(). W tym wywołaniu zwrotnym aplikacja może podjąć działanie, np. ostrzec innego użytkownika, że ktoś zrobił zrzut ekranu rozmowy w aplikacji do obsługi wiadomości.

    Kotlin

    val screenCaptureCallback = Activity.ScreenCaptureCallback {
        // Add logic to take action in your app.
    }

    Java

    final Activity.ScreenCaptureCallback screenCaptureCallback =
        new Activity.ScreenCaptureCallback() {
            @Override
            public void onScreenCaptured() {
                // Add logic to take action in your app.
            }
        };
  2. W metodzie onStart() aktywności zarejestruj wywołanie zwrotne zrzutu ekranu.

    Kotlin

    override fun onStart() {
        super.onStart()
        // Pass in the callback created in the previous step 
        // and the intended callback executor (e.g. Activity's mainExecutor).
        registerScreenCaptureCallback(mainExecutor, screenCaptureCallback)
    }

    Java

    @Override
    protected void onStart() {
        super.onStart();
        // Pass in the callback created in the previous step 
        // and the intended callback executor (e.g. Activity's mainExecutor).
        registerScreenCaptureCallback(executor, screenCaptureCallback);
    }
  3. W metodzie onStop() aktywności anuluj rejestrację funkcji wywołania zwrotnego związanego z zrzutem ekranu:

    Kotlin

    override fun onStop() {
        super.onStop()
        unregisterScreenCaptureCallback(screenCaptureCallback)
    }

    Java

    @Override
    protected void onStop() {
        super.onStop();
        unregisterScreenCaptureCallback(screenCaptureCallback);
    }

kontrolować możliwość robienia zrzutów ekranu.

Jeśli nie chcesz, aby zawartość aktywności aplikacji była widoczna na zrzutach ekranu lub na niezabezpieczonych wyświetlaczach, ustaw flagę wyświetlania FLAG_SECURE.

Kotlin

activity.getWindow().setFlags(LayoutParams.FLAG_SECURE, LayoutParams.FLAG_SECURE)

Java

activity.getWindow().setFlags(LayoutParams.FLAG_SECURE, LayoutParams.FLAG_SECURE);