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