Flutter မှာ မြန်မာနိုင်ငံတော် အလံ ဆွဲကြမယ်
ဖွဘုတ် ပွတ်ရင်းနဲ့ Memories မှာ ကိုအိမောင်လုပ်ထားတဲ့ CSS နဲ့ ဆွဲထားတဲ့ မြန်မာနိုင်ငံပုံတက်လာတော့ Flutter မှာလည်း ဆွဲလို့ရသားပဲ ဆိုပြီး စဉ်းစားမိတယ်။ အဲဒါနဲ့ပဲ လုပ်ဖြစ်သွားတယ် ဆိုပါစို့။
ဖွဘုတ် ပွတ်ရင်းနဲ့ Memories မှာ ကိုအိမောင်လုပ်ထားတဲ့ CSS နဲ့ ဆွဲထားတဲ့ မြန်မာနိုင်ငံပုံတက်လာတော့ Flutter မှာလည်း ဆွဲလို့ရသားပဲ ဆိုပြီး စဉ်းစားမိတယ်။ အဲဒါနဲ့ပဲ လုပ်ဖြစ်သွားတယ် ဆိုပါစို့။
ခွဲခြမ်းစိတ်ဖျာကြည့်တဲ့အခါ
အလံကို အဓိက အစိတ်အပိုင်းအနေနဲ့ ကြယ်ရယ်၊ အနောက်က ဝါစိမ်းနီ ၃ တန်းရယ်ဆိုပြီး ခွဲလိုက်လို့ရတယ်။ ကြယ်ကို ခဏထားလိုက်ဦး၊ အနောက်က ၃ ခုတန်းကို အရင်လုပ်ကြည့်ရအောင်။
ရိုးရိုးလေး တွေးလိုက်ရင်တော့ အဲဒီ ၃ ခုတန်းဆိုတာက လေးထောင့်တုံး ၃ ခုပါပဲ။ အဲဒါတွေကို Container နဲ့ သုံးလို့ရပါတယ်။
Container(
color: Colors.yellow, //အဝါ
),
ဒီအတိုင်းဆို Container ရဲ့ အလျားက Screen အပြည့်ယူနေမှာဖြစ်တဲ့ အတွက် သူ့ကို width နဲ့ height သတ်မှတ်လိုက်ပါမယ်။
Container(
color: MMFlagColors().mmYellow, //အဝါ
height: 50,
width: 250,
),
Container(
color: MMFlagColors().mmGreen, //အစိမ်း
height: 50,
width: 250,
),
Container(
color: MMFlagColors().mmRed, //အနီ
height: 50,
width: 250,
),
မြန်မာနိုင်ငံ အလံရဲ့ ဝါစိမ်းနီ ၃ ရောင်က သတ်မှတ်ချက် ရှိတဲ့ အတွက် Wiki မှာ ပြောထားတဲ့ အရောင်တွေ ထည့်လိုက်ပါတယ်။ ဒီမှာ Class အသစ်မဆောက်ပဲ အပေါ်က Container ရဲ့ color: နေရာမှာ တန်းထည့်လို့လည်း ရပါတယ်။
class MMFlagColors {
// According to Wikipedia, Myanmar Flag's colors are as follows.
Color mmYellow = Color(0xffFECB00);
Color mmGreen = Color(0xff34B233);
Color mmRed = Color(0xffEA2839);
}
ကြယ် ဆောက်မယ်
ကြယ် ရေးမယ်ဆိုရင် ကြယ်ပုံဆွဲတာဖြစ်တဲ့အတွက် Custom Clipper ကို သုံးပါမယ်။ Path ရဲ့ lineTo နဲ့ ဘယ်နေရာ ဘယ်နေရာ ဆိုတာကို ပြောပြီး ကျွန်တော်တို့ လိုချင်တဲ့ ပုံစံဖြစ်အောင် ပုံသွင်းလို့ ရပါတယ်။
size.width ဆိုတာ screen ရဲ့ လက်ရှိ အလျား ပါ။ 0.5 နဲ့ မြှောက်လိုက်တော့ တစ်ဝက်တိတိမှာ နေရာစယူပါတယ်။ အဲဒီကနေ စပြီးဆွဲပါတယ်။
class _StarClipper extends CustomClipper<Path> {
@override
Path getClip(Size size) {
final path = Path();
path.lineTo(size.width * 0.5, size.height * 0.175);
path.lineTo(size.width * 0.45, size.height * 0.4);
path.lineTo(size.width * 0.30, size.height * 0.4);
path.lineTo(size.width * 0.425, size.height * 0.55);
path.lineTo(size.width * 0.375, size.height * 0.8);
path.lineTo(size.width * 0.5, size.height * 0.65);
path.lineTo(size.width * 0.625, size.height * 0.8);
path.lineTo(size.width * 0.575, size.height * 0.55);
path.lineTo(size.width * 0.70, size.height * 0.4);
path.lineTo(size.width * 0.55, size.height * 0.4);
path.lineTo(size.width * 0.5, size.height * 0.175);
path.close();
return path;
}
@override
bool shouldReclip(CustomClipper<Path> oldClipper) => false;
}
သူ့ကို ခေါ်သုံးမယ်ဆိုရင်တော့ ClipPath ဆိုတဲ့ Widget မှာ ခေါ်သုံးလို့ရပါတယ်။
ClipPath(
child: Container(
color: Colors.white,
),
clipper: _StarClipper(),
),
နှစ်ခုပြန်ထပ်မယ်
စောစောက Container တွေနဲ့ ကြယ်ကို Stack Widget နဲ့ ထပ်လိုက်တာနဲ့ မြန်မာနိုင်ငံအလံရပါပြီ။
Stack(
children: [
Positioned.fill(
child: Column(
mainAxisSize: MainAxisSize.min,
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Container(
color: MMFlagColors().mmYellow,
height: 50,
width: 250,
),
Container(
color: MMFlagColors().mmGreen,
height: 50,
width: 250,
),
Container(
color: MMFlagColors().mmRed,
height: 50,
width: 250,
),
],
),
),
Positioned.fill(
child: ClipPath(
child: Container(
color: Colors.white,
),
clipper: _StarClipper(),
),
),
],
),
Code အပြည့်အစုံ စမ်းရန်
(ရလဒ်ကို ကြည့်ရှုရန် Run ကို နှိပ်ပါ)
Github Gist မှာလည်း ကြည့်လို့ရပါတယ်။
ကျေးဇူးတင်ပါတယ်။