创建记事应用

नोट लेना, Android की एक मुख्य सुविधा है. इससे उपयोगकर्ताओं की उत्पादकता बढ़ती है बड़ी स्क्रीन वाले डिवाइस. नोट लेने वाले ऐप्लिकेशन की मदद से उपयोगकर्ता, नोट लिख सकते हैं और स्केच बना सकते हैं फ़्लोटिंग विंडो या फ़ुल स्क्रीन पर, स्क्रीन के कॉन्टेंट को कैप्चर और एनोटेट करें, और बाद में समीक्षा और संशोधन के लिए नोट सेव कर लें.

उपयोगकर्ता, नोट लेने वाले ऐप्लिकेशन को लॉक स्क्रीन से ऐक्सेस कर सकते हैं. इसके अलावा, वे कोई दूसरा ऐप्लिकेशन इस्तेमाल करते समय भी इनका इस्तेमाल कर सकते हैं दिखाई देता है.

नोट लेने से जुड़े स्टाइलस की मदद से, उपयोगकर्ताओं को बेहतरीन अनुभव मिलता है.

नोट की भूमिका

कॉन्टेंट बनाने RoleManager.ROLE_NOTES भूमिका, नोट लेने वाले ऐप्लिकेशन की पहचान करती है और उन्हें LAUNCH_CAPTURE_CONTENT_ACTIVITY_FOR_NOTE अनुमति.

अपने ऐप्लिकेशन के लिए नोट की भूमिका पाने के लिए, यह तरीका अपनाएं:

  1. isRoleAvailable() पर कॉल करें भूमिका की स्थिति जांचने के लिए.
  2. अगर नोट भूमिका उपलब्ध है, तो createRequestRoleIntent() पर कॉल करें नोट करने के खास इंटेंट के बारे में ज़्यादा जानने के लिए.
  3. startActivityForResult() पर कॉल करें नोट के इंटेंट से, जिसका मकसद उपयोगकर्ता को आपकी है.

नोट की भूमिका सिर्फ़ एक ऐप्लिकेशन के पास हो सकती है.

ऐप्लिकेशन, एक इंप्लिसिट मैसेज के जवाब में खुलता है ACTION_CREATE_NOTE इंटेंट कार्रवाई. अगर डिवाइस की लॉक स्क्रीन से शुरू किया जाता है, तो ऐप्लिकेशन फ़ुल स्क्रीन में खुल जाता है स्क्रीन; अगर यह नीति फ़्लोटिंग विंडो में, स्क्रीन अनलॉक होने पर शुरू की जाती है.

ऐप्लिकेशन मेनिफ़ेस्ट

नोट की भूमिका पाने के लिए, आपके ऐप्लिकेशन में यह एलान शामिल होना चाहिए के लिए:

<activity
    android:name="YourActivityName"
    android:exported="true"
    android:showWhenLocked="true"
    android:turnScreenOn="true">
    <intent-filter>
        <action android:name="android.intent.action.CREATE_NOTE" />
        <category android:name="android.intent.category.DEFAULT" />
    </intent-filter>
</activity>

एलान से, लोगों को आपके ऐप्लिकेशन के लिए नोट की भूमिका असाइन करने की सुविधा मिलती है. इससे यह नोट लेने की सुविधा वाला डिफ़ॉल्ट ऐप्लिकेशन:

  • ACTION_CREATE_NOTE इंटेंट कार्रवाई सेट करता है, जिसके लिए आपका ऐप्लिकेशन जवाब देता है

  • showWhenLocked आपके ऐप्लिकेशन को डिवाइस की लॉक स्क्रीन से ऐक्सेस किया जा सकता है

  • turnScreenOn चालू करता है आपका ऐप्लिकेशन, ऐप्लिकेशन के चलने पर डिवाइस की स्क्रीन चालू कर देगा

ऐप्लिकेशन की सुविधाएं

नोट लिखने की सुविधा देने वाला, बड़ी स्क्रीन वाला ऐसा ऐप्लिकेशन जो आपको बेहतरीन अनुभव देता है नोट लेने की क्षमता.

स्टाइलस इस्तेमाल किया जा सकता है

