त्वरित पहुँच वॉलेट

एंड्रॉइड 11 से उपलब्ध क्विक एक्सेस वॉलेट सुविधा, उपयोगकर्ता को सीधे पावर मेनू से भुगतान कार्ड और प्रासंगिक पास तक पहुंचने की अनुमति देती है। प्रमुख उपयोग के मामलों में एनएफसी टर्मिनल पर लेनदेन करने से पहले उचित भुगतान विधि का चयन करना और आने वाली घटनाओं के लिए जल्दी से उड़ानों और अन्य पास तक पहुंचना शामिल है।

एंड्रॉइड 12 या उच्चतर में, क्विक एक्सेस वॉलेट सुविधा छाया से उपलब्ध है जैसा कि चित्र 1 और चित्र 2 में दिखाया गया है।

छाया में त्वरित पहुँच वॉलेट सुविधा
चित्रा 1. त्वरित पहुंच वॉलेट सुविधा (डिवाइस लॉक)।
छाया में त्वरित पहुँच वॉलेट सुविधा
चित्रा 2. त्वरित पहुंच वॉलेट सुविधा (डिवाइस अनलॉक)।

एंड्रॉइड 11 में, यह फीचर पावर मेन्यू से उपलब्ध है जैसा कि चित्र 3 में दिखाया गया है।

पावर मेनू में क्विक एक्सेस वॉलेट सुविधा
चित्रा 3. पावर मेनू में त्वरित एक्सेस वॉलेट सुविधा।

आवश्यकताएं

क्विक एक्सेस वॉलेट सुविधा का उपयोग करने के लिए आपके डिवाइस में एनएफसी होना चाहिए। यह सुविधा डिफ़ॉल्ट NFC भुगतान ऐप के QuickAccessWalletService से जुड़ती है, जिसका अर्थ है कि डिवाइस को NFC होस्ट-आधारित कार्ड इम्यूलेशन (HCE) का भी समर्थन करना चाहिए।

फ़ीचर सिंहावलोकन

क्विक एक्सेस वॉलेट के दो हिस्से हैं: क्विक एक्सेस वॉलेट यूआई और क्विक एक्सेस वॉलेट कार्ड प्रदाता।

Android 12 या उच्चतर में, वॉलेट UI सिस्टम UI में चलता है और frameworks/base/packages/SystemUI/src/com/android/systemui/wallet में स्थित होता है। एंड्रॉइड 11 में, वॉलेट यूआई, जो platform/packages/apps/QuickAccessWallet वॉलेट में स्थित है, को स्थापित और श्वेतसूची में होना चाहिए।

क्विक एक्सेस वॉलेट कार्ड प्रदाता डिफ़ॉल्ट एनएफसी भुगतान ऐप है। उपयोगकर्ता एक साथ कई एनएफसी भुगतान ऐप इंस्टॉल कर सकते हैं, लेकिन केवल डिफ़ॉल्ट एनएफसी भुगतान ऐप ही पावर मेनू पर कार्ड दिखा सकता है। आप निर्दिष्ट कर सकते हैं कि कौन सा एनएफसी भुगतान ऐप प्रारंभ में डिफ़ॉल्ट के रूप में सेट है, लेकिन उपयोगकर्ता सेटिंग्स में एक अलग ऐप का चयन कर सकते हैं। यदि केवल एक NFC भुगतान ऐप इंस्टॉल किया गया है, तो यह स्वचालित रूप से डिफ़ॉल्ट हो जाता है (देखें CardEmulationManager )।

कार्यान्वयन

क्विक एक्सेस वॉलेट UI को कार्ड प्रदान करने के लिए, NFC भुगतान ऐप्स को QuickAccessWalletService को लागू करना होगा। भुगतान ऐप्स में सेवा का विज्ञापन करने वाली एक मेनिफेस्ट प्रविष्टि शामिल होनी चाहिए।

