स्पंदन - लेआउट का परिचय

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

लेआउट विजेट का प्रकार

लेआउट विगेट्स को उसके बच्चे के आधार पर दो अलग-अलग श्रेणी में बांटा जा सकता है -

  • एकल बच्चे का समर्थन करने वाला विजेट
  • विजेट कई बच्चे का समर्थन करता है

आइए हम आगामी अनुभागों में दोनों प्रकार के विजेट और इसकी कार्यक्षमता सीखते हैं।

सिंगल चाइल्ड विजेट्स

इस श्रेणी में, विगेट्स के पास केवल एक विजेट होगा जैसा कि उसका बच्चा और प्रत्येक विजेट में एक विशेष लेआउट कार्यक्षमता होगी।

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

सिंगल चाइल्ड विजेट हाई क्वालिटी विजेट बनाने के लिए बढ़िया विकल्प हैं जैसे कि सिंगल फंक्शनलिटी जैसे बटन, लेबल इत्यादि।

कंटेनर विजेट का उपयोग करके एक साधारण बटन बनाने का कोड इस प्रकार है -

class MyButton extends StatelessWidget {
   MyButton({Key key}) : super(key: key); 

   @override 
   Widget build(BuildContext context) {
      return Container(
         decoration: const BoxDecoration(
            border: Border(
               top: BorderSide(width: 1.0, color: Color(0xFFFFFFFFFF)),
               left: BorderSide(width: 1.0, color: Color(0xFFFFFFFFFF)),
               right: BorderSide(width: 1.0, color: Color(0xFFFF000000)),
               bottom: BorderSide(width: 1.0, color: Color(0xFFFF000000)),
            ),
         ),
         child: Container(
            padding: const
            EdgeInsets.symmetric(horizontal: 20.0, vertical: 2.0),
            decoration: const BoxDecoration(
               border: Border(
                  top: BorderSide(width: 1.0, color: Color(0xFFFFDFDFDF)),
                  left: BorderSide(width: 1.0, color: Color(0xFFFFDFDFDF)),
                  right: BorderSide(width: 1.0, color: Color(0xFFFF7F7F7F)),
                  bottom: BorderSide(width: 1.0, color: Color(0xFFFF7F7F7F)),
               ),
               color: Colors.grey,
            ),
            child: const Text(
               'OK',textAlign: TextAlign.center, style: TextStyle(color: Colors.black)
            ), 
         ), 
      ); 
   }
}

यहाँ, हमने दो विजेट्स का उपयोग किया है - एक कंटेनर विजेट और एक टेक्स्ट विजेट। विजेट का परिणाम एक कस्टम बटन के रूप में नीचे दिखाया गया है -

आइए हम Flutter द्वारा प्रदान किए गए कुछ सबसे महत्वपूर्ण एकल चाइल्ड लेआउट विजेट देखें -

  • Padding- दिए गए पैडिंग द्वारा अपने बच्चे के विजेट को व्यवस्थित करने के लिए उपयोग किया जाता है। यहां, एजिंगसेट्स वर्ग द्वारा पैडिंग प्रदान की जा सकती है ।

  • Align- संरेखण संपत्ति के मूल्य का उपयोग करके अपने बाल विजेट को अपने भीतर संरेखित करें । संरेखण संपत्ति के लिए मूल्य FractionalOffset वर्ग द्वारा प्रदान किया जा सकता है । FractionalOffset वर्ग शीर्ष बाएं से एक दूरी के संदर्भ में ऑफसेट निर्दिष्ट करता है।

ऑफसेट के कुछ संभावित मूल्य इस प्रकार हैं -

  • FractionalOffset (1.0, 0.0) शीर्ष दाएं का प्रतिनिधित्व करता है।

  • FractionalOffset (0.0, 1.0) नीचे बाईं ओर का प्रतिनिधित्व करता है।

ऑफसेट के बारे में एक नमूना कोड नीचे दिखाया गया है -

Center(
   child: Container(
      height: 100.0, 
      width: 100.0, 
      color: Colors.yellow, child: Align(
         alignment: FractionalOffset(0.2, 0.6),
         child: Container( height: 40.0, width:
            40.0, color: Colors.red,
         ), 
      ), 
   ), 
)
  • FittedBox - यह चाइल्ड विजेट को मापता है और फिर निर्दिष्ट फिट के अनुसार इसे पोस्ट करता है।

  • AspectRatio - यह बच्चे के विजेट को निर्दिष्ट पहलू अनुपात में आकार देने का प्रयास करता है

  • ConstrainedBox

  • Baseline

  • FractinallySizedBox

  • IntrinsicHeight

  • IntrinsicWidth

  • LiimitedBox

  • OffStage

  • OverflowBox

  • SizedBox

  • SizedOverflowBox

  • Transform

  • CustomSingleChildLayout

