ज़मारिन - त्वरित गाइड

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 मेनू, और फिर "अज्ञात स्रोतों से एप्लिकेशन की स्थापना की अनुमति दें" की जांच करें।