स्टाइलस की बेहतर सुविधाएं

Android और ChromeOS कई तरह के एपीआई उपलब्ध कराते हैं. इनकी मदद से, ऐसे ऐप्लिकेशन बनाए जा सकते हैं जो स्टाइलस का इस्तेमाल शानदार तरीके से करते हैं. कॉन्टेंट बनाने MotionEvent क्लास एक्सपोज़र स्क्रीन के साथ स्टाइलस के इंटरैक्शन के बारे में जानकारी, जिसमें स्टाइलस के दबाव, स्क्रीन की दिशा, झुकाना, माउस घुमाना, और पाम डिटेक्शन. लो-लेटेंसी ग्राफ़िक और मोशन पूर्वानुमान लाइब्रेरी, स्टाइलस की ऑन-स्क्रीन रेंडरिंग को बेहतर बनाती हैं, ताकि और काग़ज़ भी जैसा अनुभव देते हैं.

MotionEvent

MotionEvent क्लास, उपयोगकर्ता के इनपुट इंटरैक्शन की जानकारी देती है, जैसे कि पोज़िशन और स्क्रीन पर टच पॉइंटर की हलचल. स्टाइलस इनपुट के लिए, MotionEvent डेटा पर दबाव, स्क्रीन की दिशा, झुकाव, और कर्सर घुमाने से जुड़ी जानकारी भी दिखती है.

इवेंट डेटा

To access MotionEvent data, add a pointerInput modifier to components:

@Composable
fun Greeting() {
    Text(
        text = "Hello, Android!", textAlign = TextAlign.Center, style = TextStyle(fontSize = 5.em),
        modifier = Modifier
            .pointerInput(Unit) {
                awaitEachGesture {
                    while (true) {
                        val event = awaitPointerEvent()
                        event.changes.forEach { println(it) }
                    }
                }
            },
    )
}

MotionEvent ऑब्जेक्ट, यूज़र इंटरफ़ेस (यूआई) के इन पहलुओं से जुड़ा डेटा देता है इवेंट:

  • कार्रवाइयां: डिवाइस के साथ शारीरिक इंटरैक्शन—स्क्रीन छूना, पॉइंटर को स्क्रीन की सतह पर घुमाते हुए, स्क्रीन पर कर्सर घुमाते हुए प्लैटफ़ॉर्म
  • पॉइंटर: स्क्रीन पर मौजूद ऑब्जेक्ट के आइडेंटिफ़ायर, जैसे कि उंगली, स्टाइलस, माउस
  • ऐक्सिस: डेटा का टाइप—x और y कोऑर्डिनेट, प्रेशर, टिल्ट, ओरिएंटेशन, और होवर (दूरी)

कार्रवाइयां

स्टाइलस इस्तेमाल करने की सुविधा लागू करने के लिए, आपको यह समझना होगा कि उपयोगकर्ता क्या कार्रवाई कर रहा है परफ़ॉर्म कर रहा है.

MotionEvent में कई तरह के ACTION कॉन्सटेंट मिलते हैं, जो गति को परिभाषित करते हैं इवेंट. स्टाइलस के लिए सबसे ज़रूरी कार्रवाइयां ये हैं:

कार्रवाई ब्यौरा
ACTION_DOWN
ACTION_POINTER_DOWN
पॉइंटर ने स्क्रीन के साथ संपर्क बनाया है.
ACTION_मूव पॉइंटर स्क्रीन पर ले जाया जा रहा है.
ACTION_UP
ACTION_POINTER_UP
पॉइंटर अब स्क्रीन के संपर्क में नहीं है
ACTION_CANCEL पिछला या मौजूदा मोशन सेट रद्द किए जाने पर.

ACTION_DOWN होने पर आपका ऐप्लिकेशन, नए स्ट्रोक शुरू करने जैसे काम कर सकता है ऐसा होता है, जब स्ट्रोक ACTION_MOVE, से बनाया जाता है और स्ट्रोक तब पूरा होता है जब ACTION_UP ट्रिगर हो गया है.

