नोट लेना, Android की एक मुख्य सुविधा है. इससे उपयोगकर्ताओं की उत्पादकता बढ़ती है बड़ी स्क्रीन वाले डिवाइस. नोट लेने वाले ऐप्लिकेशन की मदद से उपयोगकर्ता, नोट लिख सकते हैं और स्केच बना सकते हैं फ़्लोटिंग विंडो या फ़ुल स्क्रीन पर, स्क्रीन के कॉन्टेंट को कैप्चर और एनोटेट करें, और बाद में समीक्षा और संशोधन के लिए नोट सेव कर लें.
उपयोगकर्ता, नोट लेने वाले ऐप्लिकेशन को लॉक स्क्रीन से ऐक्सेस कर सकते हैं. इसके अलावा, वे कोई दूसरा ऐप्लिकेशन इस्तेमाल करते समय भी इनका इस्तेमाल कर सकते हैं दिखाई देता है.
नोट लेने से जुड़े स्टाइलस की मदद से, उपयोगकर्ताओं को बेहतरीन अनुभव मिलता है.
नोट की भूमिका
कॉन्टेंट बनाने
RoleManager.ROLE_NOTES
भूमिका, नोट लेने वाले ऐप्लिकेशन की पहचान करती है और उन्हें
LAUNCH_CAPTURE_CONTENT_ACTIVITY_FOR_NOTE
अनुमति.
अपने ऐप्लिकेशन के लिए नोट की भूमिका पाने के लिए, यह तरीका अपनाएं:
isRoleAvailable()
पर कॉल करें भूमिका की स्थिति जांचने के लिए.- अगर नोट भूमिका उपलब्ध है, तो
createRequestRoleIntent()
पर कॉल करें नोट करने के खास इंटेंट के बारे में ज़्यादा जानने के लिए. 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()
:
Kotlin
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. } } )
Java
KeyguardManager keyguardManager = (KeyguardManager) getSystemService(KEYGUARD_SERVICE); boolean isLocked = keyguardManager.isKeyguardLocked(); keyguardManager.requestDismissKeyguard( this, new KeyguardManager.KeyguardDismissCallback() { @Override public void onDismissError() { // Unlock failed. Dismissing keyguard is not feasible. } @Override public void onDismissSucceeded() { // Unlock succeeded. Device is now unlocked. } @Override public void onDismissCancelled() { // Unlock failed. User cancelled operation or request otherwise cancelled. } });
फ़्लोटिंग विंडो
संदर्भ के हिसाब से नोट लेने के लिए, आपके ऐप्लिकेशन में ऐसी गतिविधि दी जानी चाहिए जो फ़्लोटिंग विंडो का इस्तेमाल करें.
आपके ऐप्लिकेशन को
multi-instance
मोड चालू कर सकते हैं, ताकि उपयोगकर्ता कई फ़्लोटिंग विंडो में एक से ज़्यादा नोट बना सकें
जब नोट लेने की सुविधा वाला ऐप्लिकेशन फ़ुल स्क्रीन या स्प्लिट स्क्रीन में लॉन्च होता है
मोड.
कॉन्टेंट कैप्चर करने की सुविधा
नोट लेने की सुविधा देने वाले ऐप्लिकेशन, कॉन्टेंट कैप्चर करने की एक मुख्य सुविधा है. कॉन्टेंट के साथ इससे उपयोगकर्ता नोट लेने के पीछे के डिसप्ले का स्क्रीनशॉट ले सकते हैं फ़्लोटिंग विंडो में खोलें. उपयोगकर्ता डिसप्ले का पूरा या कोई हिस्सा कैप्चर कर सकते हैं. इसके लिए, कॉन्टेंट को नोट में जोड़ा जा सकता है. साथ ही, कैप्चर किए गए कॉन्टेंट की व्याख्या या हाइलाइट की जा सकती है.
नोट लेने की सुविधा वाले आपके ऐप्लिकेशन में यूज़र इंटरफ़ेस (यूआई) की सुविधा होनी चाहिए, ताकि
ActivityResultLauncher
ने बनाया
registerForActivityResult()
.
कॉन्टेंट बनाने
ACTION_LAUNCH_CAPTURE_CONTENT_ACTIVITY_FOR_NOTE
इंटेंट कार्रवाई, लॉन्चर को सीधे तौर पर या
ActivityResultContract
.
सिस्टम गतिविधि, कॉन्टेंट को कैप्चर करती है, उसे डिवाइस पर सेव करती है, और
के कॉलबैक आर्ग्युमेंट में आपके ऐप्लिकेशन का कॉन्टेंट यूआरआई
registerForActivityResult()
.
नीचे दिए गए उदाहरण में
StartActivityForResult
अनुबंध:
Kotlin
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")} }
Java
private final ActivityResultLauncher<Intent> startForResult = registerForActivityResult( new ActivityResultContracts.StartActivityForResult(), result -> { if (result.getResultCode() == Intent.CAPTURE_CONTENT_FOR_NOTE_SUCCESS) { Uri uri = result.getData() != null ? result.getData().getData() : null; // Use the URI to paste the captured content into the note. } }); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button captureButton = findViewById(R.id.capture_button); captureButton.setOnClickListener( view -> { Log.i("ContentCapture", "Launching intent..."); startForResult.launch(new Intent(ACTION_LAUNCH_CAPTURE_CONTENT_ACTIVITY_FOR_NOTE)); }); }
आपके ऐप्लिकेशन को नतीजों के सभी कोड मैनेज करने चाहिए:
CAPTURE_CONTENT_FOR_NOTE_SUCCESS
CAPTURE_CONTENT_FOR_NOTE_FAILED
CAPTURE_CONTENT_FOR_NOTE_USER_CANCELED
CAPTURE_CONTENT_FOR_NOTE_WINDOW_MODE_UNSUPPORTED
CAPTURE_CONTENT_FOR_NOTE_BLOCKED_BY_ADMIN
कॉन्टेंट कैप्चर हो जाने पर, कैप्चर की गई इमेज को नोट में चिपकाएं. उदाहरण:
Kotlin
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. } }
Java
registerForActivityResult(new ActivityResultContracts.StartActivityForResult(), result -> { if (result.getResultCode() == Intent.CAPTURE_CONTENT_FOR_NOTE_SUCCESS) { Uri uri = result.getData() != null ? result.getData().getData() : null; // Use the URI to paste the captured content into the note. } });
कॉन्टेंट कैप्चर करने की सुविधा को यूज़र इंटरफ़ेस (यूआई) की सेटिंग के ज़रिए दिखाना चाहिए. ऐसा सिर्फ़ तब करना चाहिए, जब नोट लेने वाला आपका ऐप्लिकेशन फ़्लोटिंग विंडो में चल रहा हो फ़ुल स्क्रीन मोड चालू करके, डिवाइस की लॉक स्क्रीन से लॉन्च किया गया हो. (उपयोगकर्ता नोट लेने वाले ऐप्लिकेशन के स्क्रीनशॉट और डिवाइस का स्क्रीनशॉट सुविधाएं.)
यह पता लगाने के लिए कि आपका ऐप्लिकेशन किसी फ़्लोटिंग विंडो (या बबल) में है या नहीं, नीचे दिए गए तरीके अपनाएं:
isLaunchedFromBubble()
यह जांच करने के लिए कि नोट लेने की सुविधा देने वाला ऐप्लिकेशन फ़ुल स्क्रीन मोड में लॉन्च तो नहीं हुआ डिवाइस की लॉक स्क्रीनisRoleHeld(RoleManager.ROLE_NOTES)
आपका ऐप्लिकेशन, नोट लेने का डिफ़ॉल्ट ऐप्लिकेशन है (आपका ऐप्लिकेशन किसी बातचीत या अन्य प्रकार के बबल में चलाया जा सकता है. नोट की भूमिका)