यह सुनिश्चित करने के लिए कि केवल सिस्टम UI ही QuickAccessWalletService से जुड़ सकता है, NFC भुगतान ऐप को android.permission.BIND_QUICK_ACCESS_WALLET_SERVICE अनुमति की आवश्यकता होगी। इस अनुमति की आवश्यकता सुनिश्चित करती है कि केवल सिस्टम UI ही 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>

बटुए के बारे में अतिरिक्त जानकारी लिंक की गई 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"/>

इसके बाद, भुगतान ऐप को 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
    }
}

यदि HostApduService एक NFC लेनदेन को संभालना शुरू करता है और, परिणामस्वरूप, भुगतान की प्रगति और परिणाम प्रदर्शित करने के लिए एक गतिविधि शुरू करता है, तो उसे बाध्य QuickAccessWalletService का संदर्भ प्राप्त करने का प्रयास करना चाहिए और TYPE_NFC_PAYMENT_STARTED के एक प्रकार के साथ TYPE_NFC_PAYMENT_STARTED QuickAccessWalletService#sendEvent को कॉल करना चाहिए। . इससे क्विक एक्सेस वॉलेट यूआई को खारिज कर दिया जाता है, इस प्रकार उपयोगकर्ता को भुगतान गतिविधि के बारे में अबाधित दृश्य की अनुमति मिलती है।

QuickAccessWalletService को लागू करने पर अतिरिक्त दस्तावेज़ीकरण के लिए, QuickAccessWalletService और TestQuickAccessWalletService CTS परीक्षण देखें।

Android 11 में क्विक एक्सेस वॉलेट UI को सक्षम करना

एंड्रॉइड 11 में पावर मेनू से उपलब्ध होने के लिए क्विक एक्सेस वॉलेट को कॉन्फ़िगर करने के लिए, बिल्ड में QuickAccessWallet globalactions.wallet वॉलेट लक्ष्य शामिल करें और नीचे दिए गए कोड नमूने में overlay/frameworks/base/packages/SystemUI/res/values/config.xml फ़ाइल।

<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>

def_nfc_payment_component का उपयोग करके सेटिंग कॉन्फ़िगरेशन फ़ाइल में डिफ़ॉल्ट NFC भुगतान ऐप निर्दिष्ट करें।

डिफ़ॉल्ट एनएफसी भुगतान ऐप को क्विक एक्सेस वॉलेट को कार्ड प्रदान करने के लिए QuickAccessWalletService का खुलासा करना चाहिए। यदि डिफ़ॉल्ट NFC भुगतान ऐप इस सेवा को निर्यात नहीं करता है, तो वॉलेट UI छिपा हुआ है।

QuickAccessWalletसेवा कार्यान्वयन विवरण

QuickAccessWalletService में तीन सार विधियाँ हैं जिन्हें लागू किया जाना चाहिए: onWalletCardsRequested , onWalletCardSelected , और onWalletDismissed । नीचे दिया गया अनुक्रम आरेख एक कॉल अनुक्रम को दिखाता है जब त्वरित एक्सेस वॉलेट को किसी NFC भुगतान से ठीक पहले देखा जाता है।

त्वरित पहुँच वॉलेट अनुक्रम आरेख

उदाहरण कॉल अनुक्रम जब त्वरित पहुँच वॉलेट देखा जाता है
चित्रा 4. उदाहरण कॉल अनुक्रम जब त्वरित पहुँच वॉलेट देखा जाता है।

