ज़मारिन - त्वरित गाइड
Xamarin .NET फ्रेमवर्क पर बनाया गया है। यह उन ऐप्स को बनाने की अनुमति देता है जो आसानी से कई प्लेटफार्मों में चलते हैं। इस ट्यूटोरियल में, हम बताएंगे कि आप देशी आईओएस, एंड्रॉइड और विंडोज ऐप्स देने के लिए ज़मरीन का उपयोग कैसे कर सकते हैं।
आइए ट्यूटोरियल को विंडोज और मैक सिस्टम में Xamarin स्थापित करने के तरीके पर चर्चा के साथ शुरू करें।
सिस्टम आवश्यकताएं
खिड़कियाँ
कम से कम 2GB RAM और विंडोज 7 या उच्चतर चलाने वाला कंप्यूटर (Windows 8-10 अत्यधिक अनुशंसित है)
विजुअल स्टूडियो 2012 व्यावसायिक या उच्चतर
विजुअल स्टूडियो के लिए ज़ामरीन
मैक
- OS X Yosemite (10.10) या उच्चतर चलने वाला एक मैक कंप्यूटर
- Xamarin iOS SDK
- Apple का Xcode (7+) IDE और iOS SDK
- ज़मीरिन स्टूडियो
विंडोज पर स्थापना
से Xamarin इंस्टॉलर डाउनलोड करें https://www.xamarin.com/download ज़मारिन इंस्टॉलर चलाने से पहले, सुनिश्चित करें कि आपने अपने कंप्यूटर पर एंड्रॉइड एसडीके और जावा एसडीके स्थापित किया है।
इंस्टॉलेशन प्रक्रिया शुरू करने के लिए डाउनलोड किए गए इंस्टॉलर को चलाएं -
Xamarin लाइसेंस अनुबंध स्क्रीन दिखाई देती है। दबाएंNext बटन समझौते को स्वीकार करने के लिए।
इंस्टॉलर किसी भी लापता घटकों की खोज करेगा और आपको उन्हें डाउनलोड और इंस्टॉल करने के लिए संकेत देगा।
Xamarin स्थापना पूर्ण होने के बाद, पर क्लिक करें Close Xamarin का उपयोग करने के लिए बाहर निकलने और तैयार होने के लिए बटन।
मैक पर स्थापना
अपने मैक सिस्टम पर Xamarin स्टूडियो इंस्टॉलर डाउनलोड करें।
आपके द्वारा डाउनलोड किए गए Xamarin इंस्टॉलर को चलाएं और इंस्टॉलेशन विज़ार्ड में दिए गए चरणों का पालन करें।
स्थापना पूर्ण होने के बाद, आप अपने सिस्टम पर Xamarin का उपयोग शुरू कर सकते हैं।
इस अध्याय में, हम देखेंगे कि ज़मरीन का उपयोग करके एक छोटा एंड्रॉइड एप्लिकेशन कैसे बनाया जाए।
हैलो ज़मीर! आवेदन
सबसे पहले, Visual Studio का एक नया उदाहरण प्रारंभ करें और उस पर जाएँ File → New → Project।
दिखाई देने वाले मेनू संवाद बॉक्स पर, पर जाएँ Templates → Visual C# → Android → Blank App (Android)।
अपने आवेदन के लिए एक उपयुक्त नाम दें। हमारे मामले में, हम इसे नाम देते हैं“helloWorld”और दिए गए डिफ़ॉल्ट स्थान में इसे सहेजें। इसके बाद, नए के लिए ओके बटन पर क्लिक करें“helloXamarin” लोड करने के लिए परियोजना।
पर solution, खुला हुआ Resources → layout → Main.axmlफ़ाइल। डिज़ाइन दृश्य से स्विच करें और पर जाएंSource फ़ाइल और अपने एप्लिकेशन का निर्माण करने के लिए कोड की निम्न पंक्तियाँ टाइप करें
<?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">
<TextView
android:text = "@string/HelloXamarin"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView2"
android:textColor = "@android:color/black" />
</LinearLayout>
उपरोक्त कोड में, हमने एक नया एंड्रॉइड बनाया है textview। इसके बाद, फ़ोल्डर मान खोलें और डबल-क्लिक करेंStrings.xmlइसे खोलने के लिए। यहां, हम इसके बारे में जानकारी और मूल्यों को संग्रहीत करने जा रहे हैंbutton ऊपर बनाया गया।
<?xml version = "1.0" encoding = "utf-8"?>
<resources>
<string name = "HelloXamarin">Hello World, I am Xamarin!</string>
<string name = "ApplicationName">helloWorld</string>
</resources>
खुला हुआ MainActivity.cs फ़ाइल और कोड की निम्न पंक्तियों के साथ मौजूदा कोड को बदलें।
using System;
using Android.App;
using Android.Content;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;
namespace HelloXamarin {
public class MainActivity : Activity {
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
}
}
}
एप्लिकेशन को सहेजें। निर्मित करें और फिर इसे एंड्रॉइड एमुलेटर में बनाए गए एप्लिकेशन को प्रदर्शित करने के लिए चलाएं।
यदि आपके पास एंड्रॉइड एमुलेटर नहीं है, तो एक बनाने के लिए अगले अनुभाग में दिए गए चरणों का पालन करें।
Android एमुलेटर सेट करना
अपने Visual Studio मेनू पर, पर जाएँ Tools → Android → Android Emulator Manager। दिखाई देने वाली पॉप-अप विंडो पर, क्लिक करेंCreateबटन। यह निम्न स्क्रीन प्रदर्शित करेगा।
उपरोक्त स्क्रीन पर, आपूर्ति करें AVD nameतुम्हें चाहिए। एक चयन करेंdeviceआपके प्रदर्शन के लिए उपयुक्त है, उदाहरण के लिए, Nexus 4 ”प्रदर्शन। अपना चुनेtarget platform। हमेशा एक न्यूनतम लक्ष्य प्लेटफ़ॉर्म पर परीक्षण करने की सलाह दी जाती है, उदाहरण के लिए, एपीआई 10 एंड्रॉइड 2.3 (जिंजरब्रेड) ताकि आपके ऐप को सभी एंड्रॉइड प्लेटफॉर्म पर काम करना सुनिश्चित हो सके।
बाकी फ़ील्ड भरें और ओके बटन पर क्लिक करें। अब आपका एमुलेटर तैयार है। आप इसे मौजूदा एंड्रॉइड वर्चुअल डिवाइस की सूची से चुन सकते हैं और फिर क्लिक कर सकते हैंStart इसे लॉन्च करने के लिए।
HelloXamarin ऐप को संशोधित करना
इस खंड में, हम अपनी परियोजना को संशोधित करेंगे और एक बटन बनाएंगे, जो क्लिक करने पर पाठ प्रदर्शित करेगा। खुला हुआmain.axml और पर स्विच करें source view। हमारे बादtextview हमने बनाया, हम नीचे दिखाए गए अनुसार एक बटन जोड़ देंगे।
<Button
android:id = "@+id/MyButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "@string/ButtonClick" />
एक बटन जोड़ने के बाद, हमारा पूरा कोड इस तरह दिखेगा -
<?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:layout_height = "fill_parent">
<TextView
android:text = "@string/HelloXamarin"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView2" />
<Button
android:id = "@+id/MyButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "@string/ButtonClick" />
</LinearLayout>
इसके बाद, हम अपने बटन मूल्यों को रजिस्टर करते हैं strings.xml फ़ाइल।
<string name = "ButtonClick">Click Me!</string>
हमारे बटन को जोड़ने के बाद strings.xml फ़ाइल, हम खुलेंगे MainActivity.cs जब यह क्लिक किया जाता है तो हमारे बटन के लिए एक क्रिया जोड़ने के लिए फ़ाइल, जैसा कि निम्नलिखित कोड में दिखाया गया है।
using System;
using Android.App;
using Android.Content;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;
namespace HelloXamarin {
[Activity(Label = "HelloXamarin", MainLauncher = true, Icon = "@drawable/icon")]
public class MainActivity : Activity {
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
Button button = FindViewById<Button>(Resource.Id.MyButton);
button.Click += delegate { button.Text = "Hello world I am your first App"; };
}
}
}
इसके बाद, अपना एप्लिकेशन बनाएं और चलाएं।
बटन पर क्लिक करने के बाद, आपको निम्न आउटपुट मिलेगा -
सभी Android Apps में एक है manifest file सामान्यतः कहा जाता है AndroidManifest.xml। मैनिफ़ेस्ट फ़ाइल में Android प्लेटफ़ॉर्म के बारे में वह सब कुछ है जो एक ऐप को सफलतापूर्वक चलाने के लिए चाहिए।
यहाँ, हमने मेनिफ़ेस्ट फ़ाइल के कुछ महत्वपूर्ण कार्यों को सूचीबद्ध किया है -
यह घोषणा करता है minimum API level आवेदन के लिए आवश्यक है।
यह एप्लिकेशन द्वारा आवश्यक अनुमतियों की घोषणा करता है, जैसे, कैमरा, स्थान, आदि।
यह उपयोग किए गए हार्डवेयर या सॉफ़्टवेयर सुविधाओं की अनुमति देता है या अनुप्रयोग द्वारा आवश्यक है।
यह उन पुस्तकालयों को सूचीबद्ध करता है जो आवेदन से जुड़े होने चाहिए।
निम्न स्क्रीनशॉट एक मैनिफेस्ट फ़ाइल दिखाता है।
Application name - यह आपके ऐप के शीर्षक को संदर्भित करता है
Package name - यह एक अद्वितीय नाम है जिसका उपयोग आपके ऐप की पहचान करने के लिए किया जाता है।
Application Icon - यह आपके ऐप के लिए एंड्रॉइड होम स्क्रीन पर प्रदर्शित आइकन है।
Version Number - यह एक एकल संख्या है जिसका उपयोग आपके ऐप के एक संस्करण को दिखाने के लिए किया जाता है, दूसरे की तुलना में अधिक हाल का है।
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
android:versionCode="1" >
Version Name- यह आपके ऐप के लिए एक उपयोगकर्ता के अनुकूल संस्करण स्ट्रिंग है जो उपयोगकर्ता आपकी ऐप सेटिंग्स और Google PlayStore पर देखेंगे। निम्न कोड संस्करण नाम का एक उदाहरण दिखाता है।
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
android:versionName="1.0.0">
Minimum Android Version - यह सबसे कम एंड्रॉइड वर्जन प्लेटफॉर्म है जो आपके एप्लिकेशन को सपोर्ट करता है।
<uses-sdk android:minSdkVersion="16" />
उपरोक्त उदाहरण में, हमारा न्यूनतम एंड्रॉइड संस्करण एपीआई स्तर 16 है, जिसे सामान्यतः कहा जाता है JELLY BEAN।
Target Android Version - यह एंड्रॉइड वर्जन है जिस पर आपका ऐप संकलित है।
जब एक नया एंड्रॉइड प्रोजेक्ट बनाया जाता है, तो कुछ फाइलें होती हैं जो प्रोजेक्ट में डिफ़ॉल्ट रूप से जुड़ जाती हैं। हम इन डिफ़ॉल्ट प्रोजेक्ट फ़ाइलों और फ़ोल्डरों को कॉल करते हैंAndroid Resources। निम्नलिखित स्क्रीनशॉट पर एक नज़र डालें।
डिफ़ॉल्ट Android संसाधनों में निम्नलिखित शामिल हैं -
AndroidManifest.xml file - इसमें आपके एंड्रॉइड एप्लिकेशन, जैसे, एप्लिकेशन का नाम, अनुमतियां आदि की जानकारी होती है।
Resources folder - संसाधन चित्र, लेआउट, स्ट्रिंग्स आदि हो सकते हैं जिन्हें एंड्रॉइड के संसाधन सिस्टम के माध्यम से लोड किया जा सकता है।
Resources/drawable folder - यह उन सभी छवियों को संग्रहीत करता है जिन्हें आप अपने एप्लिकेशन में उपयोग करने जा रहे हैं।
Resources/layout folder - इसमें सभी एंड्रॉइड XML फाइलें (.axml) शामिल हैं जो एंड्रॉइड उपयोगकर्ता इंटरफेस बनाने के लिए उपयोग करता है।
The Resources/values folder- इसमें एक अनुप्रयोग के दौरान स्ट्रिंग्स (और अन्य प्रकार) के लिए कुंजी-मूल्य जोड़े घोषित करने के लिए XML फाइलें होती हैं। यह सामान्य रूप से एंड्रॉइड पर कई भाषाओं के लिए स्थानीयकरण है।
Resources.designer.cs - यह फ़ाइल स्वचालित रूप से बनाई जाती है जब एंड्रॉइड प्रोजेक्ट किया जाता है और इसमें अद्वितीय पहचानकर्ता होते हैं जो एंड्रॉइड संसाधनों का संदर्भ देते हैं।
MainActivity.cs file - यह आपके एंड्रॉइड एप्लिकेशन की पहली गतिविधि है और जहां से मुख्य एप्लिकेशन एक्शन लॉन्च किए गए हैं।
संसाधन फ़ाइलों को प्रोग्राम के माध्यम से एक्सेस किया जा सकता है unique ID जो में संग्रहित है resources.designer.csफ़ाइल। आईडी नामक एक वर्ग के तहत निहित हैResource। परियोजना में जोड़ा गया कोई भी संसाधन स्वचालित रूप से अंदर उत्पन्न होता हैresource class।
निम्न कोड दिखाता है कि सात छवियों वाले ग्रिडव्यू प्रोजेक्ट कैसे बनाएं -
namespace HelloGridView {
[System.CodeDom.Compiler.GeneratedCodeAttribute
("Xamarin.Android.Build.Tas ks",
"1.0.0.0")]
public partial class Resource {
static Resource() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
public static void UpdateIdValues() {}
public partial class Attribute {
static Attribute() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private Attribute() {}
}
public partial class Drawable {
// aapt resource value: 0x7f020000
public const int Icon = 2130837504;
// aapt resource value: 0x7f020001
public const int img1 = 2130837505;
// aapt resource value: 0x7f020002
public const int img2 = 2130837506;
// aapt resource value: 0x7f020003
public const int img3 = 2130837507;
// aapt resource value: 0x7f020004
public const int img4 = 2130837508;
// aapt resource value: 0x7f020005
public const int img5 = 2130837509;
// aapt resource value: 0x7f020006
public const int img6 = 2130837510;
// aapt resource value: 0x7f020007
public const int img7 = 2130837511;
static Drawable() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private Drawable() {}
}
public partial class Id {
// aapt resource value: 0x7f050000
public const int gridview = 2131034112;
static Id() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private Id() {}
}
public partial class Layout {
// aapt resource value: 0x7f030000
public const int Main = 2130903040;
static Layout() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private Layout() {}
}
public partial class String {
// aapt resource value: 0x7f040001
public const int ApplicationName = 2130968577;
// aapt resource value: 0x7f040000
public const int Hello = 2130968576;
static String() {
global::Android.Runtime.ResourceIdManager.UpdateIdValues();
}
private String() {}
}
}
}
उपरोक्त कोड से, सात छवियों को एक कक्षा में संदर्भित किया जाता है drawable। इन छवियों को प्रोग्रामेटिक रूप से जोड़ा जाता है। यदि कोई उपयोगकर्ता प्रोजेक्ट में कोई अन्य छवि जोड़ता है, तो उसे भी जोड़ा जाएगाdrawableकक्षा। gridviewपरियोजना में निहित भी जोड़ा और अपने दम पर एक वर्ग में संग्रहीत किया जाता है। प्रत्येक आइटम में निहित हैresources folder स्वचालित रूप से उत्पन्न होता है और एक कक्षा में संग्रहीत होता है।
जब कोई उपयोगकर्ता एंड्रॉइड ऐप के माध्यम से नेविगेट करता है, तो घटनाओं की एक श्रृंखला होती है। उदाहरण के लिए, जब कोई उपयोगकर्ता किसी ऐप को लॉन्च करता है, उदाहरण के लिए, फेसबुक ऐप, यह शुरू होता है और उपयोगकर्ता के लिए अग्रभूमि पर दिखाई देता है,onCreate() → onStart() → onResume()।
यदि कोई अन्य गतिविधि शुरू होती है, उदाहरण के लिए, एक फोन कॉल आता है, तो फेसबुक ऐप पृष्ठभूमि पर जाएगा और कॉल अग्रभूमि में आती है। अब हमारे पास दो प्रक्रियाएं चल रही हैं।
onPause() --- > onStop()
जब फोन कॉल समाप्त होता है, तो फेसबुक ऐप अग्रभूमि में वापस आ जाता है। तीन विधियाँ कही जाती हैं।
onRestart() --- > onStart() --- > onResume()
एक Android गतिविधि में 7 जीवनचक्र प्रक्रियाएं हैं। वे शामिल हैं -
onCreate - यह तब कहा जाता है जब गतिविधि पहली बार बनाई जाती है।
onStart - यह तब कहा जाता है जब गतिविधि शुरू होती है और उपयोगकर्ता को दिखाई देती है।
onResume- यह तब कहा जाता है जब गतिविधि उपयोगकर्ता के साथ बातचीत करना शुरू करती है। उपयोगकर्ता इनपुट इस स्तर पर होता है।
onPause - यह तब कहा जाता है जब गतिविधि पृष्ठभूमि में चलती है लेकिन अभी तक नहीं मारा गया है।
onStop - यह तब कहा जाता है जब गतिविधि उपयोगकर्ता को दिखाई नहीं देती है।
onRestart- फिर से शुरू करने से पहले, गतिविधि बंद हो जाने के बाद इसे बुलाया जाता है। इसे आम तौर पर तब कहा जाता है जब उपयोगकर्ता पिछली गतिविधि पर वापस जाता है जिसे रोक दिया गया था।
onDestroy - मेमोरी से गतिविधि को हटाने से पहले यह अंतिम कॉल है।
निम्नलिखित चित्रण Android गतिविधि जीवनचक्र दिखाता है -
एंड्रॉइड में, डिफ़ॉल्ट रूप से, किसी भी एप्लिकेशन को किसी भी ऑपरेशन को करने की अनुमति नहीं है जिसका उपयोगकर्ता या ऑपरेटिंग सिस्टम पर प्रभाव होगा। किसी कार्य को करने के लिए ऐप के लिए अनुमतियों की घोषणा करनी चाहिए। एंड्रॉइड सिस्टम द्वारा अनुमति दिए जाने तक ऐप कार्य नहीं कर सकता है। अनुमतियों का यह तंत्र अनुप्रयोगों को उपयोगकर्ता की सहमति के बिना इच्छानुसार करने से रोकता है।
में दर्ज किए जाने हैं AndroidManifest.xmlफ़ाइल। अनुमतियां जोड़ने के लिए, हम संपत्तियों पर डबल-क्लिक करते हैं, फिर Android मैन पर जाते हैंRequired permissionsदिखाई देगा। उन उपयुक्त अनुमतियों की जाँच करें जिन्हें आप जोड़ना चाहते हैं।
Camera - यह डिवाइस के कैमरे तक पहुंचने की अनुमति प्रदान करता है।
<uses-permission android:name="android.permission.CAMERA" />
Internet - यह नेटवर्क संसाधनों तक पहुंच प्रदान करता है।
<uses-permission android:name="android.permission.INTERNET" />
ReadContacts - यह आपके डिवाइस पर संपर्कों को पढ़ने के लिए पहुँच प्रदान करता है।
<uses-permission android:name="android.permission.READ_CONTACTS" />
ReadExternalStorage - यह बाहरी संग्रहण पर डेटा को पढ़ने और संग्रहीत करने के लिए पहुँच प्रदान करता है।
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
Calendars- यह उपयोगकर्ता डिवाइस और घटनाओं पर कैलेंडर के लिए एक ऐप का उपयोग करने की अनुमति देता है। यह अनुमति खतरनाक हो सकती है, क्योंकि यह एक ऐप को मालिक की जागरूकता के बिना मेहमानों को ईमेल भेजने की क्षमता देता है। इस अनुमति को जोड़ने का सिंटैक्स इस प्रकार है -
<uses-permission android:name="android.permission-group.CALENADAR" />
SMS- इस अनुमति वाले ऐप में मैसेजिंग सेवाओं के उपकरणों का उपयोग करने की क्षमता है। इसमें पढ़ना, लिखना और एसएमएस और एमएमएस संदेशों को संपादित करना शामिल है। इसका सिंटैक्स नीचे दिखाया गया है।
<uses-permission android:name="android.permission-group.SMS" />
Location - इस अनुमति वाला ऐप GPS नेटवर्क का उपयोग करके डिवाइस के स्थान तक पहुंच सकता है।
<uses-permission android:name="android.permission-group.LOCATION" />
Bluetooth - इस अनुमति वाला एक ऐप वायरलेस तरीके से अन्य ब्लूटूथ सक्षम डिवाइसों के साथ डेटा फ़ाइलों का आदान-प्रदान कर सकता है।
<uses-permission android:name="android.permission.BLUETOOTH" />
व्याख्यान दर्शन
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"; };
जब उपयोगकर्ता बटन पर क्लिक करता है तो उपरोक्त कोड "यू क्लिकेड मी" प्रदर्शित करता है।
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 - यह एक संग्रह हैंडलर है जो एक सूची संग्रह से डेटा आइटम पढ़ता है और उन्हें एक दृश्य के रूप में वापस करता है या उन्हें स्क्रीन पर प्रदर्शित करता है।
अब, जब आप एप्लिकेशन चलाते हैं, तो उसे निम्न आउटपुट प्रदर्शित करना चाहिए।
पॉपअप मेनू
पॉपअप मेनू एक मेनू को संदर्भित करता है जो एक दृश्य से जुड़ा होता है; यह भी एक के रूप में जाना जाता हैshortcut menu। आइए देखें कि एंड्रॉइड ऐप में पॉपअप मेनू कैसे जोड़ें।
एक नया प्रोजेक्ट बनाएं और उसे कॉल करें popUpMenu App। खुला हुआ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">
<Button
android:id = "@+id/popupButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "Show popup menu"
android:background = "@android:color/holo_green_dark"
android:textColor = "@android:color/black" />
</LinearLayout>
के तहत एक नया फ़ोल्डर बनाएँ Resources फ़ोल्डर और इसे कॉल करें Menu। मेनू फ़ोल्डर के अंदर, एक नई xml फ़ाइल जोड़ेंpopMenu.xml।
के अंतर्गत popMenu.xml, निम्न मेनू आइटम जोड़ें।
<?xml version = "1.0" encoding="utf-8"?>
<menu xmlns:android = "http://schemas.android.com/apk/res/android">
<item
android:id = "@+id/file_settings"
android:icon = "@drawable/img_settings"
android:title = "Settings"
android:showAsAction = "ifRoom">
<item
android:id = "@+id/new_game1"
android:icon = "@drawable/imgNew"
android:title = "New File Settings"/>
<item
android:id = "@+id/help"
android:icon = "@drawable/img_help"
android:title = "Help" />
<item
android:id = "@+id/about_app"
android:icon = "@drawable/img_help"
android:title = "About app"/>
</item>
</menu>
मेनू आइटम जोड़ने के बाद, पर जाएं mainActivity.cs बटन क्लिक पर पॉपअप मेनू प्रदर्शित करने के लिए।
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
Button showPopupMenu = FindViewById<Button>(Resource.Id.popupButton);
showPopupMenu.Click += (s, arg) => {
PopupMenu menu = new PopupMenu(this, showPopupMenu);
menu.Inflate(Resource.Menu.popMenu);
menu.Show();
};
}
अब, अपना एप्लिकेशन बनाएं और चलाएं। यह निम्नलिखित उत्पादन का उत्पादन करना चाहिए -
विकल्प मेनू
विकल्प मेनू उन मेनू का एक संग्रह है जो एक ऐप में प्राथमिक हैं और मुख्य रूप से सेटिंग्स, खोज आदि को संग्रहीत करने के लिए उपयोग किए जाते हैं। यहां, हम अंदर तीन आइटमों के साथ सेटिंग्स के लिए एक मेनू बनाने जा रहे हैं, अर्थात। New File Settings, Help, and About App।
एक विकल्प मेनू बनाने के लिए, हमें संसाधन फ़ोल्डर में एक नई XML लेआउट फ़ाइल बनानी होगी। सबसे पहले, हम एक नई XML फ़ाइल जोड़ेंगे। पर राइट क्लिक करेंLayout folder, फिर जाएं Add → New item → Visual C# → XML File।
के लिए एक उपयुक्त नाम चुनें layout file। हमारे उदाहरण में, हम अपनी फ़ाइल को कॉल करेंगेmyMenu.xml।
के भीतर myMenu.xml, हम एक नया मेनू बनाने और अंदर आइटम जोड़ने जा रहे हैं। निम्न कोड दिखाता है कि यह कैसे करना है।
<?xml version = "1.0" encoding = "utf-8"?>
<menu xmlns:android = "http://schemas.android.com/apk/res/android">
<item
android:id = "@+id/file_settings"
android:icon = "@drawable/img_settings"
android:title = "Settings"
android:showAsAction = "ifRoom">
<menu>
<item
android:id = "@+id/new_game1"
android:icon = "@drawable/imgNew"
android:title = "New File Settings" />
<item
android:id = "@+id/help"
android:icon = "@drawable/img_help"
android:title = "Help" />
<item
android:id = "@+id/about_app"
android:icon = "@drawable/img_help"
android:title = "About app"/>
</menu>
</item>
</menu>
अगला, हम में नेविगेट करते हैं MainActivity.cs और के लिए एक ओवरराइड क्लास बनाएं onOptionsMenu()।
public override bool OnCreateOptionsMenu(IMenu menu) {
MenuInflater.Inflate(Resource.Menu.myMenu, menu);
return base.OnPrepareOptionsMenu(menu);
}
इसके बाद, हम प्रतिक्रिया करने के लिए एक क्रिया बनाते हैं settings menuजब यह चुना जाता है। ऐसा करने के लिए, हम एक और ओवरराइड क्लास बनाते हैंOnOptionsItemSelected() मेन्यू।
public override bool OnOptionsItemSelected(IMenuItem item) {
if (item.ItemId == Resource.Id.file_settings) {
// do something here...
return true;
}
return base.OnOptionsItemSelected(item);
}
हमारा अंतिम पूर्ण कोड निम्नानुसार होगा -
namespace optionsMenuApp {
[Activity(Label = "options Menu", MainLauncher = true, Icon = "@drawable/icon")]
public class MainActivity : Activity {
public override bool OnCreateOptionsMenu(IMenu menu) {
MenuInflater.Inflate(Resource.Menu.myMenu, menu);
return base.OnPrepareOptionsMenu(menu);
}
public override bool OnOptionsItemSelected(IMenuItem item) {
if (item.ItemId == Resource.Id.file_settings) {
// do something here...
return true;
}
return base.OnOptionsItemSelected(item);
}
}
}
अब, अपना एप्लिकेशन बनाएं और चलाएं। यह निम्नलिखित उत्पादन का उत्पादन करना चाहिए -
रैखिक लेआउट
रैखिक लेआउट में, सामग्री को क्षैतिज या ऊर्ध्वाधर तरीके से व्यवस्थित किया जाता है।
रैखिक लेआउट ear क्षैतिज
इस लेआउट की सामग्री क्षैतिज रूप से व्यवस्थित की गई है। इस डेमो के लिए, हम 3 बटन बनाने जा रहे हैं और उन्हें रैखिक लेआउट में क्षैतिज रूप से व्यवस्थित करते हैं।
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "horizontal"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent"
android:background = "#d3d3d3"
android:minWidth="25px"
android:minHeight="25px">
<Button
android:id="@+id/MyButton1"
android:layout_width="wrap_content"
android:layout_margin="10dp"
android:layout_height="wrap_content"
android:text="Button 1"
android:background="@android:color/holo_green_dark" />
<Button
android:id="@+id/MyButton2"
android:layout_width="wrap_content"
android:layout_margin="10dp"
android:layout_height="wrap_content"
android:text="Button 2"
android:background="@android:color/holo_green_dark" />
<Button
android:id="@+id/MyButton3"
android:layout_width="wrap_content"
android:layout_margin="10dp"
android:layout_height="wrap_content"
android:text="Button 3"
android:background="@android:color/holo_green_dark" />
</LinearLayout>
परिणामी आउटपुट नीचे दिखाया गया है -
रैखिक लेआउट ─ कार्यक्षेत्र
इस प्रकार का लेआउट बच्चे को एक ऊर्ध्वाधर तरीके से देखता है।
<?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:layout_height = "fill_parent"
android:background = "#d3d3d3"
android:minWidth = "25px"
android:minHeight = "25px">
<Button
android:id = "@+id/MyButton1"
android:layout_width = "fill_parent"
android:layout_margin = "10dp"
android:layout_height = "wrap_content"
android:text = "Button 1"
android:background = "@android:color/holo_green_dark" />
<Button
android:id = "@+id/MyButton2"
android:layout_width = "fill_parent"
android:layout_margin = "10dp"
android:layout_height = "wrap_content"
android:text = "Button 2"
android:background = "@android:color/holo_green_dark" />
<Button
android:id = "@+id/MyButton3"
android:layout_width = "fill_parent"
android:layout_margin = "10dp"
android:layout_height = "wrap_content"
android:text="Button 3"
android:background = "@android:color/holo_green_dark" />
</LinearLayout>
इसका परिणामी उत्पादन निम्नानुसार है -
अंतरंग परिस्थिति
इस दृष्टि से, बच्चे के देखने की स्थिति उसके माता-पिता या उसके भाई के दृष्टिकोण के सापेक्ष होती है। निम्नलिखित उदाहरण में, हम 3 EditText विचार और एक बटन बनाने जा रहे हैं और फिर, उन्हें अपेक्षाकृत संरेखित करें।
एक नया प्रोजेक्ट बनाएं और उसे कॉल करें relative layout app। खुला हुआmain.axml और निम्न कोड जोड़ें।
<?xml version = "1.0" encoding = "utf-8"?>
<RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:layout_width = "match_parent"
android:layout_height = "match_parent"
android:paddingLeft = "16dp"
android:background = "#d3d3d3"
android:paddingRight = "16dp">
<EditText
android:id = "@+id/name"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:hint = "First Name"
android:textColorHint = "@android:color/background_dark"
android:textColor = "@android:color/background_dark" />
<EditText
android:id = "@+id/lastName"
android:layout_width = "0dp"
android:layout_height = "wrap_content"
android:hint = "Last Name"
android:layout_below = "@id/name"
android:textColorHint = "@android:color/background_dark"
android:textColor = "@android:color/background_dark"
android:layout_alignParentLeft = "true"
android:layout_toLeftOf = "@+id/age" />
<EditText
android:id = "@id/age"
android:layout_width = "80dp"
android:layout_height = "wrap_content"
android:layout_below = "@id/name"
android:hint = "Age"
android:textColorHint = "@android:color/background_dark"
android:textColor = "@android:color/background_dark"
android:layout_alignParentRight = "true" />
<Button
android:layout_width = "85dp"
android:layout_height = "wrap_content"
android:layout_below = "@id/age"
android:layout_alignParentRight = "true"
android:text = "Submit"
android:background = "@android:color/holo_green_dark" />
</RelativeLayout>
इस कोड में हमारे द्वारा उपयोग किए जाने वाले महत्वपूर्ण पैरामीटर हैं -
android:layout_below - यह अपने माता-पिता के नीचे बाल दृश्य तत्व को संरेखित करता है।
android:layout_alignParentLeft - यह मूल तत्व को बाईं ओर संरेखित करता है।
android:layout_toLeftOf - यह गुण एक तत्व को दूसरे तत्व के बाईं ओर संरेखित करता है।
android:layout_alignParentRight - यह माता-पिता को दाईं ओर संरेखित करता है।
जब आप ऐप बनाते हैं और चलाते हैं, तो यह निम्न आउटपुट स्क्रीन का उत्पादन करेगा -
फ़्रेम लेआउट
फ़्रेम लेआउट का उपयोग केवल एक आइटम प्रदर्शित करने के लिए किया जाता है। इस लेआउट में एक-दूसरे को ओवरलैप किए बिना कई मदों को व्यवस्थित करना मुश्किल है।
एक नई परियोजना शुरू करें और इसे कॉल करें frameLayoutApp। एक नया फ़्रेम लेआउट बनाएँ जैसा कि नीचे दिखाया गया है।
<?xml version = "1.0" encoding = "utf-8"?>
<FrameLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent">
<ImageView
android:id = "@+id/ImageView1"
android:scaleType = "matrix"
android:layout_height = "fill_parent"
android:layout_width = "fill_parent"
android:src = "@drawable/img1" />
<TextView
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:textSize = "50dp"
android:textColor = "#000"
android:text = "This is a Lake" />
<TextView
android:gravity = "right"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:textSize = "50dp"
android:text = "A very Deep Lake"
android:layout_gravity = "bottom"
android:textColor = "#fff" />
</FrameLayout>
उपरोक्त कोड एक बनाता है imageViewजो पूरी स्क्रीन भरता है। दो पाठ्यवृत्त फिर ऊपर तैरते हैंimageView।
अब, अपना एप्लिकेशन बनाएं और चलाएं। यह निम्न आउटपुट प्रदर्शित करेगा -
टेबल लेआउट
इस लेआउट में, दृश्य को व्यवस्थित किया गया है rows तथा columns। आइए देखें कि यह कैसे काम करता है।
<?xml version = "1.0" encoding = "utf-8"?>
<TableLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:layout_width = "fill_parent"
android:background = "#d3d3d3"
android:layout_height = "fill_parent"
android:stretchColumns = "1">
<TableRow>
<TextView
android:text = "First Name:"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textColor = "@android:color/black" />
<EditText
android:width = "100px"
android:layout_width = "fill_parent"
android:layout_height = "30dp"
android:textColor = "@android:color/black" />
</TableRow>
<TableRow>
<TextView
android:text = "Last Name:"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textColor = "@android:color/black" />
<EditText
android:width = "50px"
android:layout_width = "fill_parent"
android:layout_height = "30dp"
android:textColor = "@android:color/black" />
</TableRow>
<TableRow>
<TextView
android:text = "Residence:"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textColor = "@android:color/black" />
<EditText
android:width = "100px"
android:layout_width = "fill_parent"
android:layout_height = "30dp"
android:textColor = "@android:color/black" />
</TableRow>
<TableRow>
<TextView
android:text = "Occupation:"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:textColor = "@android:color/black" />
<EditText
android:width = "100px"
android:layout_width = "fill_parent"
android:layout_height = "30dp"
android:textColor = "@android:color/black" />
</TableRow>
<TableRow>
<Button
android:text = "Cancel"
android:layout_width = "wrap_content"
android:layout_margin = "10dp"
android:layout_height = "wrap_content"
android:background = "@android:color/holo_green_dark" />
<Button
android:text = "Submit"
android:width = "100px"
android:layout_margin = "10dp"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:background = "@android:color/holo_green_dark" />
</TableRow>
</TableLayout>
उपरोक्त कोड का उपयोग करके व्यवस्थित एक साधारण डेटा एंट्री फॉर्म बनाता है tables तथा rows।
खजूर बीनने वाला
यह एक विजेट है जिसका उपयोग दिनांक प्रदर्शित करने के लिए किया जाता है। इस उदाहरण में, हम एक तिथि चयनकर्ता बनाने जा रहे हैं जो पाठ दृश्य पर निर्धारित तिथि प्रदर्शित करता है।
सबसे पहले, एक नया प्रोजेक्ट बनाएं और इसे कॉल करें datePickerExample। खुला हुआMain.axml और एक बनाएँ datepicker, textview, और ए button।
<?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:layout_height = "fill_parent">
<DatePicker
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/datePicker1" />
<TextView
android:text = "Current Date"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/txtShowDate" />
<Button
android:text = "Select Date"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/btnSetDate" />
</LinearLayout>
अगला, करने के लिए जाओ Mainactivity.cs। हम पहले अंदर एक टेक्स्टव्यू का एक निजी उदाहरण बनाते हैंmainActivity:Activity कक्षा।
उदाहरण का उपयोग चयनित तिथि या डिफ़ॉल्ट तिथि को संग्रहीत करने के लिए किया जाएगा।
private TextView showCurrentDate;
इसके बाद, निम्न कोड जोड़ें setContentView() तरीका।
DatePicker pickDate = FindViewById<DatePicker>(Resource.Id.datePicker1);
showCurrentDate = FindViewById<TextView>(Resource.Id.txtShowDate);
setCurrentDate();
Button button = FindViewById<Button>(Resource.Id.btnSetDate);
button.Click += delegate {
showCurrentDate.Text = String.Format("{0}/{1}/{2}",
pickDate.Month, pickDate.DayOfMonth, pickDate.Year);
};
उपर्युक्त कोड में, हमने अपने डेटपिकर, टेक्स्टव्यू, और बटन को हमारे द्वारा ढूंढकर संदर्भित किया है main.axml फ़ाइल का उपयोग कर FindViewById कक्षा।
संदर्भित करने के बाद, हम बटन क्लिक ईवेंट सेट करते हैं जो चयनित तिथि से लेकर टेक्स्टव्यू तक चयनित तिथि को पारित करने के लिए जिम्मेदार है।
अगला, हम बनाते हैं setCurrentDate()हमारे टेक्स्टव्यू के लिए डिफ़ॉल्ट वर्तमान तिथि प्रदर्शित करने की विधि। निम्न कोड बताता है कि यह कैसे किया जाता है।
private void setCurrentDate() {
string TodaysDate = string.Format("{0}",
DateTime.Now.ToString("M/d/yyyy").PadLeft(2, '0'));
showCurrentDate.Text = TodaysDate;
}
DateTime.Now.ToString() क्लास आज के समय को एक स्ट्रिंग ऑब्जेक्ट से बांधता है।
अब, एप्लिकेशन बनाएं और चलाएं। इसे निम्न आउटपुट प्रदर्शित करना चाहिए -
समय लेने वाला
टाइम पिकर एक विजेट है जो समय को प्रदर्शित करने के साथ-साथ उपयोगकर्ता को समय लेने और सेट करने की अनुमति देने के लिए उपयोग किया जाता है। हम एक बेसिक टाइम पिकर ऐप बनाने जा रहे हैं जो समय प्रदर्शित करता है और उपयोगकर्ता को समय बदलने की भी अनुमति देता है।
के लिए जाओ 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">
<TimePicker
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/timePicker1" />
<TextView
android:text = "Time"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/txt_showTime"
android:textColor = "@android:color/black" />
<Button
android:text = "Set Time"
android:layout_width = "200dp"
android:layout_height = "wrap_content"
android:id = "@+id/btnSetTime"
android:textColor = "@android:color/black"
android:background = "@android:color/holo_green_dark" />
</LinearLayout>
के लिए जाओ MainActivity.cs हमारे द्वारा बनाए गए टेक्स्टव्यू पर एक निर्धारित तिथि प्रदर्शित करने के लिए कार्यक्षमता जोड़ने के लिए।
public class MainActivity : Activity {
private TextView showCurrentTime;
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
TimePicker Tpicker = FindViewById<TimePicker>(Resource.Id.timePicker1);
showCurrentTime = FindViewById<TextView>(Resource.Id.txt_showTime);
setCurrentTime();
Button button = FindViewById<Button>(Resource.Id.btnSetTime);
button.Click += delegate {
showCurrentTime.Text = String.Format("{0}:{1}",
Tpicker.CurrentHour, Tpicker.CurrentMinute);
};
}
private void setCurrentTime() {
string time = string.Format("{0}",
DateTime.Now.ToString("HH:mm").PadLeft(2, '0'));
showCurrentTime.Text = time;
}
}
उपरोक्त कोड में, हमने पहली बार संदर्भित किया timepicker,set time बटन और के माध्यम से समय दिखाने के लिए पाठ FindViewById<>कक्षा। फिर हमने सेट टाइम बटन के लिए एक क्लिक ईवेंट बनाया, जो क्लिक पर किसी व्यक्ति द्वारा चुने गए समय के लिए सेट करता है। डिफ़ॉल्ट रूप से, यह वर्तमान सिस्टम समय दिखाता है।
setCurrentTime() विधि वर्ग इनिशियलाइज़ करता है txt_showTime वर्तमान समय प्रदर्शित करने के लिए टेक्स्टव्यू।
अब, अपना एप्लिकेशन बनाएं और चलाएं। इसे निम्न आउटपुट प्रदर्शित करना चाहिए -
स्पिनर
स्पिनर एक विजेट है जिसका उपयोग सेट से एक विकल्प चुनने के लिए किया जाता है। यह एक ड्रॉपडाउन / कॉम्बो बॉक्स के बराबर है। सबसे पहले, एक नया प्रोजेक्ट बनाएं और इसे कॉल करेंSpinner App Tutorial।
खुला हुआ Main.axml के नीचे layout folder और एक नया बनाएँ spinner।
<?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:layout_height = "fill_parent">
<Spinner
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/spinner1"
android:prompt = "@string/daysOfWeek" />
</LinearLayout>
खुला हुआ Strings.xml के तहत स्थित फ़ाइल values folder और बनाने के लिए निम्न कोड जोड़ें spinner items।
<resources>
<string name = "daysOfWeek">Choose a planet</string>
<string-array name = "days_array">
<item>Sunday</item>
<item>Monday</item>
<item>Tuesday</item>
<item>Wednesday</item>
<item>Thursday</item>
<item>Friday</item>
<item>Saturday</item>
<item>Sunday</item>
</string-array>
</resources>
अगला, खोलें MainActivity.cs सप्ताह के चयनित दिन को प्रदर्शित करने के लिए कार्यक्षमता जोड़ने के लिए।
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
// Set our view from the "main" layout resource
SetContentView(Resource.Layout.Main);
Spinner spinnerDays = FindViewById<Spinner>(Resource.Id.spinner1);
spinnerDays.ItemSelected += new EventHandler
<AdapterView.ItemSelectedEventArgs>(SelectedDay);
var adapter = ArrayAdapter.CreateFromResource(this,
Resource.Array.days_array, Android.Resource.Layout.SimpleSpinnerItem);
adapter.SetDropDownViewResource(Android.Resource.Layout.SimpleSpinnerDropD ownItem);
spinnerDays.Adapter = adapter;
}
private void SelectedDay(object sender, AdapterView.ItemSelectedEventArgs e) {
Spinner spinner = (Spinner)sender;
string toast = string.Format("The selected
day is {0}", spinner.GetItemAtPosition(e.Position));
Toast.MakeText(this, toast, ToastLength.Long).Show();
}
अब, एप्लिकेशन बनाएं और चलाएं। इसे निम्न आउटपुट प्रदर्शित करना चाहिए -
उपरोक्त कोड में, हमने अपने द्वारा बनाए गए स्पिनर को संदर्भित किया main.axml के माध्यम से फ़ाइल FindViewById<>कक्षा। हमने फिर एक नया बनायाarrayAdapter() जिसका उपयोग हम अपनी सरणी वस्तुओं को बांधने के लिए करते थे strings.xml कक्षा।
अंत में हमने विधि बनाई SelectedDay() जिसे हम सप्ताह के चयनित दिन प्रदर्शित करते थे।
अलर्ट डायलॉग
इस खंड में, हम एक बटन बनाने जा रहे हैं, जिस पर क्लिक किया गया एक चेतावनी संवाद बॉक्स प्रदर्शित करता है। संवाद बॉक्स में दो बटन होते हैं, अर्थात,Delete तथा Cancel बटन।
सबसे पहले, पर जाएं 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">
<Button
android:id="@+id/MyButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "Click to Delete"
android:textColor = "@android:color/background_dark"
android:background = "@android:color/holo_green_dark" />
</LinearLayout>
अगला, खोलें MainActivity.cs चेतावनी संवाद बनाने और उसकी कार्यक्षमता जोड़ने के लिए।
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
Button button = FindViewById<Button>(Resource.Id.MyButton);
button.Click += delegate {
AlertDialog.Builder alertDiag = new AlertDialog.Builder(this);
alertDiag.SetTitle("Confirm delete");
alertDiag.SetMessage("Once deleted the move cannot be undone");
alertDiag.SetPositiveButton("Delete", (senderAlert, args) => {
Toast.MakeText(this, "Deleted", ToastLength.Short).Show();
});
alertDiag.SetNegativeButton("Cancel", (senderAlert, args) => {
alertDiag.Dispose();
});
Dialog diag = alertDiag.Create();
diag.Show();
};
}
एक बार किए जाने के बाद, परिणाम देखने के लिए अपना एप्लिकेशन बनाएं और चलाएं।
उपरोक्त कोड में, हमने अलर्टडायग नामक एक चेतावनी संवाद बनाया है, जिसमें निम्नलिखित दो बटन हैं -
setPositiveButton - यह शामिल है Delete बटन पर क्लिक की गई क्रिया एक पुष्टिकरण संदेश प्रदर्शित करती है Deleted।
setNegativeButton - इसमें ए Cancel बटन पर क्लिक करने पर बस अलर्ट डायलॉग बॉक्स बंद हो जाता है।
गैलरी एक प्रकार का दृश्य है जिसका उपयोग क्षैतिज स्क्रॉल करने योग्य सूची में आइटम दिखाने के लिए किया जाता है। चयनित आइटम को तब केंद्र में दिखाया गया है। इस उदाहरण में, आप एक गैलरी बनाने जा रहे हैं जिसमें चित्र हैं जो क्षैतिज रूप से स्क्रॉल करने योग्य हैं। क्लिक की गई छवि चयनित छवि के लिए एक नंबर प्रदर्शित करेगी।
सबसे पहले, एक नया प्रोजेक्ट बनाएं और इसे एक नाम दें, जैसे, गैलरी ऐप ट्यूटोरियल। इससे पहले कि आप कोड करना शुरू करें, 7 छवियों को पेस्ट करेंresource /drawable folder। पर जाएmain.axml के अंतर्गत resources folder और रैखिक लेआउट टैग के बीच में एक गैलरी।
<?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:layout_height="fill_parent"
android:background="#d3d3d3">
<Gallery
android:id="@+id/gallery"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:padding="10dp" />
</LinearLayout>
नामक एक नया वर्ग बनाएँ ImageAdapter। इस क्लास का उपयोग हम ऊपर बनाई गई गैलरी में छवियों को बांधने के लिए करने जा रहे हैं।
पहला कदम एक वर्ग को जोड़ना है जिसमें एक संदर्भ शामिल है cont जिसका उपयोग हम खेतों को संग्रहीत करने के लिए करते हैं।
public class ImageAdapter : BaseAdapter {
Context cont;
public ImageAdapter(Context ct) {
cont = ct;
}
}
अगला, हम उस सरणी सूची को गिनते हैं जिसमें हमारी छवि होती है और इसका आकार लौटाता है।
public override int Count {
get {
return imageArraylist.Length;
}
}
अगले चरण में, हमें आइटम की स्थिति मिलती है। निम्न कोड दिखाता है कि यह कैसे करना है।
public override Java.Lang.Object GetItem(int position) {
return null;
}
public override long GetItemId(int position) {
return 0;
}
अगले चरण में, हम एक बनाते हैं imageview एडेप्टर द्वारा संदर्भित आइटम के लिए।
public override View GetView(int position,View convertView, ViewGroup parent) {
ImageView img = new ImageView(cont);
img.SetImageResource(imageArraylist[position]);
img.SetScaleType(ImageView.ScaleType.FitXy);
img.LayoutParameters = new Gallery.LayoutParams(200, 100);
return img;
}
अंतिम चरण में, हम उन छवियों का संदर्भ बनाते हैं जिन्हें हमने जोड़ा था resources.drawableफ़ोल्डर। ऐसा करने के लिए, हम छवियों के संग्रह को रखने के लिए एक सरणी बनाते हैं। निम्न कोड बताता है कि यह कैसे करना है।
int[] imageArraylist = {
Resource.Drawable.img1,
Resource.Drawable.img2,
Resource.Drawable.img3,
Resource.Drawable.img4,
Resource.Drawable.img5,
Resource.Drawable.img6,
};
}
इसके बाद, हम mainActivity.cs और OnCreate () विधि के तहत निम्न कोड डालें।
Gallery myGallery = (Gallery)FindViewById<Gallery>(Resource.Id.gallery);
myGallery.Adapter = new ImageAdapter(this);
myGallery.ItemClick += delegate(object sender, AdapterView.ItemClickEventArgs args) {
Toast.MakeText(this,
args.Position.ToString(), ToastLength.Short).Show();
}
अंत में, आउटपुट देखने के लिए अपना एप्लिकेशन बनाएं और चलाएं।
listviews
सूची सूची एक उपयोगकर्ता इंटरफ़ेस तत्व है जो स्क्रॉल करने योग्य वस्तुओं की सूची प्रदर्शित करता है।
डेटा को सूची में बाँधना
इस उदाहरण में, आप एक सूची बनाने जा रहे हैं जो सप्ताह के दिनों को प्रदर्शित करता है। इसके साथ शुरू करने के लिए, हम एक नई XML फ़ाइल बनाएँ और उसे नाम देंlistViewTemplate.xml।
में listViewTemplate.xml, हम नीचे दिखाए गए अनुसार एक नया टेक्स्टव्यू जोड़ते हैं।
<?xml version = "1.0" encoding = "utf-8" ?>
<TextView xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@+id/textItem"
android:textSize ="20sp"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"/>
अगला, करने के लिए जाओ Main.axml और रैखिक लेआउट के अंदर एक नई सूची बनाएँ।
<ListView
android:minWidth="25px"
android:minHeight="25px"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/listView1" />
खुला हुआ MainActivity.csऔर हमारे द्वारा बनाई गई सूची में डेटा को बांधने के लिए निम्न कोड टाइप करें। कोड के अंदर लिखा होना चाहिएOnCreate() तरीका।
SetContentView(Resource.Layout.Main);
var listView = FindViewById<ListView>(Resource.Id.listView1);
var data = new string[] {
"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"
};
listView.Adapter = new ArrayAdapter(this, Resource.Layout.ListViewTemplate, data);
Var data = new string[] बस एक सरणी के रूप में हमारे आइटम रखती है।
सरणी एडेप्टर हमारे संग्रह में आइटम को एक दृश्य के रूप में लौटाता है। डिफ़ॉल्ट रूप से, ऐरे एडाप्टर प्रत्येक आइटम को प्रदर्शित करने के लिए एक डिफ़ॉल्ट टेक्स्ट व्यू का उपयोग करता है। उपरोक्त कोड में, हमने अपना स्वयं का टेक्स्टव्यू बनायाListViewTemplate.xml और नीचे दिखाए गए कंस्ट्रक्टर का उपयोग करके इसे संदर्भित किया।
ArrayAdapter(this, Resource.Layout.ListViewTemplate, data);
अंत में, आउटपुट देखने के लिए अपना एप्लिकेशन बनाएं और चलाएं।
GridViews
एक ग्रिड व्यू एक दृश्य समूह है जो एप्लिकेशन को दो-आयामी तरीके से स्क्रॉल करने योग्य ग्रिड में सामग्री बिछाने की अनुमति देता है।
GridView जोड़ने के लिए, एक नया प्रोजेक्ट बनाएं और उसे कॉल करें gridViewApp। के लिए जाओMain.axml और नीचे दिखाए अनुसार एक ग्रिड जोड़ें।
<?xml version = "1.0" encoding="utf-8"?>
<GridView xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@+id/gridview"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent"
android:columnWidth = "90dp"
android:numColumns = "auto_fit"
android:verticalSpacing = "10dp"
android:horizontalSpacing = "10dp"
android:stretchMode = "columnWidth"
android:gravity = "center" />
इसके बाद, एक नया वर्ग बनाएं और उसे नाम दें ImageAdpter.cs। इस वर्ग में सभी मदों के लिए एडेप्टर कक्षाएं होंगी जिन्हें ग्रिड में दिखाया जाएगा।
के भीतर ImageAdapter, निम्नलिखित कोड जोड़ें -
public class ImageAdapter : BaseAdapter {
Context context;
public ImageAdapter(Context ch) {
context = ch;
}
public override int Count {
get {
return cars.Length;
}
}
public override long GetItemId(int position) {
return 0;
}
public override Java.Lang.Object GetItem(int position) {
return null;
}
public override View GetView(int position,
View convertView, ViewGroup parent) {
ImageView imageView;
if (convertView == null) {
imageView = new ImageView(context);
imageView.LayoutParameters = new GridView.LayoutParams(100, 100);
imageView.SetScaleType(ImageView.ScaleType.CenterCrop);
imageView.SetPadding(8, 8, 8, 8);
} else {
imageView = (ImageView)convertView;
}
imageView.SetImageResource(cars[position]);
return imageView;
}
int[] cars = {
Resource.Drawable.img1, Resource.Drawable.img2,
Resource.Drawable.img3, Resource.Drawable.img4,
Resource.Drawable.img5, Resource.Drawable.img6,
};
}
उपरोक्त कोड में, हमने अपनी कार छवियों को केवल छवि एडेप्टर के लिए बाध्य किया है। अगला, खोलेंMainActivity.cs और निम्नलिखित कोड जोड़ें setContentView()।
var gridview = FindViewById<GridView>(Resource.Id.gridview);
gridview.Adapter = new ImageAdapter(this);
gridview.ItemClick += delegate(object sender,
AdapterView.ItemClickEventArgs args) {
Toast.MakeText(this,
args.Position.ToString(), ToastLength.Short).Show();
};
उपरोक्त कोड में ग्रिड व्यू को ढूँढता है main.axml और इसे बांधता है imageAdapter कक्षा। Gridview.ItemClick एक बनाता है onClick वह घटना जो किसी उपयोगकर्ता द्वारा किसी छवि पर क्लिक करने पर चयनित छवि की स्थिति लौटाती है।
अब, आउटपुट देखने के लिए अपना एप्लिकेशन बनाएं और चलाएं।
इस अध्याय में, हम एक लॉगिन सिस्टम बनाने जा रहे हैं जो एक उपयोगकर्ता को पंजीकृत करने में सक्षम बनाता है। फिर, हम सफल लॉगिन पर पंजीकृत उपयोगकर्ता को अपने ऐप की होम स्क्रीन पर ले जाएंगे।
सबसे पहले, एक नया प्रोजेक्ट बनाएं और इसे कॉल करें Login System। अपने नए प्रोजेक्ट पर, पर जाएं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:layout_height = "fill_parent"
android:background = "@android:color/background_light"
android:weightSum = "100"
android:minWidth = "25px"
android:minHeight = "25px">
<TextView
android:text = "Login App"
android:textAppearance = "?android:attr/textAppearanceMedium"
android:layout_width = "match_parent"
android:layout_weight = "20"
android:layout_height = "0dp"
android:textColor = "#368DEB"
android:id = "@+id/txtCreatAccount"
android:gravity = "center"
android:textStyle = "bold"
android:textSize = "25sp" />
<Button
android:text = "Sign In"
android:layout_width = "match_parent"
android:layout_weight = "15"
android:layout_height = "0dp"
android:background = "@drawable/btnSignInStyle"
android:id = "@+id/btnSignIn"
android:layout_marginLeft = "20dp"
android:layout_marginRight = "20dp"
android:textSize = "15sp" />
<Button
android:text = "Sign Up"
android:layout_width = "match_parent"
android:layout_weight = "15"
android:layout_height = "0dp"
android:background = "@drawable/btnSignUpStyle"
android:id = "@+id/btnSignUp"
android:layout_marginLeft = "20dp"
android:layout_marginRight = "20dp"
android:textSize = "15sp" />
<RelativeLayout
android:layout_width = "match_parent"
android:layout_height = "0dp"
android:layout_weight = "50"
android:minWidth = "25px"
android:minHeight = "25px">
<ProgressBar
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:id = "@+id/progressBar1"
android:background = "@drawable/progressBarStyle"
android:layout_centerInParent="true"
android:indeterminate = "true"
xmlns:tools = "
http://schemas.android.com/tools"
tools:visibility = "invisible" />
</RelativeLayout>
</LinearLayout>
उपयोगकर्ता इंटरफ़ेस बनाने के बाद, बटन को स्टाइल करने के लिए उन्हें और अधिक आकर्षक बनाने के लिए महत्वपूर्ण है। ऐसा करने के लिए, के तहत एक नई XML फ़ाइल बनाएँdrawable folder और फ़ाइल का नाम btnSignInStyle.xml।
XML फ़ाइल में, कोड की निम्नलिखित पंक्तियाँ जोड़ें -
<selector xmlns:android = "http://schemas.android.com/apk/res/android">
<item android:state_pressed = "false">
<layer-list>
<item android:right = "5dp" android:top = "5dp">
<shape>
<corners android:radius = "2dp"/>
<solid android:color = "#D6D6D6"/>
</shape>
</item>
<item android:left = "2dp" android:bottom = "2dp">
<shape>
<corners android:radius = "4dp"/>
<gradient android:angle = "270"
android:endColor = "#486EA9" android:startColor = "#486EA9"/>
<stroke android:width = "1dp" android:color = "#BABABA"/>
<padding android:bottom = "10dp"
android:right = "10dp" android:left = "10dp" android:top = "10dp"/>
</shape>
</item>
</layer-list>
</item>
<item android:state_pressed = "true">
<layer-list>
<item android:right = "5dp" android:top = "5dp">
<shape>
<corners android:radius = "2dp"/>
<solid android:color = "#D6D6D6"/>
</shape>
</item>
<item android:left = "2dp" android:bottom = "2dp">
<shape>
<corners android:radius = "4dp"/>
<gradient android:angle = "270"
android:endColor = "#79C791" android:startColor = "#486EA9"/>
<stroke android:radius = "4dp" android:color = "#BABABA"/>
<padding android:bottom = "10dp"
android:right = "10dp" android:left = "10dp" android:top = "10dp"/>
</shape>
</item>
</layer-list>
</item>
</selector>
उपरोक्त कोड लोड और क्लिक पर बटन के रंगों को सेट करता है, यह बटन की सीमा त्रिज्या भी निर्धारित करता है।
अगला, हम ऊपर के लिए एक समान स्टाइल XML बनाते हैं signupबटन। ऐसा करने के लिए, नीचे एक और XML बनाएँdrawable फ़ोल्डर और इसे कॉल करें btnSignUpStyle.xml। इससे सब कुछ विरासत में मिलेगाbtnSignInStyle.xml। एकमात्र अंतर बटन के ग्रेडिएंट स्टार्ट और एंड कलर होगा।
बदलाव startColor तथा endColor में btnSignUpStyle.xml सेवा
<gradient android:angle="270"
android:endColor="#008000" android:startColor="#008000"/>
के लिए जाओ layout folderऔर एक नई AXML फ़ाइल बनाएं और उसे registerDailog.axml पर कॉल करें। इस फ़ाइल में हमारे ऐप में नए उपयोगकर्ताओं के लिए पंजीकरण विवरण होगा। पेज में तीन होंगेEditTextsऔर डेटा सबमिट करने के लिए एक बटन। अपने रैखिक लेआउट कोड के अंदर निम्नलिखित कोड जोड़ें।
<EditText
android:layout_width = "match_parent"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:layout_height = "35dp"
android:paddingLeft = "10dp"
android:id = "@+id/txtUsername"
android:hint = "Username"
android:textColor = "#000" />
<EditText
android:layout_width = "match_parent"
android:layout_height = "35dp"
android:id = "@+id/txtEmail"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:paddingLeft = "10dp"
android:textColor = "#000"
android:hint = "Email" />
<EditText
android:layout_width = "match_parent"
android:layout_height = "35dp"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:paddingLeft = "10dp"
android:textColor = "#000"
android:id = "@+id/txtPassword"
android:hint = "Password" />
<Button
android:text = "Sign Up"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/btnSave"
android:textSize = "20dp"
android:textColor = "#fff"
android:textStyle = "bold"
android:height = "70dp"
android:background = "@drawable/btnSignUpStyle"
android:paddingLeft = "5dp"
android:paddingRight = "5dp"
android:paddingTop = "5dp"
android:paddingBottom = "5dp"
android:layout_marginLeft = "25dp"
android:layout_marginRight = "25dp"
android:layout_centerHorizontal = "true" />
इसके बाद, एक नया वर्ग जोड़ें signUpDialog.cs। इस वर्ग में एक संवाद बॉक्स बनाने के लिए आवश्यक कोड होगा। निम्न उदाहरण कोड दिखाता है।
public class OnSignUpEvent:EventArgs {
private string myUserName;
private string myEmail;
private string myPassword;
public string UserName {
get {
return myUserName;
}
set{
myUserName = value;
}
}
public string Email {
get {
return myEmail;
}
set {
myEmail = value;
}
}
public string Password {
get {
return myPassword;
}
set {
myPassword = value;
}
}
public OnSignUpEvent(string username, string
email, string password):base() {
UserName = username;
Email = email;
Password = password;
}
class SignUpDialog:DialogFragment {
private EditText txtUsername;
private EditText txtEmail;
private EditText txtPassword;
private Button btnSaveSignUp;
public event EventHandler<OnSignUpEvent> onSignUpComplete;
public override View OnCreateView(LayoutInflater inflater,
ViewGroup container, Bundle savedInstanceState) {
base.OnCreateView(inflater, container, savedInstanceState);
var view = inflater.Inflate(Resource.Layout.registerDialog, container, false);
txtUsername = view.FindViewById<EditText>(Resource.Id.txtUsername);
txtEmail = view.FindViewById<EditText>(Resource.Id.txtEmail);
txtPassword = view.FindViewById<EditText>(Resource.Id.txtPassword);
btnSaveSignUp = view.FindViewById<Button>(Resource.Id.btnSave);
btnSaveSignUp.Click += btnSaveSignUp_Click;
return view;
}
void btnSaveSignUp_Click(object sender, EventArgs e) {
onSignUpComplete.Invoke(this, new OnSignUpEvent(txtUsername.Text,
txtEmail.Text, txtPassword.Text));
this.Dismiss();
}
}
}
उपरोक्त कोड में, हमने उपयोग किया है get तथा setगुण। get विधि एक चर देता है, जबकि setविधि लौटे चर का मान प्रदान करती है। यहाँ एक उदाहरण है -
public string Color {
get {
return color;
}
set {
color = value;
}
}
हमारे पिछले उदाहरण में, हमने एक तरीका बनाया जो एक दृश्य को ओवरराइड करता है। विधि के अंदर, हमने एक बनायाvar बुलाया view जिसे संदर्भित किया गया registerDialog.axml लेआउट फ़ोल्डर में निहित।
अगला, करने के लिए जाओ mainActivity.cs संवाद खंड बनाने के लिए।
private Button signUp;
private Button submitNewUser;
private EditText txtUsername;
private EditText txtEmail;
private EditText txtPassword;
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
signUp = FindViewById<Button>(Resource.Id.btnSignUp);
submitNewUser = FindViewById<Button>(Resource.Id.btnSave);
txtUsername = FindViewById<EditText>(Resource.Id.txtUsername);
txtEmail = FindViewById<EditText>(Resource.Id.txtEmail);
txtPassword = FindViewById<EditText>(Resource.Id.txtPassword);
signUp.Click += (object sender, EventArgs args) => {
FragmentTransaction transFrag = FragmentManager.BeginTransaction();
SignUpDialog diagSignUp = new SignUpDialog();
diagSignUp.Show(transFrag, "Fragment Dialog");
diagSignUp.onSignUpComplete += diagSignUp_onSignUpComplete;
};
}
void diagSignUp_onSignUpComplete(object sender, OnSignUpEvent e) {
StartActivity(typeof(Activity2));
}
उपरोक्त कोड में एक बटन क्लिक करने की घटना है जो क्लिक किए जाने पर साइनअप संवाद को लोड करता है। बटन क्लिक के अंदर, हमने एक बनायाSignUpDialog वर्ग जो लोड करता है registerDialog.axml फ़ाइल।
हमने तब इस्तेमाल किया FragmentTransaction transFrag = FragmentManager.BeginTransaction(); हमारे दिखाने के लिए registerDialog पेज एक एंड्रॉइड डायलॉग फ्रैगमेंट के रूप में।
हम एक और जोड़ने जा रहे हैं .axml फ़ाइल कहा जाता है home.axml। उपयोगकर्ता द्वारा सिस्टम में सफलतापूर्वक लॉग इन करने पर यह लेआउट लैंडिंग स्क्रीन होगा। इस लेआउट के अंदर, हम एक टेक्स्टव्यू जोड़ने जा रहे हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।
<TextView
android:text = "You have been succesfully registered. Welcome!"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView1" />
अगला, हम एक अंतिम गतिविधि बनाते हैं जिसे कहा जाता है Activity2.cs। इस गतिविधि में, हम खोजने जा रहे हैंhome.axml का उपयोग करते हुए findViewById।
अंत में, अपना ऐप बनाएं और चलाएं। यह आउटपुट के रूप में निम्न स्क्रीन प्रदर्शित करेगा।
अपने ऐप के निर्माण की प्रक्रिया को पूरा करने के बाद, इस ऐप को एक भौतिक एंड्रॉइड डिवाइस पर उपयोग करना महत्वपूर्ण है या अन्य लोगों को आपके ऐप को डाउनलोड करने और इसे अपने डिवाइस पर स्थापित करने की अनुमति है।
आपका ऐप जारी करना
अपने ऐप को रिलीज़ करने से पहले, इसे एक ऐसे प्रारूप में बदलना ज़रूरी है, जिसे एंड्रॉइड सिस्टम द्वारा पढ़ा जा सके। इस प्रकार के प्रारूप को ए कहा जाता हैapk file। बनाने के लिए एapk file।
अपना प्रोजेक्ट खोलें।
के लिए जाओ Build Menu और चुनें Configuration Manager
कॉन्फ़िगरेशन प्रबंधक पर, सेट करें Active Solution Configuration App जारी करने के लिए।
इसके बाद क्लिक करें Build Menu फिर से और चुनें Export Android Package(.apk)।
एक बार समाप्त होने के बाद, apk फ़ाइल आपके प्रोजेक्ट फ़ोल्डर में संग्रहीत की जाएगी /bin/Release।
आपका ऐप प्रकाशित करना
App को प्रकाशित करने के 3 तरीके हैं -
ऑनलाइन अटैचमेंट
इसमें आपका अपलोड करना शामिल है apkअटैचमेंट के रूप में ऑनलाइन फाइल करें। फिर एंड्रॉइड डिवाइस वाले उपयोगकर्ता अपने डिवाइस पर अपने ऐप को सीधे डाउनलोड और इंस्टॉल कर सकते हैं।
गूगल प्ले स्टोर
PlayStore Android ऐप्स का सबसे बड़ा बाज़ार है। अपने ऐप को प्लेस्टोर पर अपलोड करने के लिए, आपके पास Google के साथ एक डेवलपर खाता होना चाहिए। डेवलपर खाता एक बार बनाया जाता है और लाइसेंस प्राप्त करने के लिए $ 25 का खर्च आता है।
मैनुअल स्थापना
मैनुअल इंस्टॉलेशन में इंस्टाल करना शामिल है .apkफ़ाइल एक भौतिक उपकरण पर सीधे उत्पन्न होती है। फ़ाइल को अपने Android डिवाइस की भौतिक मेमोरी या SD कार्ड में कॉपी करें और फिर फ़ाइल को अपने डिवाइस से चलाएं।
Android, डिफ़ॉल्ट रूप से, उन ऐप्स की स्थापना को रोकता है जो PlayStore से नहीं हैं। अपना ऐप इंस्टॉल करने के लिए, आपको इसे ऐप इंस्टॉलेशन को स्वीकार करने में सक्षम करना होगाSettings। ऐसा करने के लिए, पर जाएंSettings अपने डिवाइस पर, देखें Security मेनू, और फिर "अज्ञात स्रोतों से एप्लिकेशन की स्थापना की अनुमति दें" की जांच करें।