स्पंदन - इशारों का परिचय

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

व्यापक रूप से उपयोग किए जाने वाले कुछ इशारों का उल्लेख यहां किया गया है -

  • Tap - छोटी अवधि के लिए डिवाइस की सतह को उंगलियों से छूना और फिर उंगलियों को रिलीज करना।

  • Double Tap - थोड़े समय में दो बार दोहन।

  • Drag - डिवाइस की सतह को उंगलियों से छूना और फिर उंगलियों को स्थिर तरीके से हिलाना और फिर अंत में उंगलियों को रिलीज करना।

  • Flick - खींचने के समान, लेकिन इसे तेजी से करना।

  • Pinch - दो उंगलियों का उपयोग करके डिवाइस की सतह को पिंच करना।

  • Spread/Zoom - पिंचिंग के विपरीत।

  • Panning - डिवाइस की सतह को उँगलियों से छूना और किसी भी दिशा में बिना उँगलियाँ घुसेड़ना।

स्पंदन अपने विशेष विजेट के माध्यम से सभी प्रकार के इशारों के लिए एक उत्कृष्ट समर्थन प्रदान करता है, GestureDetector। GestureDetector एक गैर-विज़ुअल विजेट है जो मुख्य रूप से उपयोगकर्ता के हावभाव का पता लगाने के लिए उपयोग किया जाता है। विजेट पर लक्षित एक इशारे की पहचान करने के लिए, विजेट को GestureDetector विजेट के अंदर रखा जा सकता है। GestureDetector जेस्चर को कैप्चर करेगा और जेस्चर के आधार पर कई ईवेंट को डिस्पैच करेगा।

इशारों और संबंधित घटनाओं में से कुछ नीचे दिए गए हैं -

  • Tap
    • onTapDown
    • onTapUp
    • onTap
    • onTapCancel
  • दो बार टैप
    • onDoubleTap
  • देर तक दबाना
    • onLongPress
  • लंबवत खींचें
    • onVerticalDragStart
    • onVerticalDragUpdate
    • onVerticalDragEnd
  • क्षैतिज खींचें
    • onHorizontalDragStart
    • onHorizontalDragUpdate
    • onHorizontalDragEnd
  • Pan
    • onPanStart
    • onPanUpdate
    • onPanEnd

अब, हम इशारा पहचान सुविधा को शामिल करने और अवधारणा को समझने की कोशिश करने के लिए हैलो वर्ल्ड एप्लिकेशन को संशोधित करते हैं।

  • नीचे दिखाए गए अनुसार MyHomePage विजेट की बॉडी कंटेंट को बदलें -

body: Center( 
   child: GestureDetector( 
      onTap: () { 
         _showDialog(context); 
      }, 
      child: Text( 'Hello World', ) 
   ) 
),
  • निरीक्षण करें कि यहाँ हमने विजेट हाइरार्की में टेक्स्ट विजेट के ऊपर GestureDetector विजेट रखा है , ऑनटैप ईवेंट को कैप्चर किया और फिर अंत में एक डायलॉग विंडो दिखाई।

  • * _ShowDialog * फ़ंक्शन को तब कार्यान्वित करें जब उपयोगकर्ता हैलो वर्ल्ड संदेश को प्रदर्शित करता है , तो एक संवाद प्रस्तुत करता है । यह एक नया डायलॉग विजेट बनाने के लिए जेनेरिक शोडायलॉग और एलर्टडायलॉग विजेट का उपयोग करता है । कोड नीचे दिखाया गया है -

// user defined function void _showDialog(BuildContext context) { 
   // flutter defined function 
   showDialog( 
      context: context, builder: (BuildContext context) { 
         // return object of type Dialog
         return AlertDialog( 
            title: new Text("Message"), 
            content: new Text("Hello World"),   
            actions: <Widget>[ 
               new FlatButton( 
                  child: new Text("Close"),  
                  onPressed: () {   
                     Navigator.of(context).pop();  
                  }, 
               ), 
            ], 
         ); 
      }, 
   ); 
}
  • एप्लिकेशन हॉट रीलोड सुविधा का उपयोग करके डिवाइस में पुनः लोड होगा। अब, बस नमस्ते विश्व संदेश पर क्लिक करें और यह नीचे दिए गए संवाद को दिखाएगा -

  • अब डायलॉग में क्लोज ऑप्शन पर क्लिक करके डायलॉग को बंद करें

  • पूरा कोड (main.dart) इस प्रकार है -

import 'package:flutter/material.dart'; 
void main() => runApp(MyApp()); 

class MyApp extends StatelessWidget { 
   // This widget is the root of your application.    
   @override 
   Widget build(BuildContext context) {
      return MaterialApp(
         title: 'Hello World Demo Application', 
         theme: ThemeData( primarySwatch: Colors.blue,), 
         home: MyHomePage(title: 'Home page'), 
      ); 
   }
}
class MyHomePage extends StatelessWidget {
   MyHomePage({Key key, this.title}) : super(key: key); 
   final String title; 
   
   // user defined function 
   void _showDialog(BuildContext context) { 
      // flutter defined function showDialog( 
         context: context, builder: (BuildContext context) { 
            // return object of type Dialog return AlertDialog(
               title: new Text("Message"), 
               content: new Text("Hello World"),   
               actions: <Widget>[
                  new FlatButton(
                     child: new Text("Close"), 
                     onPressed: () {   
                        Navigator.of(context).pop();  
                     }, 
                  ), 
               ],
            );
         },
      );
   }
   @override 
   Widget build(BuildContext context) {
      return Scaffold(
         appBar: AppBar(title: Text(this.title),),
         body: Center(
            child: GestureDetector( 
               onTap: () {
                  _showDialog(context);
               },
            child: Text( 'Hello World', )
            )
         ),
      );
   }
}

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

  • PointerDownEvent
  • PointerMoveEvent
  • PointerUpEvent
  • PointerCancelEvent

स्पंदन विशेष के साथ-साथ उन्नत इशारों को करने के लिए विगेट्स का एक छोटा सा सेट भी प्रदान करता है। विजेट नीचे सूचीबद्ध हैं -

  • Dismissible - विजेट को खारिज करने के लिए झटका इशारे का समर्थन करता है।

  • Draggable - विजेट को स्थानांतरित करने के लिए इशारे को खींचें का समर्थन करता है।

  • LongPressDraggable - विजेट को ले जाने के लिए जेस्चर को ड्रैग करने का समर्थन करता है, जब इसका पैरेंट विजेट भी ड्रैग करने योग्य होता है।

  • DragTarget- किसी भी ड्रैग करने योग्य विजेट को स्वीकार करता है

  • IgnorePointer - इशारे का पता लगाने की प्रक्रिया से विजेट और उसके बच्चों को छुपाता है।

  • AbsorbPointer - इशारे का पता लगाने की प्रक्रिया को ही रोक देता है और इसलिए कोई भी अतिव्यापी विजेट भी इशारे का पता लगाने की प्रक्रिया में भाग लेने में सक्षम नहीं होता है और इसलिए, कोई भी घटना नहीं उठती है।

  • Scrollable - विजेट के अंदर उपलब्ध सामग्री का समर्थन स्क्रॉलिंग।