हमारा हैलो वर्ल्ड एप्लिकेशन होम पेज को डिजाइन करने के लिए सामग्री आधारित लेआउट विगेट्स का उपयोग कर रहा है। आइए हम नीचे दिए गए अनुसार बुनियादी लेआउट विजेट का उपयोग करके होम पेज बनाने के लिए अपने हैलो वर्ल्ड एप्लिकेशन को संशोधित करते हैं -

  • Container - अमीर, एकल बच्चे, संरेखण, पैडिंग, बॉर्डर और मार्जिन के साथ बॉक्स आधारित कंटेनर विजेट के साथ-साथ समृद्ध स्टाइलिंग विशेषताएं।

  • Center - सिंपल, सिंगल चाइल्ड कंटेनर विजेट, जो अपने चाइल्ड विजेट को सेंटर करता है।

MyHomePage और MyApp विजेट का संशोधित कोड नीचे दिया गया है -

class MyApp extends StatelessWidget {
   @override
   Widget build(BuildContext context) {
      return MyHomePage(title: "Hello World demo app");
   }
}
class MyHomePage extends StatelessWidget {
   MyHomePage({Key key, this.title}) : super(key: key);
   final String title;
   @override
   Widget build(BuildContext context) {
      return Container(
         decoration: BoxDecoration(color: Colors.white,),
         padding: EdgeInsets.all(25), child: Center(
            child:Text(
               'Hello World', style: TextStyle(
                  color: Colors.black, letterSpacing: 0.5, fontSize: 20,
               ),
               textDirection: TextDirection.ltr,
            ),
         )
      );
   }
}

यहाँ,

  • कंटेनर विजेट शीर्ष स्तर या रूट विजेट है। कंटेनर को इसकी सामग्री को लेआउट करने के लिए सजावट और गद्दी संपत्ति का उपयोग करके कॉन्फ़िगर किया गया है।

  • BoxDecoration में कंटेनर विजेट को सजाने के लिए रंग, बॉर्डर, आदि जैसे कई गुण हैं, और कंटेनर के रंग को सेट करने के लिए रंग का उपयोग किया जाता है।

  • कंटेनर विजेट की पैडिंग dgeInsets वर्ग का उपयोग करके सेट की गई है , जो पैडिंग मान को निर्दिष्ट करने का विकल्प प्रदान करती है।

  • केंद्र कंटेनर विजेट का बच्चा विजेट है । फिर से, पाठ केंद्र विजेट का बच्चा है । पाठ संदेश दिखाने के लिए प्रयोग किया जाता है और केंद्र माता पिता विजेट, के संबंध में पाठ संदेश के केंद्र के लिए प्रयोग किया जाता है कंटेनर

ऊपर दिए गए कोड का अंतिम परिणाम एक लेआउट नमूना है जैसा कि नीचे दिखाया गया है -

मल्टीपल चाइल्ड विजेट

इस श्रेणी में, दिए गए विजेट में एक से अधिक चाइल्ड विजेट होंगे और प्रत्येक विजेट का लेआउट अद्वितीय है।

उदाहरण के लिए, रो विजेट अपने बच्चों को क्षैतिज दिशा में बाहर ले जाने की अनुमति देता है , जबकि कॉलम विजेट ऊर्ध्वाधर दिशा में अपने बच्चों को बाहर रखने की अनुमति देता है। पंक्ति और स्तंभ की रचना करके , किसी भी स्तर की जटिलता वाले विजेट का निर्माण किया जा सकता है।

आइए हम इस खंड में अक्सर उपयोग किए जाने वाले कुछ विगेट्स सीखते हैं।

  • Row - अपने बच्चों को क्षैतिज रूप से व्यवस्थित करने की अनुमति देता है।

  • Column - अपने बच्चों को ऊर्ध्वाधर तरीके से व्यवस्थित करने की अनुमति देता है।

  • ListView - अपने बच्चों को सूची के रूप में व्यवस्थित करने की अनुमति देता है।

  • GridView - अपने बच्चों को गैलरी के रूप में व्यवस्थित करने की अनुमति देता है।

  • Expanded - रो और कॉलम विजेट के बच्चों को अधिकतम संभव क्षेत्र पर कब्जा करने के लिए उपयोग किया जाता है।

  • Table - टेबल आधारित विजेट।

  • Flow - प्रवाह आधारित विजेट।

  • Stack - स्टैक आधारित विजेट।