दी गई किसी कार्रवाई के लिए, ACTION_DOWN से ACTION_UP तक MotionEvent कार्रवाइयों का सेट पॉइंटर को मोशन सेट कहा जाता है.

पॉइंटर

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

पॉइंटर इंडेक्स, शून्य से लेकर उनके दिए गए पॉइंटर की संख्या तक होते हैं MotionEvent#pointerCount() 1.

पॉइंटर की ऐक्सिस वैल्यू को, getAxisValue(axis, pointerIndex) तरीके से ऐक्सेस किया जा सकता है. जब पॉइंटर इंडेक्स को हटा दिया जाता है, तब सिस्टम पॉइंटर, पॉइंटर शून्य (0).

MotionEvent ऑब्जेक्ट में यह जानकारी होती है कि किस तरह के पॉइंटर का इस्तेमाल किया जा रहा है. आपने लोगों तक पहुंचाया मुफ़्त में पॉइंटर इंडेक्स के ज़रिए दोहराकर और कॉल करके पॉइंटर टाइप पा सकता है यह getToolType(pointerIndex) तरीका.

पॉइंटर के बारे में ज़्यादा जानने के लिए, मल्टी-टच रजिस्ट्रेशन की सुविधा इस्तेमाल करना देखें हाथ के जेस्चर.

स्टाइलस के इनपुट

स्टाइलस इनपुट के लिए फ़िल्टर किया जा सकता है TOOL_TYPE_STYLUS:

val isStylus = TOOL_TYPE_STYLUS == event.getToolType(pointerIndex)

स्टाइलस यह भी बता सकता है कि इसका इस्तेमाल इरेज़र के तौर पर किया गया है TOOL_TYPE_ERASER:

val isEraser = TOOL_TYPE_ERASER == event.getToolType(pointerIndex)

स्टाइलस ऐक्सिस का डेटा

ACTION_DOWN और ACTION_MOVE, स्टाइलस के बारे में x और ऐक्सिस के बारे में ऐक्सिस डेटा देते हैं y निर्देशांक, दबाव, अभिविन् यास, झुकाव, और होवर.

इस डेटा का ऐक्सेस चालू करने के लिए, MotionEvent API से मिलता है getAxisValue(int), जहां पैरामीटर, इनमें से कोई भी ऐक्सिस आइडेंटिफ़ायर है:

Axis getAxisValue() की रिटर्न वैल्यू
AXIS_X किसी मोशन इवेंट का X कोऑर्डिनेट.
AXIS_Y किसी मोशन इवेंट का Y कोऑर्डिनेट.
AXIS_PRESSURE टचस्क्रीन या टचपैड के लिए, उंगली, स्टाइलस या अन्य पॉइंटर से किया जाने वाला दबाव. माउस या ट्रैकबॉल के लिए, अगर मुख्य बटन दबाया जाता है, तो 1 दबाएं, नहीं तो 0.
AXIS_ORIENTATION टचस्क्रीन या टचपैड के लिए, डिवाइस के वर्टिकल प्लेन के सापेक्ष उंगली, स्टाइलस या अन्य पॉइंटर का ओरिएंटेशन.
AXIS_TILT रेडियन में स्टाइलस का झुकाने का ऐंगल.
AXIS_DISTANCE स्क्रीन से स्टाइलस की दूरी.

उदाहरण के लिए, MotionEvent.getAxisValue(AXIS_X) पहला पॉइंटर.

मल्टी-टच रजिस्ट्रेशन की सुविधा को मैनेज करने का तरीका भी देखें हाथ के जेस्चर.

जगह

नीचे दिए गए कॉल की मदद से, पॉइंटर के x और y कोऑर्डिनेट हासिल किए जा सकते हैं:

स्क्रीन पर स्टाइलस की ड्रॉइंग x और y कोऑर्डिनेट मैप की गई है.
पहली इमेज. स्टाइलस पॉइंटर के X और y स्क्रीन कोऑर्डिनेट.

दबाव

इसकी मदद से, पॉइंटर प्रेशर को फिर से हासिल किया जा सकता है MotionEvent#getAxisValue(AXIS_PRESSURE) या पहले पॉइंटर के लिए, MotionEvent#getPressure().

टचस्क्रीन या टचपैड के लिए दबाव की वैल्यू, 0 (नहीं) के बीच होती है दबाव) और 1 होते हैं, लेकिन स्क्रीन के आधार पर उच्च मान लौटाए जा सकते हैं कैलिब्रेशन.

स्टाइलस स्ट्रोक, जिसमें दबाव कम या ज़्यादा होता है. बाईं तरफ़ स्ट्रोक कम और हल्का होता है. इसका मतलब है कि दबाव कम है. स्ट्रोक, बाईं से दाईं ओर तब तक चौड़ा और गहरा होता जाता है, जब तक कि यह सबसे दाईं ओर चौड़ा और सबसे गहरा हो जाता है. यह सबसे ज़्यादा दबाव दिखाता है.
दूसरी इमेज. दबाव दिखाना—बाईं ओर कम दबाव, दाईं ओर ज़्यादा दबाव.

ओरिएंटेशन

ओरिएंटेशन से पता चलता है कि स्टाइलस किस दिशा में है.

पॉइंटर ओरिएंटेशन को getAxisValue(AXIS_ORIENTATION) का इस्तेमाल करके वापस पाया जा सकता है या getOrientation() (पहले पॉइंटर के लिए).

स्टाइलस के लिए स्क्रीन की दिशा, रेडियन वैल्यू के तौर पर 0 से पाई (ियस) के बीच की होती है घड़ी की सुई की दिशा में या 0 से -पाई की उलटी दिशा में.

ओरिएंटेशन की मदद से, रीयल-लाइफ़ ब्रश का इस्तेमाल किया जा सकता है. उदाहरण के लिए, अगर स्टाइलस एक फ़्लैट ब्रश का प्रतिनिधित्व करता है, फ़्लैट ब्रश की चौड़ाई स्टाइलस की स्क्रीन की दिशा.

तीसरी इमेज. माइनस .57 रेडियन के बारे में बाईं ओर इशारा करता स्टाइलस.

कैमरा झुकाएं

झुकाना, स्क्रीन के सापेक्ष स्टाइलस के झुकाव को मापता है.

टिल्ट, रेडियन में स्टाइलस का पॉज़िटिव ऐंगल लौटाता है, जहां शून्य होता है स्क्रीन से लंबवत और खोजें/2 सतह पर रहें.

झुकाव कोण getAxisValue(AXIS_TILT) का इस्तेमाल करके वापस लाया जा सकता है (इसके लिए कोई शॉर्टकट नहीं है पहला पॉइंटर).

झुकाने की सुविधा का इस्तेमाल करके, असल ज़िंदगी में मौजूद टूल को बिलकुल करीब से बनाया जा सकता है, जैसे झुकाई गई पेंसिल से शेडिंग की नकल करना.

स्टाइलस को स्क्रीन की सतह से करीब 40 डिग्री पर झुकाया गया है.
चौथी इमेज. स्टाइलस, करीब .785 रेडियन पर, या लंबवत से 45 डिग्री पर झुका हुआ है.

कर्सर घुमाएं

