Xamarin - ऐप GUI का निर्माण

व्याख्यान दर्शन

TextView Android विजेट का एक बहुत ही महत्वपूर्ण घटक है। यह मुख्य रूप से एंड्रॉइड स्क्रीन पर टेक्स्ट प्रदर्शित करने के लिए उपयोग किया जाता है।

एक टेक्स्टव्यू बनाने के लिए, बस खोलें main.axml और रैखिक लेआउट टैग के बीच निम्न कोड जोड़ें।

<TextView 
   android:text = "Hello I am a text View" 
   android:layout_width = "match_parent" 
   android:layout_height = "wrap_content" 
   android:id = "@+id/textview1" />

बटन

एक बटन एक घटना को ट्रिगर करने के लिए उपयोग किया जाने वाला नियंत्रण है जब इसे क्लिक किया जाता है। आपके अधीनMain.axml फ़ाइल, एक बटन बनाने के लिए निम्न कोड टाइप करें।

<Button 
   android:id = "@+id/MyButton" 
   android:layout_width = "fill_parent" 
   android:layout_height = "wrap_content" 
   android:text = "@string/Hello" />

खुला हुआ Resources\Values\Strings.xml और <संसाधन> टैग के बीच कोड की निम्न पंक्ति टाइप करें।

<string name="Hello">Click Me!</string>

उपरोक्त कोड हमारे द्वारा बनाए गए बटन का मूल्य प्रदान करता है। अगला, हम खोलते हैंMainActivity.csऔर बटन क्लिक होने पर की जाने वाली क्रिया बनाएँ। निम्न कोड टाइप करेंbase.OnCreate (बंडल) विधि।

Button button = FindViewById<Button>(Resource.Id.MyButton); 
button.Click += delegate { button.Text = "You clicked me"; };

जब उपयोगकर्ता बटन पर क्लिक करता है तो उपरोक्त कोड "You Clicked Me" प्रदर्शित करता है।

FindViewById<< -->यह विधि उस दृश्य की आईडी ढूंढती है जिसे पहचाना गया था। यह .axml लेआउट फ़ाइल में आईडी की खोज करता है।

चेक बॉक्स

एक चेकबॉक्स का उपयोग तब किया जाता है जब कोई विकल्प समूह से एक से अधिक विकल्प चुनना चाहता है। इस उदाहरण में, हम एक चेकबॉक्स बनाने जा रहे हैं, जो चयनित होने पर, एक संदेश प्रदर्शित करता है कि इसे चेक किया गया है, अन्यथा यह अनियंत्रित प्रदर्शित करता है।

शुरू करने के लिए, हम खोलते हैं Main.axml हमारे प्रोजेक्ट में फ़ाइल करें और चेकबॉक्स बनाने के लिए कोड की निम्न पंक्ति टाइप करें।

<?xml version = "1.0" encoding = "utf-8"?> 
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android" 
   android:orientation = "vertical" 
   android:background = "#d3d3d3" 
   android:layout_width = "fill_parent" 
   android:layout_height = "fill_parent"> 
   <CheckBox 
      android:text = "CheckBox" 
      android:padding = "25dp" 
      android:layout_width = "300dp" 
      android:layout_height = "wrap_content" 
      android:id = "@+id/checkBox1" 
      android:textColor = "@android:color/black" 
      android:background = "@android:color/holo_blue_dark" /> 
</LinearLayout>

अगला, करने के लिए जाओ MainActivity.cs कार्यक्षमता कोड जोड़ने के लिए।

CheckBox checkMe = FindViewById<CheckBox>(Resource.Id.checkBox1); 
checkMe.CheckedChange += (object sender, CompoundButton.CheckedChangeEventArgs e) => { 
   CheckBox check = (CheckBox)sender; 
   if(check.Checked) { 
      check.Text = "Checkbox has been checked"; 
   } else { 
      check.Text = "Checkbox has not been checked"; 
   } 
};

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

CompoundButton.CheckedChangeEventArgs → चेकबॉक्स स्थिति में परिवर्तन होने पर यह विधि किसी ईवेंट को आग लगा देती है।

प्रगति पट्टी

एक प्रगति पट्टी एक नियंत्रण है जिसका उपयोग किसी ऑपरेशन की प्रगति को दिखाने के लिए किया जाता है। एक प्रगति पट्टी जोड़ने के लिए, कोड की निम्नलिखित पंक्ति जोड़ेंMain.axml फ़ाइल।

<ProgressBar 
   style="?android:attr/progressBarStyleHorizontal" 
   android:layout_width = "match_parent" 
   android:layout_height = "wrap_content" 
   android:id = "@+id/progressBar1" />

अगला, करने के लिए जाओ MainActivity.cs और प्रगति बार का मान सेट करें।

ProgressBar pb = FindViewById<ProgressBar>(Resource.Id.progressBar1); 
pb.Progress = 35;

उपरोक्त कोड में, हमने 35 के मान के साथ एक प्रगति बार बनाया है।

रेडियो के बटन