क्विक एक्सेस वॉलेट के सभी दृश्यों के बाद NFC भुगतान नहीं किया जाता है, लेकिन ऊपर चित्र 4 QuickAccessWalletService की सभी क्षमताओं को दिखाता है। इस उदाहरण में, क्विक एक्सेस वॉलेट कार्ड प्रदाता नीले रंग में उल्लिखित तत्वों को लागू करता है। यह माना जाता है कि भुगतान कार्ड डिवाइस पर डेटाबेस में संग्रहीत होते हैं और PaymentCardManager नामक इंटरफ़ेस के माध्यम से एक्सेस किए जाते हैं। आगे यह माना जाता है कि PaymentActivity नामक एक गतिविधि NFC भुगतान का परिणाम प्रदर्शित करती है। प्रवाह इस प्रकार आगे बढ़ता है:

  1. उपयोगकर्ता क्विक एक्सेस वॉलेट लाने के लिए एक इशारा करता है।
  2. क्विक एक्सेस वॉलेट यूआई (सिस्टम यूआई का हिस्सा) पैकेज मैनेजर को यह देखने के लिए जांचता है कि डिफ़ॉल्ट एनएफसी भुगतान ऐप QuickAccessWalletService निर्यात करता है या नहीं।

    • यदि सेवा निर्यात नहीं की जाती है, तो त्वरित पहुँच वॉलेट प्रदर्शित नहीं होता है।
  3. क्विक एक्सेस वॉलेट UI, QuickAccessWalletService से जुड़ता है और QuickAccessWalletService पर कॉल onWalletCardsRequested । यह विधि एक अनुरोध वस्तु लेती है जिसमें प्रदान किए जा सकने वाले कार्डों की संख्या और आकार और कॉलबैक के बारे में डेटा होता है। कॉलबैक को बैकग्राउंड थ्रेड से कॉल किया जा सकता है।

  4. QuickAccessWalletService उन कार्डों की गणना करता है जिन्हें वह दिखाना चाहता है, फिर दिए गए कॉलबैक पर onSuccess विधि को कॉल करता है। यह अनुशंसा की जाती है कि सेवा इन क्रियाओं को पृष्ठभूमि थ्रेड पर निष्पादित करे।

  5. जैसे ही कार्ड प्रदर्शित होते हैं, सिस्टम UI QuickAccessWalletService को सूचित करता है कि पहले कार्ड को onWalletCardSelected पर कॉल करके चुना गया है।

    • हर बार जब उपयोगकर्ता एक नया कार्ड चुनता है तो onWalletCardSelected को कॉल किया जाता है।
    • onWalletCardSelected को कॉल किया जा सकता है, भले ही वर्तमान में चयनित कार्ड न बदला हो।
  6. जब उपयोगकर्ता क्विक एक्सेस वॉलेट को खारिज कर देता है, तो सिस्टम UI, onWalletDismissed को QuickAccessWalletService पर कॉल करके सूचित करता है।

उपरोक्त उदाहरण में, जब वॉलेट प्रदर्शित किया जा रहा है, तब उपयोगकर्ता फोन को एनएफसी भुगतान टर्मिनल की सीमा में लाता है। NFC भुगतानों को संभालने का एक प्रमुख घटक HostApduService है, जिसे NFC रीडर द्वारा प्रदान किए गए APDU को संसाधित करने के लिए लागू किया जाना चाहिए (अधिक जानकारी के लिए, होस्ट-आधारित कार्ड इम्यूलेशन देखें)। यह माना जाता है कि भुगतान ऐप एनएफसी टर्मिनल के साथ बातचीत की प्रगति और परिणाम प्रदर्शित करने के लिए एक गतिविधि शुरू करता है। हालाँकि, क्विक एक्सेस वॉलेट UI ऐप विंडो के शीर्ष पर प्रदर्शित होता है, जिसका अर्थ है कि भुगतान गतिविधि क्विक एक्सेस वॉलेट UI द्वारा अस्पष्ट है। इसे सुधारने के लिए, ऐप को सिस्टम यूआई को सूचित करना चाहिए कि क्विक एक्सेस वॉलेट यूआई को खारिज कर दिया जाना चाहिए। यह बाध्य QuickAccessWalletService का संदर्भ प्राप्त करके और ईवेंट प्रकार TYPE_NFC_PAYMENT_STARTED के साथ sendWalletServiceEvent को कॉल करके ऐसा कर सकता है।

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();
    });
  }
}

QuickAccessWalletService के बारे में अधिक जानकारी के लिए, QuickAccessWalletService API संदर्भ देखें।

अनुमतियां