स्क्रीन से स्टाइलस की दूरी की जानकारी getAxisValue(AXIS_DISTANCE). यह विधि 0.0 से कोई मान दिखाती है (इससे संपर्क करें करके ज़्यादा वैल्यू पर सेट करें. कर्सर घुमाएं स्क्रीन और स्टाइलस के निब (पॉइंट) के बीच की दूरी Chromebook है. क्योंकि लागू करने की प्रक्रिया अलग-अलग हो, तो ऐप्लिकेशन के ज़रूरी फ़ंक्शन के लिए सटीक वैल्यू पर भरोसा न करें.

स्टाइलस होवर का इस्तेमाल ब्रश के साइज़ की झलक देखने या यह बताने के लिए किया जा सकता है कि बटन को चुना जाएगा.

पांचवीं इमेज. स्क्रीन पर एक स्टाइलस घूम रहा है. स्टाइलस के स्क्रीन की सतह को न छुए जाने पर भी ऐप्लिकेशन प्रतिक्रिया करता है.

ध्यान दें: Compose में ऐसे मॉडिफ़ायर मौजूद हैं जो यूज़र इंटरफ़ेस (यूआई) एलिमेंट के इंटरैक्टिव स्टेटस पर असर डालते हैं:

  • hoverable: पॉइंटर डालने और बाहर निकलने के इवेंट का इस्तेमाल करके कॉम्पोनेंट को कॉन्फ़िगर करें, ताकि उसे कर्सर घुमाया जा सके.
  • indication: इंटरैक्शन होने पर, इस कॉम्पोनेंट के लिए विज़ुअल इफ़ेक्ट दिखाता है.

हथेली के बीच में फंसना, नेविगेट करना, और अनचाहे इनपुट

कभी-कभी मल्टी-टच स्क्रीन की वजह से अनचाहे टच हो सकते हैं. उदाहरण के लिए, जब हैंडराइटिंग के दौरान, सहायता पाने के लिए उपयोगकर्ता अपने हाथ को स्क्रीन पर सामान्य तरीके से रखा हुआ है. हथेली के अस्वीकार होने की एक प्रक्रिया है, जिससे इस समस्या का पता चलता है और आपको इसकी सूचना दी जाती है आखिरी MotionEvent सेट रद्द कर दिया जाना चाहिए.

इसलिए, आपको उपयोगकर्ता के इनपुट का इतिहास रखना चाहिए, ताकि अनचाहा टच को स्क्रीन से निकाला जा सकता है और वैध उपयोगकर्ता इनपुट को फिर से रेंडर किया गया.

ACTION_CANCEL और FLAG_CANCELED

ACTION_CANCEL और FLAG_CANCELED हैं दोनों ही आपको यह सूचित करने के लिए डिज़ाइन किए गए हैं कि पिछला MotionEvent सेट रद्द कर दिया गया है, ताकि आप, उदाहरण के लिए, अंतिम ACTION_DOWN से पहले जैसा कर सकें दिए गए पॉइंटर के लिए ड्रॉइंग ऐप्लिकेशन के लिए स्ट्रोक.

ACTION_CANCEL

Android 1.0 (एपीआई लेवल 1) में जोड़ा गया

ACTION_CANCEL से पता चलता है कि मोशन इवेंट के पिछले सेट को रद्द किया जाना चाहिए.

ACTION_CANCEL तब ट्रिगर होता है, जब इनमें से किसी का पता चलता है:

  • नेविगेशन के लिए हाथ के जेस्चर (हाव-भाव)
  • हथेली के बीच की त्वचा का अस्वीकार होना

ACTION_CANCEL के ट्रिगर होने पर, आपको ऐक्टिव पॉइंटर की पहचान इससे करनी चाहिए getPointerId(getActionIndex()). इसके बाद, इनपुट के इतिहास से उस पॉइंटर से बनाए गए स्ट्रोक को हटा दें और सीन को फिर से रेंडर करें.

FLAG_रद्द किया गया

Android 13 (एपीआई लेवल 33) में जोड़ा गया

FLAG_CANCELED यह बताता है कि पॉइंटर उपयोगकर्ता ने अनजाने में टच किया था. यह झंडा है आम तौर पर तब सेट हो जाता है, जब उपयोगकर्ता गलती से स्क्रीन को छुए डिवाइस या हाथ की हथेली को स्क्रीन पर रखना.

आप फ़्लैग मान तक इस प्रकार पहुंचते हैं:

val cancel = (event.flags and FLAG_CANCELED) == FLAG_CANCELED

अगर फ़्लैग सेट है, तो आपको आखिरी MotionEvent सेट को पहले जैसा करना होगा इस पॉइंटर से ACTION_DOWN.

ACTION_CANCEL की तरह, पॉइंटर को getPointerId(actionIndex) के साथ भी ढूंढा जा सकता है.

छठी इमेज. स्टाइलस स्ट्रोक और पाम टच, MotionEvent सेट बनाते हैं. हथेली के टच को रद्द कर दिया जाता है और डिसप्ले फिर से रेंडर किया जाता है.

फ़ुल स्क्रीन, किनारे से किनारे तक, और नेविगेट करने के लिए हाथ के जेस्चर

अगर कोई ऐप्लिकेशन फ़ुल स्क्रीन मोड में है और उसके किनारे पर कार्रवाई करने लायक एलिमेंट मौजूद हैं, जैसे कि ड्रॉइंग या नोट लेने वाले ऐप्लिकेशन का कैनवस, स्क्रीन के सबसे निचले हिस्से से ऊपर की ओर स्वाइप करके नेविगेशन या ऐप्लिकेशन को बैकग्राउंड पर ले जाने पर कैनवास पर अनचाहे स्पर्श.

सातवीं इमेज. किसी ऐप्लिकेशन को बैकग्राउंड में ले जाने के लिए, हाथ के जेस्चर पर स्वाइप करें.

हाथ के जेस्चर से, अपने ऐप्लिकेशन में अनचाहे टच से बचने के लिए, ये काम किए जा सकते हैं insets का फ़ायदा मिला और ACTION_CANCEL.

पाम अस्वीकार होने, नेविगेट करने के तरीके, और अनचाहे इनपुट भी देखें सेक्शन में जाएं.

इसका इस्तेमाल करें setSystemBarsBehavior() तरीका और BEHAVIOR_SHOW_TRANSIENT_BARS_BY_SWIPE में से WindowInsetsController ताकि नेविगेशन जेस्चर की वजह से, अनचाहे टच इवेंट न हों:

// Configure the behavior of the hidden system bars.
windowInsetsController.systemBarsBehavior =
    WindowInsetsControllerCompat.BEHAVIOR_SHOW_TRANSIENT_BARS_BY_SWIPE

इनसेट और जेस्चर मैनेजमेंट के बारे में ज़्यादा जानने के लिए, यहां देखें:

लाइव स्ट्रीमिंग करने और उसके दिखने के बीच इंतज़ार का समय कम रखना

हार्डवेयर, सिस्टम, और ऐप्लिकेशन को प्रोसेस करने में लगने वाला समय, इंतज़ार के समय को कहते हैं और उपयोगकर्ता का इनपुट रेंडर करना होगा.

लेटेंसी = हार्डवेयर और ओएस इनपुट प्रोसेसिंग + ऐप्लिकेशन प्रोसेसिंग + सिस्टम कंपोज़िटिंग

  • हार्डवेयर रेंडरिंग
इंतज़ार के समय की वजह से रेंडर किया गया स्ट्रोक, स्टाइलस की पोज़िशन से पीछे हो जाता है. रेंडर किए गए स्ट्रोक और स्टाइलस की पोज़िशन के बीच का अंतर, इंतज़ार का समय दिखाता है.
आठवीं इमेज. इंतज़ार के समय की वजह से रेंडर किया गया स्ट्रोक, स्टाइलस की पोज़िशन से पीछे हो जाता है.

इंतज़ार का समय

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

लो-लेटेंसी ग्राफ़िक

Jetpack कम इंतज़ार वाली ग्राफ़िक लाइब्रेरी उपयोगकर्ता के इनपुट और ऑन-स्क्रीन रेंडरिंग के बीच की प्रोसेसिंग समय को कम करता है.

लाइब्रेरी, मल्टी-बफ़र रेंडरिंग से बचते हुए और प्रोसेस होने में लगने वाले समय को कम करती है फ़्रंट-बफ़र रेंडरिंग तकनीक का इस्तेमाल करके, सीधे स्क्रीन.

फ़्रंट-बफ़र रेंडरिंग

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

ऐप्लिकेशन, स्क्रीन बफ़र के हिसाब से डेटा लिखता है और उसे स्क्रीन बफ़र के डेटा से पढ़ता है.
नौवीं इमेज. फ़्रंट-बफ़र रेंडरिंग.
ऐप्लिकेशन मल्टी-बफ़र में डेटा लिखता है, जो स्क्रीन बफ़र के साथ स्वैप होता है. ऐप्लिकेशन, स्क्रीन बफ़र का डेटा पढ़ता है.
10वीं इमेज. मल्टी-बफ़र रेंडरिंग.

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

लो-लेटेंसी लाइब्रेरी, Android 10 (एपीआई लेवल 29) और उसके बाद वाले वर्शन से उपलब्ध है और Android 10 (एपीआई लेवल 29) और इसके बाद के वर्शन वाले ChromeOS डिवाइसों पर.

डिपेंडेंसी

इंतज़ार का समय कम करने वाली लाइब्रेरी, फ़्रंट-बफ़र रेंडरिंग के लिए कॉम्पोनेंट उपलब्ध कराती है लागू करना. ऐप्लिकेशन के मॉड्यूल में, लाइब्रेरी को डिपेंडेंसी के तौर पर जोड़ा जाता है build.gradle फ़ाइल:

dependencies {
    implementation "androidx.graphics:graphics-core:1.0.0-alpha03"
}

GLFrontBufferRenderer कॉलबैक

लो-लेटेंसी लाइब्रेरी में GLFrontBufferRenderer.Callback इंटरफ़ेस जिसमें इन तरीकों के बारे में बताया गया है:

इंतज़ार का समय कम करने वाली लाइब्रेरी का इस्तेमाल, यह तय नहीं करता है कि किस तरह का डेटा इस्तेमाल किया जाएगा GLFrontBufferRenderer.

हालांकि, लाइब्रेरी डेटा को सैकड़ों डेटा पॉइंट की स्ट्रीम के रूप में प्रोसेस करती है; इस तरह, अपने डेटा को इस तरह डिज़ाइन किया जा सकता है कि मेमोरी के इस्तेमाल और बंटवारे को ऑप्टिमाइज़ किया जा सके.

कॉलबैक

कॉलबैक रेंडर करने की सुविधा चालू करने के लिए, GLFrontBufferedRenderer.Callback लागू करें और onDrawFrontBufferedLayer() और onDrawDoubleBufferedLayer() को ओवरराइड करें. GLFrontBufferedRenderer आपके डेटा को ज़्यादा से ज़्यादा रेंडर करने के लिए कॉलबैक का इस्तेमाल करता है को भी बेहतर तरीके से ऑप्टिमाइज़ किया जा सकता है.

val callback = object: GLFrontBufferedRenderer.Callback<DATA_TYPE> {
   override fun onDrawFrontBufferedLayer(
       eglManager: EGLManager,
       bufferInfo: BufferInfo,
       transform: FloatArray,
       param: DATA_TYPE
   ) {
       // OpenGL for front buffer, short, affecting small area of the screen.
   }
   override fun onDrawMultiDoubleBufferedLayer(
       eglManager: EGLManager,
       bufferInfo: BufferInfo,
       transform: FloatArray,
       params: Collection<DATA_TYPE>
   ) {
       // OpenGL full scene rendering.
   }
}
GLFrontBufferedRenderer के किसी इंस्टेंस की जानकारी दें

SurfaceView औरGLFrontBufferedRenderer कॉलबैक जिन्हें आपने पहले बनाया था. GLFrontBufferedRenderer, रेंडरिंग को ऑप्टिमाइज़ करता है फ़्रंट और डबल बफ़र को चालू करने के लिए अपने कॉलबैक का इस्तेमाल करें:

var glFrontBufferRenderer = GLFrontBufferedRenderer<DATA_TYPE>(surfaceView, callbacks)
रेंडरिंग

फ़्रंट-बफ़र रेंडरिंग शुरू होने पर renderFrontBufferedLayer() तरीका, जो onDrawFrontBufferedLayer() कॉलबैक को ट्रिगर करता है.

जब आप commit() फ़ंक्शन, जो onDrawMultiDoubleBufferedLayer() कॉलबैक को ट्रिगर करता है.

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

Google Analytics 4 पर माइग्रेट करने के लिए, requestUnbufferedDispatch() यह पूछने के लिए कि इनपुट सिस्टम मोशन इवेंट को बैच नहीं करता, बल्कि इसके बजाय डिलीवर करता है उपलब्ध होते ही उन्हें अपडेट कर दें:

when (motionEvent.action) {
   MotionEvent.ACTION_DOWN -> {
       // Deliver input events as soon as they arrive.
       view.requestUnbufferedDispatch(motionEvent)
       // Pointer is in contact with the screen.
       glFrontBufferRenderer.renderFrontBufferedLayer(DATA_TYPE)
   }
   MotionEvent.ACTION_MOVE -> {
       // Pointer is moving.
       glFrontBufferRenderer.renderFrontBufferedLayer(DATA_TYPE)
   }
   MotionEvent.ACTION_UP -> {
       // Pointer is not in contact in the screen.
       glFrontBufferRenderer.commit()
   }
   MotionEvent.CANCEL -> {
       // Cancel front buffer; remove last motion set from the screen.
       glFrontBufferRenderer.cancel()
   }
}

रेंडरिंग में क्या करें और क्या न करें

✓ करें

स्क्रीन के छोटे-छोटे हिस्से, हैंडराइटिंग, ड्रॉइंग, स्केचिंग.

✗ ऐसा न करें

फ़ुलस्क्रीन अपडेट, पैन करना, ज़ूम करना. इससे बाल आंसू आ सकता है.

टियरिंग

स्क्रीन बफ़र होने के दौरान स्क्रीन रीफ़्रेश होने पर, फ़ोन में चार्जिंग शुरू हो जाती है साथ ही, बदलाव भी किए गए हैं. स्क्रीन का एक हिस्सा नया डेटा दिखाता है, जबकि दूसरी स्क्रीन पर पुराना डेटा दिखाता है.

स्क्रीन रीफ़्रेश होने के दौरान टूट-फूट की वजह से, Android इमेज के ऊपरी और निचले हिस्से ठीक से अलाइन नहीं हुए हैं.
11वीं इमेज. स्क्रीन के ऊपर से नीचे की ओर रीफ़्रेश होता है.

हलचल का अनुमान

Jetpack मोशन का अनुमान लाइब्रेरी से उपयोगकर्ता के स्ट्रोक पाथ का अनुमान लगाकर और कुछ समय के लिए, रेंडरर की ओर इशारा करता है.

मोशन की अनुमान लगाने वाली लाइब्रेरी से, MotionEvent ऑब्जेक्ट के तौर पर असल उपयोगकर्ता के इनपुट मिलते हैं. ऑब्जेक्ट में x और y निर्देशांक, दबाव, और समय के बारे में जानकारी होती है, भविष्य के MotionEvent का अनुमान लगाने के लिए, गति के अनुमान लगाने वाले टूल की मदद से इनका इस्तेमाल किया जाता है ऑब्जेक्ट हैं.

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

मोशन का अनुमान लगाने वाली लाइब्रेरी Android 4.4 (एपीआई लेवल 19) और ये ऐप्लिकेशन, Android 9 (एपीआई लेवल 28) और इसके बाद के वर्शन वाले ChromeOS डिवाइसों पर काम करते हैं.

इंतज़ार के समय की वजह से रेंडर किया गया स्ट्रोक, स्टाइलस की पोज़िशन से पीछे हो जाता है. स्ट्रोक और स्टाइलस के बीच के अंतर को अनुमान बताने वाले पॉइंट से भर दिया गया है. बचा हुआ अंतर, इंतज़ार का समय है.
12वीं इमेज. मोशन के अनुमान से इंतज़ार का समय कम किया गया.

डिपेंडेंसी

हलचल के सुझाव वाली लाइब्रेरी से अनुमान को लागू करने की सुविधा मिलती है. कॉन्टेंट बनाने लाइब्रेरी को ऐप्लिकेशन की मॉड्यूल build.gradle फ़ाइल में डिपेंडेंसी के तौर पर जोड़ा गया है:

dependencies {
    implementation "androidx.input:input-motionprediction:1.0.0-beta01"
}

लागू करना

गति पूर्वानुमान लाइब्रेरी में MotionEventPredictor इंटरफ़ेस जिसमें इन तरीकों के बारे में बताया गया है:

  • record(): उपयोगकर्ता की कार्रवाइयों के रिकॉर्ड के तौर पर, MotionEvent ऑब्जेक्ट सेव करता है
  • predict(): अनुमानित MotionEvent दिखाता है
MotionEventPredictor के एक इंस्टेंस की जानकारी दें
var motionEventPredictor = MotionEventPredictor.newInstance(view)
अनुमान लगाने वाले को डेटा से फ़ीड करें
motionEventPredictor.record(motionEvent)
अनुमान लगाएं

when (motionEvent.action) {
   MotionEvent.ACTION_MOVE -> {
       val predictedMotionEvent = motionEventPredictor?.predict()
       if(predictedMotionEvent != null) {
            // use predicted MotionEvent to inject a new artificial point
       }
   }
}

मोशन का अनुमान लगाने के लिए क्या करें और क्या न करें

✓ करें

नया अनुमानित पॉइंट जोड़े जाने पर, अनुमानित पॉइंट हटा दें.

✗ ऐसा न करें

फ़ाइनल रेंडरिंग के लिए, अनुमानित पॉइंट का इस्तेमाल न करें.

नोट लेने वाले ऐप्लिकेशन

ChromeOS की मदद से, आपका ऐप्लिकेशन, नोट लेने से जुड़ी कुछ कार्रवाइयों का एलान कर सकता है.

ChromeOS पर किसी ऐप्लिकेशन को नोट लेने वाले ऐप्लिकेशन के तौर पर रजिस्टर करने के लिए, इनपुट साथ काम करता है.

Android पर नोट लेने की सुविधा के तौर पर किसी ऐप्लिकेशन को रजिस्टर करने के लिए, नोट लेने की सुविधा बनाएं ऐप्लिकेशन है.

Android 14 (एपीआई लेवल 34) ने ACTION_CREATE_NOTE इंटेंट, जो आपके ऐप्लिकेशन को लॉक पर नोट लेने की गतिविधि शुरू करने में मदद करता है स्क्रीन.

एमएल किट की मदद से, डिजिटल इंक की पहचान करने की सुविधा

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

ML Kit Ink.Stroke.Builder क्लास Ink ऑब्जेक्ट बनाएं जिन्हें मशीन लर्निंग मॉडल की मदद से प्रोसेस किया जा सके हैंडराइटिंग को टेक्स्ट में बदला जा सकता है.

लिखावट की पहचान करने के अलावा, यह मॉडल हाथ के जेस्चर, जैसे कि मिटाना और सर्कल बनाना.

डिजिटल इंक देखें पहचान देखें.

अन्य संसाधन

डेवलपर गाइड

कोड लैब