यह एक एंड्रॉइड विजेट है जो एक व्यक्ति को विकल्पों में से एक को चुनने की अनुमति देता है। इस खंड में, हम एक रेडियो समूह बनाने जा रहे हैं जिसमें कारों की एक सूची है जो एक जाँच किए गए रेडियो बटन को पुनः प्राप्त करेगा।

सबसे पहले, हम एक रेडियो समूह और एक जोड़ते हैं textview जैसा कि निम्नलिखित कोड में दिखाया गया है -

<?xml version = "1.0" encoding = "utf-8"?> 
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android" 
   android:orientation = "vertical" 
   android:background = "@android:color/darker_gray" 
   android:layout_width = "fill_parent" 
   android:layout_height = "fill_parent"> 
   <TextView 
      android:text = "What is your favourite Car" 
      android:layout_width = "match_parent" 
      android:layout_height = "wrap_content" 
      android:id = "@+id/textView1" 
      android:textColor = "@android:color/black" /> 
   <RadioGroup 
      android:layout_width = "match_parent" 
      android:layout_height = "wrap_content" 
      android:id = "@+id/radioGroup1" 
      android:backgroundTint = "#a52a2aff" 
      android:background = "@android:color/holo_green_dark"> 
   <RadioButton 
      android:layout_width = "wrap_content" 
      android:layout_height = "wrap_content" 
      android:text = "Ferrari" 
      android:id = "@+id/radioFerrari" /> 
   <RadioButton 
      android:layout_width = "wrap_content" 
      android:layout_height = "wrap_content" 
      android:text = "Mercedes" 
      android:id = "@+id/radioMercedes" /> 
   <RadioButton 
      android:layout_width = "wrap_content" 
      android:layout_height = "wrap_content" 
      android:text = "Lamborghini" 
      android:id = "@+id/radioLamborghini" />
   <RadioButton 
      android:text = "Audi" 
      android:layout_width = "match_parent" 
      android:layout_height = "wrap_content" 
      android:id = "@+id/radioAudi" /> 
   </RadioGroup> 
</LinearLayout>

एक क्रिया करने के लिए, जब एक रेडियो बटन पर क्लिक किया जाता है, तो हम एक गतिविधि जोड़ते हैं। के लिए जाओMainActivity.cs और नीचे दिखाए गए अनुसार एक नया ईवेंट हैंडलर बनाएं।

private void onClickRadioButton(object sender, EventArgs e) { 
   RadioButton cars = (RadioButton)sender; 
   Toast.MakeText(this, cars.Text, ToastLength.Short).Show 
   (); 
}

Toast.MakeText() →यह एक दृश्य विधि है जिसका उपयोग किसी छोटे पॉप अप में संदेश / आउटपुट प्रदर्शित करने के लिए किया जाता है। के निचले भाग परOnCreate() विधि बस के बाद SetContentView(), कोड का निम्नलिखित टुकड़ा जोड़ें। यह प्रत्येक रेडियो बटन को कैप्चर करेगा और हमारे द्वारा बनाए गए ईवेंट हैंडलर में जोड़ देगा।

RadioButton radio_Ferrari = FindViewById<RadioButton> 
   (Resource.Id.radioFerrari); 
   RadioButton radio_Mercedes = FindViewById<RadioButton> 
   (Resource.Id.radioMercedes); 
   RadioButton radio_Lambo = FindViewById<RadioButton> 
   (Resource.Id.radioLamborghini); 
   RadioButton radio_Audi = FindViewById<RadioButton> 
   (Resource.Id.radioAudi); 
   radio_Ferrari.Click += onClickRadioButton; 
   radio_Mercedes.Click += onClickRadioButton; 
   radio_Lambo.Click += onClickRadioButton; 
   radio_Audi.Click += onClickRadioButton;

अब, अपना एप्लिकेशन चलाएं। इसे निम्न स्क्रीन को आउटपुट के रूप में प्रदर्शित करना चाहिए -

बटन टॉगल करें

टॉगल बटन का उपयोग दो राज्यों के बीच वैकल्पिक करने के लिए किया जाता है, उदाहरण के लिए, यह ओन और ऑफ के बीच टॉगल कर सकता है। खुला हुआResources\layout\Main.axml और टॉगल बटन बनाने के लिए कोड की निम्नलिखित पंक्तियों को जोड़ें।

<?xml version = "1.0" encoding = "utf-8"?> 
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android" 
   android:orientation = "vertical" 
   android:background = "#d3d3d3" 
   android:layout_width = "fill_parent" 
   android:layout_height = "fill_parent"> 
   <ToggleButton 
      android:id = "@+id/togglebutton" 
      android:layout_width = "wrap_content" 
      android:layout_height = "wrap_content" 
      android:textOn = "Torch ON" 
      android:textOff = "Torch OFF" 
      android:textColor = "@android:color/black" /> 
</LinearLayout>

क्लिक होने पर हम टॉगल बार में क्रिया जोड़ सकते हैं। खुला हुआMainActivity.cs और कोड की निम्न पंक्तियों को जोड़ने के बाद OnCreate() विधि वर्ग।