QuickAccessWalletService के लिए मेनिफेस्ट प्रविष्टि के लिए android.permission.BIND_QUICK_ACCESS_WALLET_SERVICE अनुमति की आवश्यकता Android 11 में होनी चाहिए। यह सिस्टम UI द्वारा आयोजित एक हस्ताक्षर-स्तरीय अनुमति है, जिसका अर्थ है कि केवल सिस्टम UI प्रक्रिया QuickAccessWalletService के कार्यान्वयन के लिए बाध्य हो सकती है। ध्यान रखें कि साइड-लोडेड ऐप्स इस अनुमति का दावा कर सकते हैं और Android 10 या इससे पहले के संस्करण चलाने वाले उपकरणों पर QuickAccessWalletService डेटा तक पूर्ण पहुंच प्राप्त कर सकते हैं। इसे रोकने के लिए, यह अनुशंसा की जाती है कि सेवा onCreate में बिल्ड संस्करण की जांच करे और सेवा को केवल Android 11 और उच्चतर चलाने वाले उपकरणों पर सक्षम करे। होस्ट कार्ड इम्यूलेशन भुगतान सेवाएं प्रदान करने के लिए आवश्यक से अधिक किसी अन्य ऐप अनुमतियों की आवश्यकता नहीं है।

यदि डिफ़ॉल्ट एनएफसी भुगतान ऐप QuickAccessWalletService को लागू या निर्यात नहीं करता है, तो त्वरित एक्सेस वॉलेट UI प्रदर्शित नहीं होता है।

Android 12 . में सेटिंग

लॉक स्क्रीन से क्विक एक्सेस वॉलेट को सक्षम या अक्षम करने के लिए, उपयोगकर्ता सेटिंग > डिस्प्ले > लॉक स्क्रीन में शो वॉलेट टॉगल का उपयोग कर सकते हैं। वॉलेट को छाया में अक्षम करने के लिए, उपयोगकर्ताओं को इसे त्वरित सेटिंग शेड में मैन्युअल रूप से संपादित करना होगा।

लॉक स्क्रीन से वॉलेट को सक्षम या अक्षम करने के लिए टॉगल करें

चित्रा 5. सेटिंग्स में लॉक स्क्रीन पेज में वॉलेट टॉगल दिखाएं।

Android 11 में सेटिंग्स

उपयोगकर्ता सेटिंग ऐप से क्विक एक्सेस वॉलेट सुविधा को बंद कर सकते हैं। सेटिंग पृष्ठ सेटिंग > सिस्टम > जेस्चर > कार्ड और पास में पाया जाता है।

त्वरित पहुँच वॉलेट सुविधा को सक्षम या अक्षम करने के लिए सेटिंग पृष्ठ
चित्र 6. क्विक एक्सेस वॉलेट सुविधा को सक्षम या अक्षम करने के लिए सेटिंग पृष्ठ।

अनुकूलन

सिस्टम UI में किसी अन्य स्थान पर त्वरित पहुँच वॉलेट दृश्य जोड़ना

क्विक एक्सेस वॉलेट UI को सिस्टम प्लगइन के रूप में बनाया गया है। हालांकि एओएसपी कार्यान्वयन GlobalActionsDialog (लंबे पावर प्रेस पर दिखाया गया) में इसका उपयोग करता है, जब तक आप प्लगइन इंटरफ़ेस द्वारा निर्दिष्ट अनुबंध को बनाए रखते हैं, तब तक आप सुविधा को एक अलग इशारा के पीछे ले जा सकते हैं।

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);
  }
}

क्विक एक्सेस वॉलेट UI GlobalActionsPanelPlugin और PanelViewController को लागू करता है। GlobalActionsDialog को com.android.systemui.Dependency .निर्भरता का उपयोग करके वॉलेट प्लगइन का एक उदाहरण मिलता है:

GlobalActionsPanelPlugin mPanelPlugin =
    Dependency.get(ExtensionController.class)
        .newExtension(GlobalActionsPanelPlugin.class)
        .withPlugin(GlobalActionsPanelPlugin.class)
        .build()
        .get();

