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);
}
Container ၃ ခုထပ်ထားတဲ့ပုံ

ကြယ် ဆောက်မယ်

ကြယ် ရေးမယ်ဆိုရင် ကြယ်ပုံဆွဲတာဖြစ်တဲ့အတွက် 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 မှာလည်း ကြည့်လို့ရပါတယ်။

ကျေးဇူးတင်ပါတယ်။