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 - यह एक संग्रह हैंडलर है जो एक सूची संग्रह से डेटा आइटम पढ़ता है और उन्हें एक दृश्य के रूप में वापस करता है या उन्हें स्क्रीन पर प्रदर्शित करता है।
अब, जब आप एप्लिकेशन चलाते हैं, तो उसे निम्न आउटपुट प्रदर्शित करना चाहिए।