यह जांचने के बाद कि प्लगइन गैर-शून्य है और PanelViewController onPanelShown लौटाया गया है, गैर-शून्य है, संवाद getPanelContent द्वारा प्रदान किए गए View को अपने स्वयं के View में संलग्न करता है और सिस्टम ईवेंट के लिए उपयुक्त कॉलबैक प्रदान करता है।

// 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();

पावर मेनू से क्विक एक्सेस वॉलेट को हटाने के लिए, सिस्टम बिल्ड से QuickAccessWallet लक्ष्य को छोड़ दें। पावर मेनू से क्विक एक्सेस वॉलेट को हटाने के लिए लेकिन इसे एक अलग सिस्टम UI प्रदान किए गए दृश्य में जोड़ें, बिल्ड लक्ष्य शामिल करें और GlobalActionsPanelPlugin के संदर्भों को GlobalActionsPanelPlugin से GlobalActionsImpl दें।

डिफ़ॉल्ट कॉन्फ़िगरेशन सेट करना

एंड्रॉइड 12

Android 12 या उच्चतर में, त्वरित एक्सेस वॉलेट हमेशा त्वरित सेटिंग शेड में दिखाई देता है। लॉक स्क्रीन में क्विक एक्सेस वॉलेट की दृश्यता निम्नलिखित सुरक्षित सेटिंग द्वारा निर्धारित की जाती है: LOCKSCREEN_SHOW_WALLET । यह सेटिंग नियंत्रित करती है कि लॉक स्क्रीन के नीचे दाईं ओर क्विक एक्सेस वॉलेट आइकन दिखाया गया है या नहीं। यह सेटिंग डिफ़ॉल्ट रूप से true पर सेट होती है, लेकिन उपयोगकर्ता द्वारा सेटिंग > डिस्प्ले > लॉक स्क्रीन > वॉलेट दिखाएं में इसे बंद किया जा सकता है।

एंड्रॉइड 11

Android 11 में, त्वरित एक्सेस वॉलेट दृश्यता दो सुरक्षित सेटिंग्स द्वारा निर्धारित की जाती है: GLOBAL_ACTIONS_PANEL_ENABLED और GLOBAL_ACTIONS_PANEL_AVAILABLEAVAILABLE सेटिंग यह नियंत्रित करती है कि सेटिंग में सुविधा को चालू और बंद किया जा सकता है या नहीं। यह सेटिंग WalletPluginService द्वारा true पर सेट की गई है। यदि QuickAccessWallet बिल्ड में शामिल नहीं है, तो सेटिंग false रहती है। ENABLED सेटिंग उसी स्थान पर डिफ़ॉल्ट रूप से true पर सेट होती है, लेकिन उपयोगकर्ता द्वारा सेटिंग में इसे बंद किया जा सकता है। डिफ़ॉल्ट व्यवहार बदलने के लिए, WalletPluginService#enableFeatureInSettings संशोधित करें।

मान्यकरण

क्विक एक्सेस वॉलेट के अपने कार्यान्वयन को सत्यापित करने के लिए, सीटीएस और मैन्युअल परीक्षण चलाएं। प्लगइन में परिवर्तन शामिल रोबोइलेक्ट्रिक परीक्षणों का भी प्रयोग करना चाहिए।

सीटीएस परीक्षण

cts/tests/quickaccesswallet पर स्थित CTS परीक्षण चलाएँ।

Android 12 . के लिए मैन्युअल परीक्षण

क्विक एक्सेस वॉलेट की मुख्य विशेषताओं का परीक्षण करने के लिए एक एनएफसी भुगतान टर्मिनल (असली या नकली) और एक एनएफसी भुगतान ऐप की आवश्यकता होती है जो QuickAccessWalletService (वॉलेट ऐप) को लागू करता है। जिन मुख्य विशेषताओं का परीक्षण किया जाना चाहिए उनमें शामिल हैं: उपलब्धता, शून्य स्थिति, कार्ड चयन और लॉक स्क्रीन व्यवहार।

