Funkcja Quick Access Wallet, dostępna w Androidzie 11, umożliwia użytkownikowi dostęp do kart płatniczych i odpowiednich kart dostępu bezpośrednio z menu zasilania. Główne przypadki użycia obejmują wybór odpowiedniej formy płatności przed dokonaniem transakcji w terminalu NFC oraz szybki dostęp do lotów i innych kart na nadchodzące wydarzenia.
Na Androidzie 12 i nowszych funkcja Portfel w szybkim dostępie jest dostępna w obszarze powiadomień, tak jak na ilustracjach 1 i 2.
Na Androidzie 11 ta funkcja jest dostępna w menu zasilania, jak pokazano na rys. 3.
Wymagania
Aby korzystać z funkcji Szybki dostęp do Portfela, musisz mieć na urządzeniu komunikację NFC. Ta funkcja wiąże się z QuickAccessWalletService
domyślnej aplikacji płatniczej NFC, co oznacza, że urządzenie musi też obsługiwać emulację kart hosta (HCE) NFC.
Omówienie funkcji
Szybki dostęp do Portfela składa się z 2 części: interfejsu Szybkiego dostępu do Portfela i dostawcy kart Szybkiego dostępu do Portfela.
W Androidzie 12 lub nowszym interfejs Portfel działa w interfejsie systemowym i znajduje się w sekcji frameworks/base/packages/SystemUI/src/com/android/systemui/wallet
. W Androidzie 11 interfejs Portfela, który znajduje się w sekcji platform/packages/apps/QuickAccessWallet
, musi zostać zainstalowany i umieszczony na białej liście.
Dostawca karty Portfela Szybkiego Dostępu to domyślna aplikacja do płatności NFC. Użytkownicy mogą mieć zainstalowane jednocześnie kilka aplikacji do płatności NFC, ale tylko domyślna aplikacja do płatności NFC może wyświetlać karty w menu zasilania. Możesz określić, która aplikacja płatnicza z użyciem NFC ma być początkowo domyślna, ale użytkownicy mogą wybrać inną aplikację w Ustawieniach. Jeśli zainstalowana jest tylko 1 aplikacja do płatności NFC, automatycznie staje się ona domyślną (patrz: CardEmulationManager
).
Implementacja
Aby udostępniać karty w interfejsie Portfela Szybkiego Dostępu, aplikacje do płatności NFC muszą implementować QuickAccessWalletService
.
Aplikacje do płatności muszą zawierać wpis w pliku manifestu reklamujący usługę.
Aby mieć pewność, że tylko interfejs systemowy może się łączyć z QuickAccessWalletService
, aplikacja do płatności NFC musi wymagać uprawnienia android.permission.BIND_QUICK_ACCESS_WALLET_SERVICE
. Wymaganie tego uprawnienia zapewnia, że tylko interfejs UI systemu może się wiązać z elementem QuickAccessWalletService
.
<service
android:name=".MyQuickAccessWalletService"
android:label="@string/my_default_tile_label"
android:icon="@drawable/my_default_icon_label"
android:logo="@drawable/my_wallet_logo"
android:permission="android.permission.BIND_QUICK_ACCESS_WALLET_SERVICE">
<intent-filter>
<action android:name="android.service.quickaccesswallet.QuickAccessWalletService" />
<category android:name="android.intent.category.DEFAULT"/>
</intent-filter>
<meta-data android:name="android.quickaccesswallet"
android:resource="@xml/quickaccesswallet_configuration" />
<meta-data
android:name="android.quickaccesswallet.tile"
android:resource="@drawable/my_default_tile_icon"/>
</service>
Dodatkowe informacje o portfelu są zawarte w połączonym pliku XML:
<quickaccesswallet-service
xmlns:android="http://schemas.android.com/apk/res/android"
android:settingsActivity="com.example.android.SettingsActivity"
android:shortcutLongLabel="@string/my_wallet_empty_state_text"
android:shortcutShortLabel="@string/my_wallet_button_text"
android:targetActivity="com.example.android.WalletActivity"/>
Następnie aplikacja do płatności musi zaimplementować QuickAccessWalletService
:
public class MyQuickAccessWalletService extends QuickAccessWalletService {
@Override
public void onWalletCardsRequested(
GetWalletCardsRequest request,
GetWalletCardsCallback callback) {
GetWalletCardsResponse response = // generate response
callback.onSuccess(response);
}
@Override
public void onWalletCardSelected(SelectWalletCardRequest request) {
// selecting a card should ensure that it is used when making an NFC payment
}
@Override
public void onWalletDismissed() {
// May un-select card if the wallet app has the concept of a 'default'
// payment method
}
}
Jeśli usługa HostApduService
zacznie obsługiwać transakcję NFC i w konsekwencji uruchomi aktywność, aby wyświetlić postęp i wynik płatności, powinna też spróbować uzyskać odwołanie do powiązanej usługi QuickAccessWalletService
i wywołać usługę QuickAccessWalletService#sendEvent
z typem zdarzenia TYPE_NFC_PAYMENT_STARTED
. Spowoduje to zamknięcie interfejsu portfela Szybki dostęp, dzięki czemu użytkownik będzie miał pełny widok aktywności związanej z płatnościami.
Więcej informacji o wdrażaniu QuickAccessWalletService
znajdziesz w dokumentacji QuickAccessWalletService
oraz w teście CTS TestQuickAccessWalletService
.
Włączanie interfejsu Portfela Szybkiego Dostępu w Androidzie 11
Aby skonfigurować portfel Quick Access Wallet tak, aby był dostępny w menu zasilania w Androidzie 11, dodaj do kompilacji obiekt QuickAccessWallet
i włącz wtyczkę globalactions.wallet
, dodając do pliku overlay/frameworks/base/packages/SystemUI/res/values/config.xml
wiersz pogrubiony w przykładowym kodzie poniżej.
<resources> ... <!-- SystemUI Plugins that can be loaded on user builds. --> <string-array name="config_pluginWhitelist" translatable="false"> <item>com.android.systemui</item> <item>com.android.systemui.plugin.globalactions.wallet</item> </string-array> </resources>
W pliku konfiguracyjnym ustawień użyj parametru def_nfc_payment_component
, aby określić domyślną aplikację do płatności NFC.
Domyślna aplikacja do płatności NFC musi udostępniać karty QuickAccessWalletService
, aby udostępniać karty w Portfelu Szybkiego Dostępu. Jeśli domyślna aplikacja płatnicza NFC nie eksportuje tej usługi, interfejs portfela jest ukryty.
Szczegóły implementacji usługi QuickAccessWalletService
QuickAccessWalletService
udostępnia 3 abstrakcyjne metody, które należy wdrożyć: onWalletCardsRequested
, onWalletCardSelected
i onWalletDismissed
. Poniższy diagram sekwencji przedstawia sekwencję wywołań, gdy widoczny jest portfel Quick Access Wallet bezpośrednio przed płatnością NFC.
Nie wszystkie widoki Portfela Szybkiego Dostępu są poprzedzone płatnością NFC, ale rycina 4 powyżej przedstawia wszystkie możliwości
QuickAccessWalletService
. W tym przykładzie dostawca karty Szybki dostęp do Portfela implementuje elementy zaznaczone na niebiesko. Zakłada się, że karty płatnicze są przechowywane na urządzeniu w bazie danych i dostęp do nich jest możliwy za pomocą interfejsu o nazwie PaymentCardManager
. Zakładamy też, że aktywność o nazwie PaymentActivity
wyświetla wynik płatności NFC. Proces przebiega w ten sposób:
- Użytkownik wykonuje gest, aby otworzyć Portfel szybkiego dostępu.
Interfejs użytkownika Portfela Szybkiego Dostępu (część interfejsu System UI) sprawdza menedżera pakietów, aby sprawdzić, czy domyślna aplikacja do płatności NFC eksportuje dane.
QuickAccessWalletService
- Jeśli usługa nie jest eksportowana, Portfel Szybki dostęp nie jest wyświetlany.
Interfejs użytkownika Portfela Szybki dostęp łączy się z
QuickAccessWalletService
i wywołujeonWalletCardsRequested
. Ta metoda przyjmuje obiekt żądania zawierający dane o liczbie i rozmiarze kart, które można podać, oraz funkcję wywołania zwrotnego. Funkcja callback może być wywoływana z wątku tła.QuickAccessWalletService
oblicza karty, które chce wyświetlić, a następnie wywołuje metodęonSuccess
w ramach podanego wywołania zwrotnego. Zalecamy, aby usługa wykonywała te czynności w wątku w tle.Gdy tylko karty się wyświetlą, interfejs systemu powiadomi
QuickAccessWalletService
, że pierwsza karta została wybrana, wywołując funkcjęonWalletCardSelected
.- Funkcja
onWalletCardSelected
jest wywoływana za każdym razem, gdy użytkownik wybierze nową kartę. - Funkcja
onWalletCardSelected
może zostać wywołana nawet wtedy, gdy wybrana aktualnie karta się nie zmieniła.
- Funkcja
Gdy użytkownik zamknie Portfel Szybki dostęp, interfejs użytkownika systemu wyśle powiadomienie
QuickAccessWalletService
, wywołując funkcjęonWalletDismissed
.
W powyższym przykładzie użytkownik zbliża telefon do terminala płatniczego z modułem NFC, gdy wyświetla się portfel. Kluczowym elementem obsługi płatności NFC jest HostApduService
, który musi zostać zaimplementowany w celu przetwarzania APDU udostępnianych przez czytnik NFC (więcej informacji znajdziesz w emulacji karty hosta).
Zakładamy, że aplikacja płatnicza rozpoczyna działanie, aby wyświetlić postęp i wynik interakcji z terminalem NFC. Interfejs Portfela Szybki dostęp jest jednak wyświetlany na górze okna aplikacji, co oznacza, że aktywność związana z płatnościami jest zasłonięta przez interfejs Portfela Szybki dostęp. Aby rozwiązać ten problem, aplikacja musi powiadomić interfejs systemu o tym, że interfejs Portfela szybkiego dostępu powinien zostać zamknięty. Aby to zrobić, pobiera odwołanie do powiązanej wartości QuickAccessWalletService
i wywołuje funkcję sendWalletServiceEvent
z typem zdarzenia TYPE_NFC_PAYMENT_STARTED
.
Przykładowa implementacja QuickAccessWalletService
/** Sample implementation of {@link QuickAccessWalletService} */
@RequiresApi(VERSION_CODES.R)
public class MyQuickAccessWalletService extends QuickAccessWalletService {
private static final String TAG = "QAWalletSvc";
private ExecutorService executor;
private PaymentCardManager paymentCardManager;
@Override
public void onCreate() {
super.onCreate();
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
Log.w(TAG, "Should not run on pre-R devices");
stopSelf();
return;
}
executor = Executors.newSingleThreadExecutor();
paymentCardManager = new PaymentCardManager();
}
@Override
public void onDestroy() {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
return;
}
executor.shutdownNow();
}
@Override
public void onWalletCardsRequested(
@NonNull GetWalletCardsRequest request, @NonNull GetWalletCardsCallback callback) {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
return;
}
executor.submit(
() -> {
List<PaymentCard> paymentCards = paymentCardManager.getCards();
int maxCards = Math.min(paymentCards.size(), request.getMaxCards());
List<WalletCard> walletCards = new ArrayList<>(maxCards);
int selectedIndex = 0;
int cardWidthPx = request.getCardWidthPx();
int cardHeightPx = request.getCardHeightPx();
for (int index = 0; index < maxCards; index++) {
PaymentCard paymentCard = paymentCards.get(index);
WalletCard walletCard =
new WalletCard.Builder(
paymentCard.getCardId(),
paymentCard.getCardImage(cardWidthPx, cardHeightPx),
paymentCard.getContentDescription(),
paymentCard.getPendingIntent())
.build();
walletCards.add(walletCard);
if (paymentCard.isSelected()) {
selectedIndex = index;
}
}
GetWalletCardsResponse response =
new GetWalletCardsResponse(walletCards, selectedIndex);
callback.onSuccess(response);
});
}
@Override
public void onWalletCardSelected(@NonNull SelectWalletCardRequest request) {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
return;
}
executor.submit(
() -> paymentCardManager.selectCardById(request.getCardId()));
}
@Override
public void onWalletDismissed() {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.R) {
return;
}
executor.submit(() -> {
paymentCardManager.removeCardOverrides();
});
}
}
Więcej informacji o QuickAccessWalletService
znajdziesz w dokumentacji interfejsu API QuickAccessWalletService
.
Uprawnienia
Wpis w pliku manifestu dla QuickAccessWalletService
musi wymagać uprawnienia android.permission.BIND_QUICK_ACCESS_WALLET_SERVICE
wprowadzonego w Androidzie 11. To uprawnienie na poziomie podpisu jest przypisywane przez interfejs systemowy, co oznacza, że tylko proces interfejsu systemowego może się wiązać z implementacjami QuickAccessWalletService
. Pamiętaj, że aplikacje ładowane z zewnętrznych źródeł mogą żądać tego uprawnienia i uzyskać pełny dostęp do danych QuickAccessWalletService
na urządzeniach z Androidem 10 lub starszym. Aby temu zapobiec, zalecamy sprawdzenie wersji kompilacji w onCreate
i włączenie usługi tylko na urządzeniach z Androidem 11 lub nowszym. Oprócz uprawnień niezbędnych do świadczenia usług płatności w ramach emulacji karty hosta nie są wymagane żadne inne uprawnienia aplikacji.
Jeśli domyślna aplikacja do płatności NFC nie obsługuje eksportowania danych QuickAccessWalletService
, interfejs Portfela Szybkiego Dostępu nie jest wyświetlany.
Ustawienia w Androidzie 12
Aby włączyć lub wyłączyć Portfel szybkiego dostępu na ekranie blokady, użytkownicy mogą użyć przełącznika Pokaż portfel w sekcji Ustawienia > Wyświetlacz > Ekran blokady. Aby wyłączyć portfel w panelu, użytkownicy muszą ręcznie go edytować w panelu szybkich ustawień.
Rysunek 5. Wyświetl przełącznik portfela na stronie ekranu blokady w Ustawieniach.
Ustawienia w Androidzie 11
Użytkownicy mogą wyłączyć funkcję Portfela szybkiego dostępu w aplikacji Ustawienia. Stronę ustawień znajdziesz, klikając Ustawienia > System > Gesty > Karty i bilety.
Dostosowywanie
Dodawanie widoku Portfela Szybki dostęp w innym miejscu w interfejsie systemu
Interfejs Szybki dostęp do Portfela został stworzony jako wtyczka systemowa.
Chociaż implementacja AOSP używa tej funkcji w GlobalActionsDialog
(wyświetlana po długim naciśnięciu przycisku zasilania), możesz użyć innej czynności, o ile nie naruszy to umowy określonej przez interfejs wtyczki.
public interface GlobalActionsPanelPlugin extends Plugin {
/** Invoked when the view is shown */
PanelViewController onPanelShown(Callbacks callbacks, boolean deviceLocked);
/** Callbacks for interacting with the view container */
interface Callbacks {
/** Dismisses the view */
void dismissGlobalActionsMenu();
/** Starts a PendingIntent, dismissing the keyguard if necessary. */
void startPendingIntentDismissingKeyguard(PendingIntent pendingIntent);
}
/** Provides the Quick Access Wallet view */
interface PanelViewController {
/** Returns the QuickAccessWallet view, which may take any size */
View getPanelContent();
/** Invoked when the view is dismissed */
void onDismissed();
/** Invoked when the device is either locked or unlocked. */
void onDeviceLockStateChanged(boolean locked);
}
}
Interfejs Portfela Szybki dostęp implementuje GlobalActionsPanelPlugin
i PanelViewController
.
GlobalActionsDialog
pobiera instancję wtyczki Portfela za pomocą:
com.android.systemui.Dependency
:
GlobalActionsPanelPlugin mPanelPlugin =
Dependency.get(ExtensionController.class)
.newExtension(GlobalActionsPanelPlugin.class)
.withPlugin(GlobalActionsPanelPlugin.class)
.build()
.get();
Po sprawdzeniu, czy wtyczka nie ma wartości null, a pole PanelViewController
zwrócone przez onPanelShown
nie ma wartości null, okno łączy tag View
udostępniony przez getPanelContent
do jego własnej wartości View
i wyświetla odpowiednie wywołania zwrotne dla zdarzeń systemowych.
// Construct a Wallet PanelViewController.
// `this` implements GlobalActionsPanelPlugin.Callbacks
GlobalActionsPanelPlugin.PanelViewController mPanelController =
mPanelPlugin.onPanelShown(this, !mKeyguardStateController.isUnlocked());
// Attach the view
FrameLayout panelContainer = findViewById(R.id.my_panel_container);
FrameLayout.LayoutParams panelParams =
new FrameLayout.LayoutParams(
FrameLayout.LayoutParams.MATCH_PARENT,
FrameLayout.LayoutParams.MATCH_PARENT);
panelContainer.addView(mPanelController.getPanelContent(), panelParams);
// Respond to unlock events (if the view can be accessed while the phone is locked)
keyguardStateController.addCallback(new KeyguardStateController.Callback() {
@Override
public void onUnlockedChanged() {
boolean unlocked = keyguardStateController.isUnlocked()
|| keyguardStateController.canDismissLockScreen();
mPanelController.onDeviceLockStateChanged(unlocked);
}
});
// Implement GlobalActionsPanelPlugin.Callbacks
@Override
public void dismissGlobalActionsMenu() {
dismissDialog();
}
@Override
public void startPendingIntentDismissingKeyguard(PendingIntent pendingIntent) {
mActivityStarter.startPendingIntentDismissingKeyguard(pendingIntent);
}
// Notify the wallet when the container view is dismissed
mPanelController.onDismissed();
Aby usunąć Portfel szybkiego dostępu z menu zasilania, pomiń cel QuickAccessWallet
w kompilacji systemu. Aby usunąć portfel Szybki dostęp z menu zasilania, ale dodać go do innego widoku interfejsu użytkownika, dodaj ustawienie docelowe kompilacji i usuń odwołania do GlobalActionsPanelPlugin
z GlobalActionsImpl
.
Ustaw konfiguracje domyślne
Android 12
W Androidzie 12 lub nowszym Szybki dostęp do Portfela jest zawsze widoczny w panelu Szybkie ustawienia. Widoczność portfela Szybki dostęp na ekranie blokady zależy od tego ustawienia zabezpieczeń:LOCKSCREEN_SHOW_WALLET
. To ustawienie określa, czy ikona Szybkiego dostępu do portfela ma być widoczna w prawym dolnym rogu ekranu blokady. Domyślne ustawienie to true
, ale użytkownik może go wyłączyć, klikając Ustawienia > Wyświetlacz > Ekran blokady > Pokaż portfel.
Android 11
W Androidzie 11 widoczność Portfela Szybkiego dostępu zależy od 2 ustawień zabezpieczeń:
GLOBAL_ACTIONS_PANEL_ENABLED
i GLOBAL_ACTIONS_PANEL_AVAILABLE
. Ustawienie AVAILABLE
określa, czy tę funkcję można włączać i wyłączać w Ustawieniach. To ustawienie jest skonfigurowane jako true
przez WalletPluginService
.
Jeśli QuickAccessWallet
nie jest uwzględniona w kompilacji, ustawienie pozostaje na poziomie false
. Ustawienie ENABLED
jest domyślnie ustawione na true
w tym samym miejscu, ale użytkownik może je wyłączyć w Ustawieniach. Aby zmienić działanie domyślne, zmień wartość WalletPluginService#enableFeatureInSettings
.
Weryfikacja
Aby zweryfikować implementację Portfela Szybkiego Dostępu, uruchom testy CTS i testy ręczne. Zmiany w wtyczce powinny też obejmować zawarte w niej testy Robolectric.
Testy CTS
Uruchom testy CTS dostępne pod adresem cts/tests/quickaccesswallet
.
Testy ręczne na Androidzie 12
Testowanie podstawowych funkcji Portfela Szybkiego Dostępu wymaga terminala do płatności NFC (prawdziwego lub symulowanego) oraz aplikacji do płatności NFC, która implementuje QuickAccessWalletService
(aplikację Portfela). Funkcje podstawowe, które należy przetestować, to: dostępność, stan zerowy, wybór karty i zachowanie ekranu blokady.
Dostępność
- Jeśli domyślna aplikacja płatnicza NFC nie obsługuje tej funkcji, Portfel z szybkim dostępem nie będzie dostępny ani w szybkich ustawieniach, ani na ekranie blokady.
- Jeśli domyślna aplikacja do płatności NFC obsługuje tę funkcję, portfel Szybki dostęp jest dostępny w panelu Szybkie ustawienia.
- Jeśli domyślna aplikacja do płatności NFC obsługuje tę funkcję, a ustawienie
LOCKSCREEN_SHOW_WALLET
ma wartośćtrue
, Portfel Szybkiego Dostępu jest dostępny na ekranie blokady. - Jeśli domyślna aplikacja do płatności NFC obsługuje tę funkcję i ustawienie
LOCKSCREEN_SHOW_WALLET
tofalse
, Portfel Szybkiego Dostępu nie będzie dostępny na ekranie blokady.
Stan zero
Jeśli zasada
QuickAccessWalletService
jest włączona i wyeksportowana, ale nie zawiera żadnych kart, kafelek w cieniu jest widoczny w przykładzie na rys. 7. Kliknięcie kafelka powoduje otwarcie domyślnej aplikacji do płatności NFC.Rysunek 7. Przykładowy kafelek w cieniu przedstawiający domyślną aplikację płatniczą NFC.
Kliknięcie pustego widoku stanu, jak pokazano na rys. 8, otwiera domyślną aplikację płatniczą NFC. Ten pusty widok stanu wyświetla się tylko wtedy, gdy użytkownik pozostawi jedną kartę w portfelu, usuwa ją ze strony z danymi karty, a potem wróci do widoku portfela.
Na ekranie blokady widoczna jest ikona portfela.
Rysunek 8. Widok pustego stanu w interfejsie Portfela w sekcji Szybki dostęp.
Stan inny niż 0
Jeśli aplikacja Portfel udostępnia co najmniej 1 kartę, kafelek w kolorze będzie wyglądał tak, jak na rysunku 9.
Rysunek 9. Przykład kafelka w cieniach, gdy aplikacja Portfel ma co najmniej 1 kartę
Po kliknięciu kafelka wyświetla się karuzela kart.
Na ekranie blokady widoczny jest przycisk, który otwiera Portfel Szybkiego Dostępu.
Rysunek 10. Widok interfejsu Portfela w Szybkim dostępie z wyświetloną kartą.
Jeśli wyświetlona karta reprezentuje formę płatności NFC, przyłożenie telefonu do terminala płatniczego NFC spowoduje użycie tej formy płatności i zamknięcie widoku portfela.
Kliknięcie wyświetlonej karty powoduje otwarcie szczegółowych informacji o tej aktywności.
Jeśli
QuickAccessWalletService
udostępnia wiele kart, użytkownik może przełączać się między nimi.Rozszerzone menu zawiera 1 pozycję: otwórz ustawienia ekranu blokady, aby użytkownik mógł zmienić opcję Pokaż portfel.
Testy stanu blokady
- Gdy telefon jest zablokowany, w obszarze szybkich ustawień widoczny jest portfel wraz z opisem Dodaj kartę, jeśli w domyślnej aplikacji płatniczej nie ma karty, lub odblokuj, aby używać, jeśli karta jest zapisana w domyślnej aplikacji płatniczej.
- Jeśli telefon jest zablokowany, widoczność portfela na ekranie blokady jest kontrolowana przez ustawienie
Secure.LOCKSCREEN_SHOW_WALLET
, które jest kontrolowane w Ustawieniach. - Jeśli telefon jest zablokowany,
LOCKSCREEN_SHOW_WALLET
jestfalse
, a w domyślnej aplikacji do płatności NFC nie ma żadnej karty, portfel nie jest wyświetlany na ekranie blokady. - Jeśli telefon jest zablokowany,
LOCKSCREEN_SHOW_WALLET
jesttrue
, a w domyślnej aplikacji do płatności NFC nie ma żadnej karty, portfel nie jest wyświetlany na ekranie blokady. - Jeśli telefon jest zablokowany,
LOCKSCREEN_SHOW_WALLET
jesttrue
, a karty są dostępne w domyślnej aplikacji do płatności NFC, portfel jest wyświetlany na ekranie blokady. - Odblokowanie telefonu, gdy portfel jest wyświetlany na ekranie blokady, powoduje ponowne zażądanie kart, co może skutkować wyświetleniem innej zawartości karty.
Testy ułatwień dostępu
- Użytkownicy TalkBack mogą poruszać się po widoku portfela, przesuwając palcem w lewo i prawo oraz słuchając opisów treści na kartach.
- Przesuwanie palcem w lewo i w prawo przy włączonej funkcji TalkBack powoduje kolejne karty. Użytkownicy TalkBack mogą wybrać formę płatności NFC i z niej korzystać w terminalu płatniczym NFC.
Testy ręczne na Androidzie 11
Testowanie podstawowych funkcji Portfela Szybkiego Dostępu wymaga terminala do płatności NFC (prawdziwego lub symulowanego) oraz aplikacji do płatności NFC, która implementuje QuickAccessWalletService
(aplikację Portfela). Główne funkcje, które należy przetestować, to dostępność, stan zero, wybór karty i działanie ekranu blokady.
Dostępność
- Jeśli ustawienie
GLOBAL_ACTIONS_PANEL_ENABLED
ma wartośćtrue
, a domyślna aplikacja do płatności NFC obsługuje tę funkcję, Portfel Szybki dostęp jest dostępny. - Jeśli ustawienie
GLOBAL_ACTIONS_PANEL_ENABLED
ma wartośćfalse
, a domyślna aplikacja płatnicza obsługuje tę funkcję, Portfel w szybkim dostępie nie jest dostępny. - Jeśli ustawienie
GLOBAL_ACTIONS_PANEL_ENABLED
totrue
, a domyślna aplikacja do płatności NFC nie obsługuje tej funkcji, Portfel Szybkiego Dostępu nie będzie dostępny. - Jeśli ustawienie
GLOBAL_ACTIONS_PANEL_ENABLED
tofalse
, a domyślna aplikacja do płatności NFC nie obsługuje tej funkcji, Portfel Szybkiego Dostępu nie będzie dostępny.
Stan zerowy
- Jeśli
QuickAccessWalletService
jest włączone i wyeksportowane, ale nie zawiera żadnych kart, interfejs Portfela w szybkim dostępie wyświetla pusty stan. Kliknięcie pustego stanu powoduje otwarcie aplikacji Portfel.
Stan inny niż 0
Jeśli aplikacja portfela obsługuje co najmniej jedną kartę, są one wyświetlane w interfejsie Portfela w szybkim dostępie.
Jeśli wyświetlona karta reprezentuje formę płatności NFC, przyłożenie telefonu do terminala płatniczego NFC spowoduje użycie tej formy płatności i zamknięcie widoku portfela.
Kliknięcie wyświetlonej karty powoduje zamknięcie widoku portfela i otwarcie szczegółowej aktywności tej karty.
Jeśli
QuickAccessWalletService
udostępnia wiele kart, użytkownik może przełączać się między nimi.Menu przepełnienia zawiera 2 pozycje: jedną, która otwiera aplikację Portfel, a drugą, która otwiera w Ustawieniach ekran Pokaż karty i karty dostępu.
Testy stanu blokady
- Gdy telefon jest zablokowany, widoczność portfela jest kontrolowana przez ustawienie
Settings.Secure.POWER_MENU_LOCK_SHOW_CONTENT
, którym można zarządzać w Ustawieniach. - Jeśli telefon jest zablokowany, a
POWER_MENU_LOCK_SHOW_CONTENT
ma wartośćfalse
, portfel nie jest widoczny. - Jeśli telefon jest zablokowany, a
POWER_MENU_LOCK_SHOW_CONTENT
jesttrue
, wyświetla się portfel. - Odblokowanie telefonu, gdy portfel jest widoczny na ekranie blokady, powoduje ponowne wyszukanie kart, co może spowodować wyświetlenie innej zawartości karty.
Testy ułatwień dostępu
- Użytkownicy TalkBack mogą poruszać się po widoku portfela, przesuwając palcem w lewo i prawo oraz słuchając opisów treści na kartach.
- Przesuwanie palcem w lewo i w prawo przy włączonej funkcji TalkBack powoduje kolejno wybieranie kolejnych kart. Użytkownicy TalkBack mogą wybrać formę płatności NFC i z niej korzystać w terminalu płatniczym NFC.