Utwórz kafelek Szybkie ustawienia płatności za pomocą kodu QR

Szybkie ustawienia to kafelki wyświetlane w panelu Szybkie ustawienia. Użytkownicy mogą klikać te kafelki, aby szybko wykonywać zadania cykliczne. Z tego dokumentu dowiesz się, jak utworzyć niestandardowy kafelek Szybkich ustawień z kodem QR płatności.

Zanim przejdziesz dalej, zapoznaj się z ogólnymi instrukcjami metod tworzenia niestandardowych kafelków Szybkich ustawień dla aplikacji.

Aby utworzyć kafelek, wykonaj te czynności:

  1. Utwórz ikonę niestandardową.
  2. Utwórz i zadeklaruj TileService.

  3. Aby uruchomić płatność za pomocą kodu QR, podaj formę płatności onClick(). Długie naciśnięcie kafelek z prośbą o wyświetlenie użytkownikowi ekranu Informacje o aplikacji. Aby zastąpić to działanie i zamiast tego uruchomić aktywność związaną z ustawieniami, dodaj <intent-filter> do jednej z Twoich aktywności z ACTION_QS_TILE_PREFERENCES

    Kotlin

    import android.service.quicksettings.TileService
    
    // Called when the user taps on your tile in an active or inactive state.
    override fun onClick() {
       // Create Intent, replace MainActivity::class.java with QR Code Activity
       val intent = Intent(this, MainActivity::class.java)
       // Create PendingIntent
       val pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_IMMUTABLE)
       if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.UPSIDE_DOWN_CAKE) {
         startActivityAndCollapse(pendingIntent)
       } else {
         intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
         startActivityAndCollapse(intent)
       }
    }
    

    Java

    import android.service.quicksettings.TileService;
    
    // Called when the user taps on your tile in an active or inactive state.
    @Override
    public void onClick() {
     // Create Intent, replace MainActivity.class with QR Code Activity
     Intent intent = new Intent(MyQSTileService.this, MainActivity.class);
     // Create PendingIntent
     PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_IMMUTABLE);
     if (VERSION.SDK_INT >= VERSION_CODES.UPSIDE_DOWN_CAKE) {
       startActivityAndCollapse(pendingIntent);
     } else {
       intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
       startActivityAndCollapse(intent);
     }
    }
    
  4. Aby chronić użytkowników poufnych danych do płatności, wykonuj tylko bezpieczne działania na bezpiecznie zablokowanych urządzeniach.

    Kotlin

    import android.service.quicksettings.TileService
    
    override fun onClick() {
       val intent = Intent(this, MainActivity::class.java)
       val pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_IMMUTABLE)
    
       // ...
    
       if (isSecure()) {
           startActivityAndCollapse(pendingIntent)
       } else {
           unlockAndRun {
               startActivityAndCollapse(pendingIntent)
           }
       }
       // ...
    }
    

    Java

    import android.service.quicksettings.TileService;
    
    @Override
    public void onClick() {
     Intent intent = new Intent(MyQSTileService.this, MainActivity.class);
     PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_IMMUTABLE);
     ...
     if (isSecure()) {
       startActivityAndCollapse(pendingIntent);
     } else {
       unlockAndRun(new Runnable() {
         @Override
         public void run() {
           startActivityAndCollapse(pendingIntent);
         }
       });
      }
     ...
    }
    
  5. Przy pierwszym wprowadzeniu tej funkcji poproś użytkownika o dodanie .