उपलब्धता

  • यदि डिफ़ॉल्ट एनएफसी भुगतान ऐप सुविधा का समर्थन नहीं करता है, तो त्वरित एक्सेस वॉलेट न तो त्वरित सेटिंग्स और न ही लॉक स्क्रीन में पहुंच योग्य है।
  • यदि डिफ़ॉल्ट एनएफसी भुगतान ऐप इस सुविधा का समर्थन करता है, तो क्विक एक्सेस वॉलेट को क्विक सेटिंग्स शेड में एक्सेस किया जा सकता है।
  • यदि डिफ़ॉल्ट एनएफसी भुगतान ऐप सुविधा का समर्थन करता है और यदि LOCKSCREEN_SHOW_WALLET सेटिंग true , तो त्वरित एक्सेस वॉलेट लॉक स्क्रीन पर पहुंच योग्य है।
  • यदि डिफ़ॉल्ट एनएफसी भुगतान ऐप सुविधा का समर्थन करता है और यदि LOCKSCREEN_SHOW_WALLET सेटिंग false है, तो त्वरित एक्सेस वॉलेट लॉक स्क्रीन पर पहुंच योग्य नहीं है।

शून्य अवस्था

  • यदि QuickAccessWalletService सक्षम और निर्यात किया जाता है लेकिन कोई कार्ड प्रदान नहीं करता है, तो शेड में टाइल चित्र 7 में उदाहरण के रूप में दिखाई देती है। टाइल पर क्लिक करने से डिफ़ॉल्ट NFC भुगतान ऐप खुल जाता है।

    डिफ़ॉल्ट एनएफसी भुगतान ऐप दिखाने वाली छाया में उदाहरण टाइल

    चित्र 7. डिफ़ॉल्ट एनएफसी भुगतान ऐप दिखाने वाली छाया में उदाहरण टाइल।

  • जैसा कि चित्र 8 में दिखाया गया है, खाली स्थिति दृश्य पर क्लिक करने से डिफ़ॉल्ट एनएफसी भुगतान ऐप खुल जाता है। यह खाली स्थिति दृश्य केवल तभी प्रदर्शित होता है जब उपयोगकर्ता के पास बटुए में एक कार्ड बचा हो, कार्ड विवरण पृष्ठ से कार्ड को हटा देता है, और फिर वॉलेट दृश्य में वापस चला जाता है।

  • लॉक स्क्रीन वॉलेट आइकन दिखाती है।

क्विक एक्सेस वॉलेट में खाली स्टेट व्यू

चित्र 8. त्वरित पहुँच वॉलेट UI में खाली स्थिति दृश्य।

गैर-शून्य राज्य

  • यदि वॉलेट ऐप एक या अधिक कार्ड प्रदान करता है, तो छाया में टाइल चित्र 9 में दिखाए गए अनुसार दिखाई देती है।

    उदाहरण टाइल छाया में जब वॉलेट ऐप में एक या अधिक कार्ड हों

    चित्र 9. छाया में उदाहरण टाइल जब वॉलेट ऐप में एक या अधिक कार्ड हों।

  • टाइल पर क्लिक करने से एक कार्ड हिंडोला दिखाई देता है।

  • लॉक स्क्रीन एक बटन दिखाती है जो क्विक एक्सेस वॉलेट को खोलता है।

    प्रदर्शित कार्ड के साथ त्वरित एक्सेस वॉलेट UI

    चित्र 10. प्रदर्शित कार्ड के साथ त्वरित एक्सेस वॉलेट UI।

  • यदि प्रदर्शित कार्ड एक एनएफसी भुगतान विधि का प्रतिनिधित्व करता है, तो फोन को एनएफसी भुगतान टर्मिनल पर रखने से उस भुगतान विधि का उपयोग किया जा रहा है और वॉलेट दृश्य खारिज कर दिया गया है।

  • प्रदर्शित कार्ड पर क्लिक करने से उस कार्ड की विस्तृत गतिविधि खुल जाती है।

  • यदि QuickAccessWalletService द्वारा कई कार्ड प्रदान किए जाते हैं, तो उपयोगकर्ता कार्ड के बीच स्वाइप करने में सक्षम होता है।

  • अतिप्रवाह मेनू में एक प्रविष्टि होती है: लॉक स्क्रीन सेटिंग खोलें ताकि उपयोगकर्ता वॉलेट दिखाएँ विकल्प को बदल सके।