उन्नत लेआउट अनुप्रयोग

इस भाग में, आइए जानें कि सिंगल और मल्टीपल चाइल्ड लेआउट विजेट दोनों का उपयोग करके कस्टम डिज़ाइन के साथ उत्पाद लिस्टिंग का एक जटिल उपयोगकर्ता इंटरफ़ेस कैसे बनाया जाए ।

इस उद्देश्य के लिए, नीचे दिए गए अनुक्रम का पालन करें -

  • Android स्टूडियो, product_layout_app में एक नया फ़्लटर एप्लिकेशन बनाएं ।

  • मुख्य कोड को फ़ोलोइंग कोड से बदलें -

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: 'Flutter Demo', theme: ThemeData( 
         primarySwatch: Colors.blue,), 
         home: MyHomePage(title: 'Product layout demo home page'),
      ); 
   } 
} 
class MyHomePage extends StatelessWidget {
   MyHomePage({Key key, this.title}) : super(key: key); 
   final String title; 
      
   @override 
   Widget build(BuildContext context) {
      return Scaffold(
         appBar: AppBar(title: Text(this.title),), 
         body: Center(child: Text( 'Hello World', )), 
      ); 
   }
}
  • Here,

  • हमने डिफ़ॉल्ट स्टेटफुलगेट के बजाय स्टेटलेसविजेट को विस्तारित करके MyHomePage विजेट बनाया है और फिर संबंधित कोड को हटा दिया है।

  • अब, जैसा कि नीचे दिखाया गया है, निर्दिष्ट डिज़ाइन के अनुसार एक नया विजेट, प्रोडक्टबॉक्स बनाएं -

  • ProductBox के लिए कोड निम्नानुसार है।

class ProductBox extends StatelessWidget {
   ProductBox({Key key, this.name, this.description, this.price, this.image}) 
      : super(key: key); 
   final String name; 
   final String description; 
   final int price; 
   final String image; 

   Widget build(BuildContext context) {
      return Container(
         padding: EdgeInsets.all(2), height: 120,  child: Card( 
            child: Row(
               mainAxisAlignment: MainAxisAlignment.spaceEvenly, children: <Widget>[
                  Image.asset("assets/appimages/" +image), Expanded(
                     child: Container(
                        padding: EdgeInsets.all(5), child: Column(
                           mainAxisAlignment: MainAxisAlignment.spaceEvenly, 
                              children: <Widget>[ 
                              
                              Text(this.name, style: TextStyle(fontWeight: 
                                 FontWeight.bold)), Text(this.description), 
                              Text("Price: " + this.price.toString()), 
                           ], 
                        )
                     )
                  )
               ]
            )
         )
      );
   }
}
  • कृपया निम्नलिखित कोड देखें -

  • ProductBox ने नीचे बताए अनुसार चार तर्कों का इस्तेमाल किया है -

    • नाम - उत्पाद का नाम

    • विवरण - उत्पाद विवरण

    • कीमत - उत्पाद की कीमत

    • छवि - उत्पाद की छवि

  • ProductBox नीचे दिए गए अनुसार सात बिल्ड-इन विगेट्स का उपयोग करता है -

    • Container
    • Expanded
    • Row
    • Column
    • Card
    • Text
    • Image
  • ProductBox को उपर्युक्त विजेट का उपयोग करके बनाया गया है। विजेट की व्यवस्था या पदानुक्रम नीचे दिखाए गए चित्र में निर्दिष्ट है -

  • अब, आवेदन की संपत्ति फ़ोल्डर में उत्पाद जानकारी के लिए कुछ डमी छवि (नीचे देखें) रखें और नीचे दिखाए गए अनुसार pubspec.yaml फ़ाइल में संपत्ति फ़ोल्डर को कॉन्फ़िगर करें -

assets: 
   - assets/appimages/floppy.png 
   - assets/appimages/iphone.png 
   - assets/appimages/laptop.png 
   - assets/appimages/pendrive.png 
   - assets/appimages/pixel.png 
   - assets/appimages/tablet.png

iPhone.png

Pixel.png

Laptop.png

Tablet.png

Pendrive.png

Floppy.png

अंत में, उपयोग ProductBox में विजेट MyHomePage विजेट के रूप में नीचे निर्दिष्ट -

class MyHomePage extends StatelessWidget { 
   MyHomePage({Key key, this.title}) : super(key: key); 
   final String title; 