ToggleButton togglebutton = FindViewById<ToggleButton> (Resource.Id.togglebutton); 
togglebutton.Click += (o, e) => { 
   if (togglebutton.Checked) 
      Toast.MakeText(this, "Torch is ON", ToastLength.Short).Show (); 
   else 
      Toast.MakeText(this, "Torch is OFF", 
      ToastLength.Short).Show(); 
};

अब, जब आप ऐप चलाते हैं, तो इसे निम्न आउटपुट प्रदर्शित करना चाहिए -

रेटिंग बार

एक रेटिंग बार एक फार्म तत्व है जो सितारों से बना होता है जो ऐप उपयोगकर्ता उन चीजों का उपयोग कर सकते हैं जो आपने उनके लिए प्रदान की हैं। अपने मेंMain.axml फ़ाइल, 5 सितारों के साथ एक नया रेटिंग बार बनाएं।

<?xml version = "1.0" encoding = "utf-8"?> 
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android" 
   android:orientation = "vertical" 
   android:background = "#d3d3d3" 
   android:layout_width = "fill_parent" 
   android:layout_height = "fill_parent"> 
   <RatingBar 
      android:layout_width = "wrap_content" 
      android:layout_height = "wrap_content" 
      android:id = "@+id/ratingBar1" 
      android:numStars = "5" 
      android:stepSize = "1.0" /> 
</LinearLayout>

एप्लिकेशन को चलाने पर, इसे निम्न आउटपुट प्रदर्शित करना चाहिए -

स्वतः पूर्ण पाठ

यह एक टेक्स्टव्यू है जो उपयोगकर्ता को टाइप करते समय पूर्ण सुझाव दिखाता है। हम लोगों के नामों की एक सूची और एक बटन पर एक स्वत: पूर्ण पाठ बनाने जा रहे हैं, जिस पर क्लिक करने पर हमें चयनित नाम दिखाई देगा।

खुला हुआ Main.axml और निम्नलिखित कोड लिखें।

<?xml version = "1.0" encoding = "utf-8"?> 
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android" 
   android:orientation = "vertical" 
   android:layout_width = "fill_parent" 
   android:background = "#d3d3d3" 
   android:layout_height = "fill_parent"> 
   <TextView 
      android:text = "Enter Name" 
      android:textAppearance = "?android:attr/textAppearanceMedium" 
      android:layout_width = "fill_parent" 
      android:layout_height = "wrap_content" 
      android:id = "@+id/textView1" 
      android:padding = "5dp" 
      android:textColor = "@android:color/black" /> 
   <AutoCompleteTextView 
      android:layout_width = "fill_parent" 
      android:layout_height = "wrap_content" 
      android:id = "@+id/autoComplete1" 
      android:textColor = "@android:color/black" /> 
   <Button 
      android:text = "Submit" 
      android:layout_width = "fill_parent" 
      android:layout_height = "wrap_content" 
      android:id = "@+id/btn_Submit" 
      android:background="@android:color/holo_green_dark" /> 
</LinearLayout>

उपर्युक्त कोड टाइप करने के लिए एक TextView बनाता है, AutoCompleteTextViewसुझाव दिखाने के लिए, और TextView से दर्ज नामों को प्रदर्शित करने के लिए एक बटन। के लिए जाओMainActivity.cs कार्यक्षमता जोड़ने के लिए।

एक नया ईवेंट हैंडलर विधि बनाएं जैसा कि नीचे दिखाया गया है।

protected void ClickedBtnSubmit(object sender, System.EventArgs e){ 
   if (autoComplete1.Text != ""){ 
      Toast.MakeText(this, "The Name Entered =" 
         + autoComplete1.Text, ToastLength.Short).Show(); 
   } else { 
      Toast.MakeText(this, "Enter a Name!", ToastLength.Short).Show(); 
   } 
}

बनाया गया हैंडलर यह जाँचता है कि स्वतः पूर्ण पाठ खाली है या नहीं। यदि यह खाली नहीं है, तो यह चयनित स्वतः पूर्ण पाठ प्रदर्शित करता है। के अंदर निम्न कोड टाइप करेंOnCreate() कक्षा।

autoComplete1 = FindViewById<AutoCompleteTextView>(Resource.Id.autoComplete1); 
btn_Submit = FindViewById<Button>(Resource.Id.btn_Submit);  
var names = new string[] { "John", "Peter", "Jane", "Britney" }; 
ArrayAdapter adapter = new ArrayAdapter<string>(this,           
   Android.Resource.Layout.SimpleSpinnerItem, names); 
autoComplete1.Adapter = adapter; 
btn_Submit.Click += ClickedBtnSubmit;

ArrayAdapter - यह एक संग्रह हैंडलर है जो एक सूची संग्रह से डेटा आइटम पढ़ता है और उन्हें एक दृश्य के रूप में वापस करता है या उन्हें स्क्रीन पर प्रदर्शित करता है।

अब, जब आप एप्लिकेशन चलाते हैं, तो उसे निम्न आउटपुट प्रदर्शित करना चाहिए।