लॉक स्टेट टेस्ट

  • यदि फ़ोन लॉक है, तो वॉलेट त्वरित सेटिंग शेड पर दिखाई देता है, जिसमें डिफ़ॉल्ट भुगतान ऐप में कोई कार्ड मौजूद नहीं होने पर कार्ड जोड़ें या डिफ़ॉल्ट भुगतान ऐप में कार्ड मौजूद होने पर उपयोग करने के लिए अनलॉक करें
  • यदि फ़ोन लॉक है, तो लॉक स्क्रीन पर वॉलेट दृश्यता को Secure.LOCKSCREEN_SHOW_WALLET सेटिंग द्वारा नियंत्रित किया जाता है, जिसे सेटिंग में नियंत्रित किया जाता है।
  • यदि फ़ोन लॉक है, LOCKSCREEN_SHOW_WALLET false है, और डिफ़ॉल्ट NFC भुगतान ऐप में कोई कार्ड मौजूद नहीं है, तो लॉक स्क्रीन पर वॉलेट प्रदर्शित नहीं होता है।
  • यदि फ़ोन लॉक है, LOCKSCREEN_SHOW_WALLET true , और डिफ़ॉल्ट NFC भुगतान ऐप में कोई कार्ड मौजूद नहीं है, तो लॉक स्क्रीन पर वॉलेट प्रदर्शित नहीं होता है।
  • यदि फ़ोन लॉक है, LOCKSCREEN_SHOW_WALLET true , और कार्ड डिफ़ॉल्ट NFC भुगतान ऐप में मौजूद हैं, वॉलेट लॉक स्क्रीन पर प्रदर्शित होता है।
  • लॉक स्क्रीन पर वॉलेट प्रदर्शित होने के दौरान फोन को अनलॉक करने के परिणामस्वरूप कार्ड की आवश्यकता होती है, जिसके परिणामस्वरूप विभिन्न कार्ड सामग्री हो सकती है।

अभिगम्यता परीक्षण

  • टॉकबैक उपयोगकर्ता बाएँ और दाएँ स्वाइप करके और कार्ड के सामग्री विवरण को सुनकर वॉलेट दृश्य को नेविगेट कर सकते हैं।
  • टॉकबैक सक्षम के साथ बाएं और दाएं स्वाइप करने से बारी-बारी से प्रत्येक कार्ड का चयन होता है। टॉकबैक उपयोगकर्ता एनएफसी भुगतान टर्मिनल पर एनएफसी भुगतान विधि का चयन और उपयोग कर सकते हैं।

Android 11 के लिए मैन्युअल परीक्षण

क्विक एक्सेस वॉलेट की मुख्य विशेषताओं का परीक्षण करने के लिए एक एनएफसी भुगतान टर्मिनल (असली या नकली) और एक एनएफसी भुगतान ऐप की आवश्यकता होती है जो QuickAccessWalletService (वॉलेट ऐप) को लागू करता है। जिन मुख्य विशेषताओं का परीक्षण किया जाना चाहिए उनमें उपलब्धता, शून्य स्थिति, कार्ड चयन और लॉक स्क्रीन व्यवहार शामिल हैं।

उपलब्धता

  • यदि GLOBAL_ACTIONS_PANEL_ENABLED सेटिंग true और डिफ़ॉल्ट NFC भुगतान ऐप सुविधा का समर्थन करता है, तो त्वरित एक्सेस वॉलेट पहुंच योग्य है।
  • यदि GLOBAL_ACTIONS_PANEL_ENABLED सेटिंग false है और डिफ़ॉल्ट NFC भुगतान ऐप सुविधा का समर्थन करता है, तो त्वरित एक्सेस वॉलेट पहुंच योग्य नहीं है।
  • यदि GLOBAL_ACTIONS_PANEL_ENABLED सेटिंग true और डिफ़ॉल्ट NFC भुगतान ऐप सुविधा का समर्थन नहीं करता है, तो त्वरित एक्सेस वॉलेट पहुंच योग्य नहीं है।
  • यदि GLOBAL_ACTIONS_PANEL_ENABLED सेटिंग false है और डिफ़ॉल्ट NFC भुगतान ऐप सुविधा का समर्थन नहीं करता है, तो त्वरित एक्सेस वॉलेट पहुंच योग्य नहीं है।