   @override 
   Widget build(BuildContext context) {
      return Scaffold(
         appBar: AppBar(title:Text("Product Listing")), 
         body: ListView(
            shrinkWrap: true, padding: const EdgeInsets.fromLTRB(2.0, 10.0, 2.0, 10.0), 
            children: <Widget> [
               ProductBox(
                  name: "iPhone", 
                  description: "iPhone is the stylist phone ever", 
                  price: 1000, 
                  image: "iphone.png"
               ), 
               ProductBox(
                  name: "Pixel", 
                  description: "Pixel is the most featureful phone ever", 
                  price: 800, 
                  image: "pixel.png"
               ), 
               ProductBox( 
                  name: "Laptop", 
                  description: "Laptop is most productive development tool", 
                  price: 2000, 
                  image: "laptop.png"
               ), 
               ProductBox( 
                  name: "Tablet", 
                  description: "Tablet is the most useful device ever for meeting", 
                  price: 1500, 
                  image: "tablet.png"
               ), 
               ProductBox(
                  name: "Pendrive", 
                  description: "Pendrive is useful storage medium", 
                  price: 100, 
                  image: "pendrive.png"
               ), 
               ProductBox(
                  name: "Floppy Drive", 
                  description: "Floppy drive is useful rescue storage medium", 
                  price: 20, 
                  image: "floppy.png"
               ), 
            ],
         )
      );
   }
}
  • यहाँ, हमने ProductBox का उपयोग ListView विजेट के बच्चों के रूप में किया है ।

  • उत्पाद लेआउट एप्लिकेशन (product_layout_app) का पूरा कोड (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: 'Flutter Demo', theme: ThemeData(
            primarySwatch: Colors.blue,
         ), 
         home: MyHomePage(title: 'Product layout demo home page'), 
      );
   }
}
class MyHomePage extends StatelessWidget { 
   MyHomePage({Key key, this.title}) : super(key: key); 
   final String title; 
   
   @override 
   Widget build(BuildContext context) { 
      return Scaffold( 
         appBar: AppBar(title: Text("Product Listing")), 
         body: ListView(
            shrinkWrap: true, 
            padding: const EdgeInsets.fromLTRB(2.0, 10.0, 2.0, 10.0), 
            children: <Widget>[ 
               ProductBox(
                  name: "iPhone", 
                  description: "iPhone is the stylist phone ever", 
                  price: 1000, 
                  image: "iphone.png"
               ), 
               ProductBox( 
                  name: "Pixel",    
                  description: "Pixel is the most featureful phone ever", 
                  price: 800, 
                  image: "pixel.png"
               ), 
               ProductBox( 
                  name: "Laptop", 
                  description: "Laptop is most productive development tool", 
                  price: 2000, 
                  image: "laptop.png"
               ), 
               ProductBox( 
                  name: "Tablet", 
                  description: "Tablet is the most useful device ever for meeting", 
                  price: 1500, 
                  image: "tablet.png"
               ), 
               ProductBox( 
                  name: "Pendrive", 
                  description: "Pendrive is useful storage medium", 
                  price: 100, 
                  image: "pendrive.png"
               ), 
               ProductBox(
                  name: "Floppy Drive", 
                  description: "Floppy drive is useful rescue storage medium", 
                  price: 20, 
                  image: "floppy.png"
               ), 
            ],
         )
      );
   }
}
class ProductBox extends StatelessWidget {
   ProductBox({Key key, this.name, this.description, this.price, this.image}) :
      super(key: key); 
   final String name; 
   final String description; 
   final int price; 
   final String image; 
   
   Widget build(BuildContext context) {
      return Container(
         padding: EdgeInsets.all(2), 
         height: 120, 
         child: Card(
            child: Row(
               mainAxisAlignment: MainAxisAlignment.spaceEvenly, 
               children: <Widget>[ 
                  Image.asset("assets/appimages/" + image), 
                  Expanded( 
                     child: Container( 
                        padding: EdgeInsets.all(5), 
                        child: Column(    
                           mainAxisAlignment: MainAxisAlignment.spaceEvenly, 
                           children: <Widget>[ 
                              Text(
                                 this.name, style: TextStyle(
                                    fontWeight: FontWeight.bold
                                 )
                              ),
                              Text(this.description), Text(
                                 "Price: " + this.price.toString()
                              ), 
                           ], 
                        )
                     )
                  )
               ]
            )
         )
      );
   }
}

आवेदन का अंतिम आउटपुट निम्नानुसार है -