स्पंदन - राज्य प्रबंधन
एक आवेदन में राज्य का प्रबंधन एक आवेदन के जीवन चक्र में सबसे महत्वपूर्ण और आवश्यक प्रक्रिया में से एक है।
आइए एक साधारण शॉपिंग कार्ट एप्लिकेशन पर विचार करें।
उपयोगकर्ता आवेदन में अपनी साख का उपयोग करके लॉगिन करेगा।
एक बार जब उपयोगकर्ता लॉग इन हो जाता है, तो एप्लिकेशन को सभी स्क्रीन में लॉग इन यूजर डिटेल जारी रखनी चाहिए।
फिर, जब उपयोगकर्ता किसी उत्पाद का चयन करता है और एक कार्ट में सहेजा जाता है, तो कार्ट की जानकारी पृष्ठों के बीच बनी रहनी चाहिए जब तक कि उपयोगकर्ता कार्ट से बाहर की जाँच न कर ले।
किसी भी समय उपयोगकर्ता और उनकी कार्ट जानकारी को उस उदाहरण पर एप्लिकेशन की स्थिति कहा जाता है।
एक राज्य प्रबंधन को दो श्रेणियों में विभाजित किया जा सकता है, यह उस अवधि के आधार पर होता है, जब विशेष राज्य आवेदन में रहता है।
Ephemeral- एनीमेशन की वर्तमान स्थिति या किसी उत्पाद की वर्तमान रेटिंग जैसे एकल पृष्ठ की तरह कुछ सेकंड के लिए अंतिम। स्पंदन स्टेटफुलगेट के माध्यम से इसका समर्थन करता है।
app state - पिछले पूरे आवेदन उपयोगकर्ता जानकारी में लॉग इन की तरह, गाड़ी जानकारी, आदि के लिए, स्पंदन इसके माध्यम से scoped_model का समर्थन करता है।
नेविगेशन और रूटिंग
किसी भी एप्लिकेशन में, एक पेज / स्क्रीन से दूसरे पेज पर नेविगेट करना एप्लिकेशन के कार्य प्रवाह को परिभाषित करता है। जिस तरह से किसी अनुप्रयोग के नेविगेशन को संभाला जाता है उसे रूटिंग कहा जाता है। स्पंदन एक बुनियादी मार्ग वर्ग प्रदान करता है - MaterialPageRoute और दो विधियाँ - Navigator.push और Navigator.pop, किसी अनुप्रयोग के कार्य प्रवाह को परिभाषित करने के लिए।
MaterialPageRoute
MaterialPageRoute एक ऐसा विजेट है जिसका उपयोग यूआई को एक मंच विशिष्ट एनीमेशन के साथ पूरी स्क्रीन को बदलने के लिए किया जाता है।
MaterialPageRoute(builder: (context) => Widget())
यहां, बिल्डर एप्लिकेशन के वर्तमान संदर्भ को दबाकर अपनी सामग्री बनाने के लिए एक फ़ंक्शन को स्वीकार करेगा।
Navigation.push
Navigation.push का उपयोग MaterialPageRoute विजेट का उपयोग करके नई स्क्रीन पर नेविगेट करने के लिए किया जाता है।
Navigator.push( context, MaterialPageRoute(builder: (context) => Widget()), );
Navigation.pop
नेवीगेशन.पॉप का उपयोग पिछली स्क्रीन पर नेविगेट करने के लिए किया जाता है।
Navigator.push(context);
नेविगेशन अवधारणा को बेहतर ढंग से समझने के लिए एक नया एप्लिकेशन बनाएं।
Android स्टूडियो, product_nav_app में एक नया फ़्लटर एप्लिकेशन बनाएं
Product_nav_app से product_state_app तक की संपत्ति फ़ोल्डर कॉपी करें और pubspec.yaml फ़ाइल के अंदर संपत्ति जोड़ें।
flutter:
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
हमारे स्टार्टअप कोड के साथ डिफ़ॉल्ट स्टार्टअप कोड (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 state 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',)
),
);
}
}
उत्पाद जानकारी को व्यवस्थित करने के लिए एक उत्पाद वर्ग बनाते हैं।
class Product {
final String name;
final String description;
final int price;
final String image;
Product(this.name, this.description, this.price, this.image);
}
हमें अपने डमी उत्पाद रिकॉर्ड बनाने के लिए उत्पाद वर्ग में एक विधि getProducts लिखें।
static List<Product> getProducts() {
List<Product> items = <Product>[];
items.add(
Product(
"Pixel",
"Pixel is the most feature-full phone ever", 800,
"pixel.png"
)
);
items.add(
Product(
"Laptop",
"Laptop is most productive development tool",
2000, "
laptop.png"
)
);
items.add(
Product(
"Tablet",
"Tablet is the most useful device ever for meeting",
1500,
"tablet.png"
)
);
items.add(
Product(
"Pendrive",
"Pendrive is useful storage medium",
100,
"pendrive.png"
)
);
items.add(
Product(
"Floppy Drive",
"Floppy drive is useful rescue storage medium",
20,
"floppy.png"
)
);
return items;
}
import product.dart in main.dart
import 'Product.dart';
हमें अपना नया विजेट, रेटिंगबॉक्स शामिल करें।
class RatingBox extends StatefulWidget {
@override
_RatingBoxState createState() =>_RatingBoxState();
}
class _RatingBoxState extends State<RatingBox> {
int _rating = 0;
void _setRatingAsOne() {
setState(() {
_rating = 1;
});
}
void _setRatingAsTwo() {
setState(() {
_rating = 2;
});
}
void _setRatingAsThree() {
setState(() {
_rating = 3;
});
}
Widget build(BuildContext context) {
double _size = 20;
print(_rating);
return Row(
mainAxisAlignment: MainAxisAlignment.end,
crossAxisAlignment: CrossAxisAlignment.end,
mainAxisSize: MainAxisSize.max,
children: <Widget>[
Container(
padding: EdgeInsets.all(0),
child: IconButton(
icon: (
_rating >= 1?
Icon(
Icons.star,
size: _size,
)
: Icon(
Icons.star_border,
size: _size,
)
),
color: Colors.red[500],
onPressed: _setRatingAsOne,
iconSize: _size,
),
),
Container(
padding: EdgeInsets.all(0),
child: IconButton(
icon: (
_rating >= 2?
Icon(
Icons.star,
size: _size,
)
: Icon(
Icons.star_border,
size: _size,
)
),
color: Colors.red[500],
onPressed: _setRatingAsTwo,
iconSize: _size,
),
),
Container(
padding: EdgeInsets.all(0),
child: IconButton(
icon: (
_rating >= 3 ?
Icon(
Icons.star,
size: _size,
)
: Icon(
Icons.star_border,
size: _size,
)
),
color: Colors.red[500],
onPressed: _setRatingAsThree,
iconSize: _size,
),
),
],
);
}
}
हमारे नए उत्पाद वर्ग के साथ काम करने के लिए अपने ProductBox विजेट को संशोधित करें।
class ProductBox extends StatelessWidget {
ProductBox({Key key, this.item}) : super(key: key);
final Product item;
Widget build(BuildContext context) {
return Container(
padding: EdgeInsets.all(2),
height: 140,
child: Card(
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Image.asset("assets/appimages/" + this.item.image),
Expanded(
child: Container(
padding: EdgeInsets.all(5),
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Text(this.item.name,
style: TextStyle(fontWeight: FontWeight.bold)),
Text(this.item.description),
Text("Price: " + this.item.price.toString()),
RatingBox(),
],
)
)
)
]
),
)
);
}
}
उत्पाद मॉडल के साथ काम करने और ListView का उपयोग करके सभी उत्पादों को सूचीबद्ध करने के लिए हमारे MyHomePage विजेट को फिर से लिखें।
class MyHomePage extends StatelessWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
final items = Product.getProducts();
@override
Widget build(BuildContext context) {
return Scaffold( appBar: AppBar(title: Text("Product Navigation")),
body: ListView.builder(
itemCount: items.length,
itemBuilder: (context, index) {
return GestureDetector(
child: ProductBox(item: items[index]),
onTap: () {
Navigator.push(
context, MaterialPageRoute(
builder: (context) => ProductPage(item: items[index]),
),
);
},
);
},
));
}
}
यहां, हमने उत्पाद विवरण पृष्ठ पर नेविगेट करने के लिए MaterialPageRoute का उपयोग किया है।
अब, उत्पाद विवरण दिखाने के लिए ProductPage को जोड़ते हैं।
class ProductPage extends StatelessWidget {
ProductPage({Key key, this.item}) : super(key: key);
final Product item;
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(this.item.name),
),
body: Center(
child: Container(
padding: EdgeInsets.all(0),
child: Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Image.asset("assets/appimages/" + this.item.image),
Expanded(
child: Container(
padding: EdgeInsets.all(5),
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Text(
this.item.name, style: TextStyle(
fontWeight: FontWeight.bold
)
),
Text(this.item.description),
Text("Price: " + this.item.price.toString()),
RatingBox(),
],
)
)
)
]
),
),
),
);
}
}
आवेदन का पूरा कोड इस प्रकार है -
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class Product {
final String name;
final String description;
final int price;
final String image;
Product(this.name, this.description, this.price, this.image);
static List<Product> getProducts() {
List<Product> items = <Product>[];
items.add(
Product(
"Pixel",
"Pixel is the most featureful phone ever",
800,
"pixel.png"
)
);
items.add(
Product(
"Laptop",
"Laptop is most productive development tool",
2000,
"laptop.png"
)
);
items.add(
Product(
"Tablet",
"Tablet is the most useful device ever for meeting",
1500,
"tablet.png"
)
);
items.add(
Product(
"Pendrive",
"iPhone is the stylist phone ever",
100,
"pendrive.png"
)
);
items.add(
Product(
"Floppy Drive",
"iPhone is the stylist phone ever",
20,
"floppy.png"
)
);
items.add(
Product(
"iPhone",
"iPhone is the stylist phone ever",
1000,
"iphone.png"
)
);
return items;
}
}
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 Navigation demo home page'),
);
}
}
class MyHomePage extends StatelessWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
final items = Product.getProducts();
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text("Product Navigation")),
body: ListView.builder(
itemCount: items.length,
itemBuilder: (context, index) {
return GestureDetector(
child: ProductBox(item: items[index]),
onTap: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => ProductPage(item: items[index]),
),
);
},
);
},
)
);
}
}
class ProductPage extends StatelessWidget {
ProductPage({Key key, this.item}) : super(key: key);
final Product item;
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(this.item.name),
),
body: Center(
child: Container(
padding: EdgeInsets.all(0),
child: Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Image.asset("assets/appimages/" + this.item.image),
Expanded(
child: Container(
padding: EdgeInsets.all(5),
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Text(this.item.name, style: TextStyle(fontWeight: FontWeight.bold)),
Text(this.item.description),
Text("Price: " + this.item.price.toString()),
RatingBox(),
],
)
)
)
]
),
),
),
);
}
}
class RatingBox extends StatefulWidget {
@override
_RatingBoxState createState() => _RatingBoxState();
}
class _RatingBoxState extends State<RatingBox> {
int _rating = 0;
void _setRatingAsOne() {
setState(() {
_rating = 1;
});
}
void _setRatingAsTwo() {
setState(() {
_rating = 2;
});
}
void _setRatingAsThree() {
setState(() {
_rating = 3;
});
}
Widget build(BuildContext context) {
double _size = 20;
print(_rating);
return Row(
mainAxisAlignment: MainAxisAlignment.end,
crossAxisAlignment: CrossAxisAlignment.end,
mainAxisSize: MainAxisSize.max,
children: <Widget>[
Container(
padding: EdgeInsets.all(0),
child: IconButton(
icon: (
_rating >= 1 ? Icon(
Icons.star,
size: _size,
)
: Icon(
Icons.star_border,
size: _size,
)
),
color: Colors.red[500],
onPressed: _setRatingAsOne,
iconSize: _size,
),
),
Container(
padding: EdgeInsets.all(0),
child: IconButton(
icon: (
_rating >= 2 ?
Icon(
Icons.star,
size: _size,
)
: Icon(
Icons.star_border,
size: _size,
)
),
color: Colors.red[500],
onPressed: _setRatingAsTwo,
iconSize: _size,
),
),
Container(
padding: EdgeInsets.all(0),
child: IconButton(
icon: (
_rating >= 3 ?
Icon(
Icons.star,
size: _size,
)
: Icon(
Icons.star_border,
size: _size,
)
),
color: Colors.red[500],
onPressed: _setRatingAsThree,
iconSize: _size,
),
),
],
);
}
}
class ProductBox extends StatelessWidget {
ProductBox({Key key, this.item}) : super(key: key);
final Product item;
Widget build(BuildContext context) {
return Container(
padding: EdgeInsets.all(2),
height: 140,
child: Card(
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Image.asset("assets/appimages/" + this.item.image),
Expanded(
child: Container(
padding: EdgeInsets.all(5),
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Text(this.item.name, style: TextStyle(fontWeight: FontWeight.bold)), Text(this.item.description),
Text("Price: " + this.item.price.toString()),
RatingBox(),
],
)
)
)
]
),
)
);
}
}
एप्लिकेशन चलाएं और उत्पाद आइटम में से किसी एक पर क्लिक करें। यह प्रासंगिक विवरण पृष्ठ दिखाएगा। हम बैक बटन पर क्लिक करके होम पेज पर जा सकते हैं। उत्पाद सूची पृष्ठ और अनुप्रयोग के उत्पाद विवरण पृष्ठ को निम्नानुसार दिखाया गया है -