शून्य अवस्था

  • यदि QuickAccessWalletService सक्षम और निर्यात किया गया है, लेकिन कोई कार्ड प्रदान नहीं करता है, तो त्वरित एक्सेस वॉलेट UI खाली स्थिति दृश्य प्रदर्शित करता है।
  • खाली स्टेट व्यू पर क्लिक करने से वॉलेट ऐप खुल जाता है।

    त्वरित पहुँच वॉलेट UI में खाली स्थिति दृश्य
    चित्र 11. त्वरित पहुँच वॉलेट UI में खाली स्थिति दृश्य।

गैर-शून्य राज्य

  • यदि वॉलेट ऐप एक या अधिक कार्ड प्रदान करता है, तो कार्ड क्विक एक्सेस वॉलेट UI में प्रदर्शित होते हैं।

    प्रदर्शित कार्ड के साथ त्वरित एक्सेस वॉलेट UI
    चित्र 12. प्रदर्शित कार्ड के साथ त्वरित एक्सेस वॉलेट UI।
  • यदि प्रदर्शित कार्ड एक एनएफसी भुगतान विधि का प्रतिनिधित्व करता है, तो फोन को एनएफसी भुगतान टर्मिनल पर रखने से उस भुगतान विधि का उपयोग किया जा रहा है और वॉलेट दृश्य खारिज कर दिया गया है।

  • प्रदर्शित कार्ड पर क्लिक करने से वॉलेट दृश्य ख़ारिज हो जाता है और उस कार्ड की विस्तृत गतिविधि खुल जाती है।

  • यदि QuickAccessWalletService द्वारा कई कार्ड प्रदान किए जाते हैं, तो उपयोगकर्ता कार्ड के बीच स्वाइप करने में सक्षम होता है।

  • अतिप्रवाह मेनू में दो प्रविष्टियां होती हैं: एक जो वॉलेट ऐप को खोलता है और एक जो सेटिंग में शो कार्ड और पास स्क्रीन खोलता है।

लॉक स्टेट टेस्ट

  • यदि फ़ोन लॉक है, तो वॉलेट की दृश्यता को Settings.Secure.POWER_MENU_LOCK_SHOW_CONTENT सेटिंग द्वारा नियंत्रित किया जाता है, जिसे सेटिंग में नियंत्रित किया जा सकता है।
  • यदि फ़ोन लॉक है और POWER_MENU_LOCK_SHOW_CONTENT false है, तो वॉलेट प्रदर्शित नहीं होता है।
  • यदि फ़ोन लॉक है और POWER_MENU_LOCK_SHOW_CONTENT true , तो वॉलेट प्रदर्शित होता है।
  • लॉक स्क्रीन पर वॉलेट प्रदर्शित होने के दौरान फोन को अनलॉक करने से कार्ड की फिर से पूछताछ की जाती है, जिसके परिणामस्वरूप कार्ड की सामग्री अलग हो सकती है।

अभिगम्यता परीक्षण

  • टॉकबैक उपयोगकर्ता बाएं और दाएं स्वाइप करके और कार्ड के सामग्री विवरण को सुनकर वॉलेट दृश्य को नेविगेट कर सकते हैं।
  • TalkBack सक्षम के साथ बाएं और दाएं स्वाइप करने से बारी-बारी से प्रत्येक कार्ड का चयन होता है। टॉकबैक उपयोगकर्ता एनएफसी भुगतान टर्मिनल पर एनएफसी भुगतान विधि का चयन और उपयोग कर सकते हैं।