जब आपका ऐप्लिकेशन EXTRA_USE_STYLUS_MODE इंटेंट को true पर अतिरिक्त सेट किया गया है, तो ऐप को एक ऐसा नोट खोलना चाहिए जो स्टाइलस स्वीकार करता हो (या फ़िंगर-टच इनपुट शामिल है.

अगर इंटेंट एक्स्ट्रा को false पर सेट किया गया है, तो आपके ऐप्लिकेशन को एक ऐसा नोट खोलना चाहिए जो स्वीकार करता हो कीबोर्ड इनपुट.

लॉकस्क्रीन का ऐक्सेस

आपके ऐप्लिकेशन में फ़ुल-स्क्रीन पर होने वाली ऐसी गतिविधि शामिल होनी चाहिए जो ऐप्लिकेशन के: डिवाइस की लॉक स्क्रीन से खोला गया हो.

आपके ऐप्लिकेशन को पुराने नोट सिर्फ़ तब दिखाने चाहिए, जब उपयोगकर्ता ने सहमति दी हो (इसमें डिवाइस की स्थिति को अनलॉक किया है). अन्यथा, लॉक स्क्रीन, आपके ऐप्लिकेशन को हमेशा नया नोट बनाना चाहिए.

आपके पास यह देखने का विकल्प होता है कि क्या आपका ऐप्लिकेशन, KeyguardManager#isKeyguardLocked(). उपयोगकर्ता से डिवाइस की पुष्टि करने और उसे अनलॉक करने के लिए, कॉल करें KeyguardManager#requestDismissKeyguard():

val keyguardManager =
getSystemService(KEYGUARD_SERVICE) as KeyguardManager
keyguardManager.requestDismissKeyguard(  this, object :
KeyguardDismissCallback() {  override fun onDismissError() {  // Unlock failed.
Dismissing keyguard is not feasible.  }  override fun onDismissSucceeded() {  //
Unlock succeeded. Device is now unlocked.  }  override fun onDismissCancelled()
{  // Unlock failed. User cancelled operation or request otherwise cancelled.  }
 } )

फ़्लोटिंग विंडो

संदर्भ के हिसाब से नोट लेने के लिए, आपके ऐप्लिकेशन में ऐसी गतिविधि दी जानी चाहिए जो फ़्लोटिंग विंडो का इस्तेमाल करें.

आपके ऐप्लिकेशन को multi-instance मोड चालू कर सकते हैं, ताकि उपयोगकर्ता कई फ़्लोटिंग विंडो में एक से ज़्यादा नोट बना सकें जब नोट लेने की सुविधा वाला ऐप्लिकेशन फ़ुल स्क्रीन या स्प्लिट स्क्रीन में लॉन्च होता है मोड.

कॉन्टेंट कैप्चर करने की सुविधा

नोट लेने की सुविधा देने वाले ऐप्लिकेशन, कॉन्टेंट कैप्चर करने की एक मुख्य सुविधा है. कॉन्टेंट के साथ इससे उपयोगकर्ता नोट लेने के पीछे के डिसप्ले का स्क्रीनशॉट ले सकते हैं फ़्लोटिंग विंडो में खोलें. उपयोगकर्ता डिसप्ले का पूरा या कोई हिस्सा कैप्चर कर सकते हैं. इसके लिए, कॉन्टेंट को नोट में जोड़ा जा सकता है. साथ ही, कैप्चर किए गए कॉन्टेंट की व्याख्या या हाइलाइट की जा सकती है.

नोट लेने की सुविधा वाले आपके ऐप्लिकेशन में यूज़र इंटरफ़ेस (यूआई) की सुविधा होनी चाहिए, ताकि ActivityResultLauncher ने बनाया registerForActivityResult(). कॉन्टेंट बनाने ACTION_LAUNCH_CAPTURE_CONTENT_ACTIVITY_FOR_NOTE इंटेंट कार्रवाई, लॉन्चर को सीधे तौर पर या ActivityResultContract.

सिस्टम गतिविधि, कॉन्टेंट को कैप्चर करती है, उसे डिवाइस पर सेव करती है, और के कॉलबैक आर्ग्युमेंट में आपके ऐप्लिकेशन का कॉन्टेंट यूआरआई registerForActivityResult().

नीचे दिए गए उदाहरण में StartActivityForResult अनुबंध:

private val startForResult =
registerForActivityResult(  ActivityResultContracts.StartActivityForResult()) {
 result: ActivityResult ->  if (result.resultCode ==
Intent.CAPTURE_CONTENT_FOR_NOTE_SUCCESS) {  val uri = result.data?.data  // Use
the URI to paste the captured content into the note.  }  } override fun
onCreate(savedInstanceState: Bundle?) {  super.onCreate(savedInstanceState)
setContent {  NotesTheme {  Surface(color =
MaterialTheme.colorScheme.background) {  CaptureButton(  onClick = {
Log.i("ContentCapture", "Launching intent...")
startForResult.launch(Intent(ACTION_LAUNCH_CAPTURE_CONTENT_ACTIVITY_FOR_NOTE))
})  }  }  } } @Composable fun CaptureButton(onClick: () -> Unit) {
Button(onClick = onClick)
 {Text("Capture Content")} }

आपके ऐप्लिकेशन को नतीजों के सभी कोड मैनेज करने चाहिए:

कॉन्टेंट कैप्चर हो जाने पर, कैप्चर की गई इमेज को नोट में चिपकाएं. उदाहरण:

registerForActivityResult(ActivityResultContracts.StartActivityForResult()) {
 result: ActivityResult ->  if (result.resultCode ==
Intent.CAPTURE_CONTENT_FOR_NOTE_SUCCESS) {  val uri = result.data?data  // Use
the URI to paste the captured content into the note.  } }

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

यह पता लगाने के लिए कि आपका ऐप्लिकेशन किसी फ़्लोटिंग विंडो (या बबल) में है या नहीं, नीचे दिए गए तरीके अपनाएं:

  • isLaunchedFromBubble() यह जांच करने के लिए कि नोट लेने की सुविधा देने वाला ऐप्लिकेशन फ़ुल स्क्रीन मोड में लॉन्च तो नहीं हुआ डिवाइस की लॉक स्क्रीन
  • isRoleHeld(RoleManager.ROLE_NOTES) आपका ऐप्लिकेशन, नोट लेने का डिफ़ॉल्ट ऐप्लिकेशन है (आपका ऐप्लिकेशन किसी बातचीत या अन्य प्रकार के बबल में चलाया जा सकता है. नोट की भूमिका)

अन्य संसाधन