Xamarin-빠른 가이드

Xamarin은 .NET Framework를 기반으로합니다. 여러 플랫폼에서 쉽게 실행되는 앱을 만들 수 있습니다. 이 자습서에서는 Xamarin을 사용하여 네이티브 iOS, Android 및 Windows 앱을 제공하는 방법을 설명합니다.

Windows 및 Mac 시스템에 Xamarin을 설치하는 방법에 대한 토론과 함께 자습서를 시작하겠습니다.

시스템 요구 사항

윈도우

  • RAM이 2GB 이상이고 Windows 7 이상을 실행하는 컴퓨터 (Windows 8-10 권장)

  • Visual Studio 2012 Professional 이상

  • Visual Studio 용 Xamarin

  • OS X Yosemite (10.10) 이상을 실행하는 Mac 컴퓨터
  • Xamarin iOS SDK
  • Apple의 Xcode (7+) IDE 및 iOS SDK
  • 자 마린 스튜디오

Windows에 설치

Xamarin 설치 관리자 다운로드 https://www.xamarin.com/download Xamarin 설치 관리자를 실행하기 전에 컴퓨터에 Android SDK 및 Java SDK를 설치했는지 확인하십시오.

다운로드 한 설치 프로그램을 실행하여 설치 프로세스를 시작하십시오-

  • Xamarin 라이선스 계약 화면이 나타납니다. 클릭Next 버튼을 눌러 동의합니다.

  • 설치 프로그램은 누락 된 구성 요소를 검색하고 다운로드하여 설치하라는 메시지를 표시합니다.

  • Xamarin 설치가 완료된 후 Close 버튼을 눌러 종료하고 Xamarin 사용을 시작할 준비를합니다.

Mac에 설치

  • Mac 시스템에 Xamarin Studio 설치 관리자를 다운로드합니다.

  • 다운로드 한 Xamarin 설치 관리자를 실행하고 설치 마법사에 제공된 단계를 따릅니다.

  • 설치가 완료된 후 시스템에서 Xamarin 사용을 시작할 수 있습니다.

이 장에서는 Xamarin을 사용하여 작은 Android 애플리케이션을 만드는 방법을 살펴 봅니다.

안녕하세요 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>

위의 코드에서 우리는 새로운 Android를 만들었습니다. 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 Emulator에 생성 된 앱을 표시합니다.

Android 에뮬레이터가없는 경우 다음 섹션에 제공된 단계에 따라 만듭니다.

Android 에뮬레이터 설정

Visual Studio 메뉴에서 Tools → Android → Android Emulator Manager. 표시되는 팝업 창에서Create단추. 다음 화면이 표시됩니다.

위 화면에서 AVD name당신이 원합니다. 선택device디스플레이에 적합합니다 (예 : Nexus 4”디스플레이). 선택target platform. 앱이 모든 Android 플랫폼에서 작동하는지 확인하기 위해 항상 최소 대상 플랫폼 (예 : API 10 Android 2.3 (Gingerbread))에서 테스트하는 것이 좋습니다.

나머지 필드를 채우고 확인 버튼을 클릭합니다. 이제 에뮬레이터가 준비되었습니다. 기존 Android 가상 장치 목록에서 선택한 다음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 앱에는 manifest file 일반적으로 AndroidManifest.xml. 매니페스트 파일에는 앱이 성공적으로 실행되는 데 필요한 Android 플랫폼에 대한 모든 것이 포함되어 있습니다.

여기에 매니페스트 파일의 중요한 기능 중 일부를 나열했습니다.

  • 그것은 선언합니다 minimum API level 응용 프로그램에 필요합니다.

  • 애플리케이션에 필요한 권한 (예 : 카메라, 위치 등)을 선언합니다.

  • 응용 프로그램에서 사용하거나 필요한 하드웨어 및 소프트웨어 기능에 대한 권한을 부여합니다.

  • 애플리케이션이 링크되어야하는 라이브러리를 나열합니다.

다음 스크린 샷은 매니페스트 파일을 보여줍니다.

Application name − 앱 제목을 의미합니다.

Package name − 귀하의 앱을 식별하는 데 사용되는 고유 한 이름입니다.

Application Icon − 앱의 Android 홈 화면에 표시되는 아이콘입니다.

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 − 애플리케이션이 지원하는 가장 낮은 Android 버전 플랫폼입니다.

<uses-sdk android:minSdkVersion="16" />

위의 예에서 최소 Android 버전은 API 레벨 16이며 일반적으로 JELLY BEAN.

Target Android Version − 앱이 컴파일되는 Android 버전입니다.

새 Android 프로젝트가 생성되면 기본적으로 프로젝트에 추가되는 일부 파일이 있습니다. 이러한 기본 프로젝트 파일 및 폴더를Android Resources. 다음 스크린 샷을보십시오.

기본 Android 리소스에는 다음이 포함됩니다.

  • AndroidManifest.xml file − 여기에는 Android 애플리케이션에 대한 정보 (예 : 애플리케이션 이름, 권한 등)가 포함됩니다.

  • Resources folder − 리소스는 Android의 리소스 시스템을 통해로드 할 수있는 이미지, 레이아웃, 문자열 등이 될 수 있습니다.

  • Resources/drawable folder − 응용 프로그램에서 사용할 모든 이미지를 저장합니다.

  • Resources/layout folder − 여기에는 Android가 사용자 인터페이스를 구축하는 데 사용하는 모든 Android XML 파일 (.axml)이 포함되어 있습니다.

  • The Resources/values folder− 애플리케이션 전체에서 문자열 (및 기타 유형)에 대한 키-값 쌍을 선언하는 XML 파일이 포함되어 있습니다. Android에서 일반적으로 여러 언어에 대한 현지화가 설정되는 방식입니다.

  • Resources.designer.cs −이 파일은 Android 프로젝션이 생성 될 때 자동으로 생성되며 Android 리소스를 참조하는 고유 식별자를 포함합니다.

  • MainActivity.cs file − 이것은 Android 애플리케이션의 첫 번째 활동이며 기본 애플리케이션 작업이 시작되는 곳입니다.

리소스 파일은 다음을 통해 프로그래밍 방식으로 액세스 할 수 있습니다. unique ID 에 저장되는 resources.designer.cs파일. ID는 다음과 같은 클래스 아래에 포함됩니다.Resource. 프로젝트에 추가 된 모든 리소스는resource class.

다음 코드는 7 개의 이미지를 포함하는 gridview 프로젝트를 만드는 방법을 보여줍니다.

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() {} 
      } 
   } 
}

위의 코드에서 7 개의 이미지는 다음과 같은 클래스에서 참조됩니다. drawable. 이러한 이미지는 프로그래밍 방식으로 추가됩니다. 사용자가 프로젝트에 다른 이미지를 추가하면 해당 이미지도 프로젝트에 추가됩니다.drawable수업. 그만큼gridview프로젝트에 포함 된 내용도 자체적으로 클래스에 추가되고 저장됩니다. 에 포함 된 각 항목resources folder 자동으로 생성되어 클래스에 저장됩니다.

사용자가 Android 앱을 탐색 할 때 일련의 이벤트가 발생합니다. 예를 들어 사용자가 앱 (예 : Facebook 앱)을 시작하면 시작되고 사용자에게 포 그라운드에서 표시됩니다.onCreate() → onStart() → onResume().

다른 활동이 시작되면 (예 : 전화가 들어 오면) Facebook 앱이 백그라운드로 이동하고 통화가 포 그라운드로 이동합니다. 이제 두 개의 프로세스가 실행 중입니다.

onPause()  --- > onStop()

전화 통화가 끝나면 Facebook 앱이 전경으로 돌아갑니다. 세 가지 메서드가 호출됩니다.

onRestart() --- > onStart() --- > onResume()

Android 활동에는 7 개의 수명주기 프로세스가 있습니다. 그들은 포함합니다-

  • onCreate − 액티비티가 처음 생성 될 때 호출됩니다.

  • onStart − 활동이 시작될 때 호출되어 사용자에게 표시됩니다.

  • onResume− 액티비티가 사용자와 상호 작용을 시작할 때 호출됩니다. 사용자 입력은이 단계에서 발생합니다.

  • onPause − 활동이 백그라운드에서 실행되지만 아직 종료되지 않은 경우 호출됩니다.

  • onStop − 활동이 더 이상 사용자에게 보이지 않을 때 호출됩니다.

  • onRestart− 활동이 중지 된 후 다시 시작하기 전에 호출됩니다. 일반적으로 사용자가 중지 된 이전 활동으로 돌아갈 때 호출됩니다.

  • onDestroy − 활동이 메모리에서 제거되기 전 마지막 호출입니다.

다음 그림은 Android 활동 수명주기를 보여줍니다.

Android에서는 기본적으로 사용자 또는 운영 체제에 영향을 미치는 작업을 수행 할 권한이있는 애플리케이션이 없습니다. 앱이 작업을 수행하려면 권한을 선언해야합니다. Android 시스템에서 권한을 부여 할 때까지 앱은 작업을 수행 할 수 없습니다. 이 권한 메커니즘은 사용자의 동의없이 애플리케이션이 원하는대로 수행하지 못하도록합니다.

권한이 기록됩니다. AndroidManifest.xml파일. 권한을 추가하려면 속성을 두 번 클릭 한 다음 Android Man으로 이동합니다.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−이 권한이있는 앱은 장치 메시징 서비스를 사용할 수 있습니다. 여기에는 SMS 및 MMS 메시지 읽기, 쓰기 및 편집이 포함됩니다. 구문은 다음과 같습니다.

<uses-permission android:name="android.permission-group.SMS" />

Location −이 권한이있는 앱은 GPS 네트워크를 사용하여 장치의 위치에 액세스 할 수 있습니다.

<uses-permission android:name="android.permission-group.LOCATION" />

Bluetooth −이 권한이있는 앱은 다른 Bluetooth 지원 장치와 무선으로 데이터 파일을 교환 할 수 있습니다.

<uses-permission android:name="android.permission.BLUETOOTH" />

TextView

TextView는 Android 위젯의 매우 중요한 구성 요소입니다. 주로 Android 화면에 텍스트를 표시하는 데 사용됩니다.

textview를 만들려면 간단히 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 <resources> 태그 사이에 다음 코드 줄을 입력합니다.

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

위의 코드는 우리가 만든 버튼의 값을 제공합니다. 다음으로 우리는MainActivity.cs버튼을 클릭했을 때 수행 할 액션을 생성합니다. 아래에 다음 코드를 입력하십시오.base.OnCreate (번들) 방법.

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

위의 코드는 사용자가 버튼을 클릭하면 "You Clicked Me"를 표시합니다.

FindViewById<< -->이 메소드는 식별 된보기의 ID를 찾습니다. .axml 레이아웃 파일에서 ID를 검색합니다.

체크 박스

확인란은 옵션 그룹에서 둘 이상의 옵션을 선택하려는 경우 사용됩니다. 이 예에서는 선택시 확인 된 메시지를 표시하고 그렇지 않으면 선택되지 않은 상태로 표시하는 확인란을 만들 것입니다.

우선, 우리는 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. 다음으로 체크 박스에 대한 핸들러 메서드를 생성하고 핸들러에서 선택한 결과에 따라 메시지를 표시하는 if else 문을 생성합니다.

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 인 진행률 표시 줄을 만들었습니다.

라디오 버튼

이것은 사용자가 옵션 세트에서 하나를 선택할 수있는 Android 위젯입니다. 이 섹션에서는 체크 된 라디오 버튼을 검색 할 자동차 목록을 포함하는 라디오 그룹을 만들 것입니다.

먼저 라디오 그룹을 추가하고 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;

이제 애플리케이션을 실행하십시오. 다음 화면이 출력으로 표시되어야합니다.

토글 버튼

토글 버튼은 두 상태 사이를 전환하는 데 사용됩니다. 예를 들어 ON과 OFF 사이를 전환 할 수 있습니다. 열다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>

앱을 실행하면 다음과 같은 출력이 표시됩니다.

자동 완성 Textview

이것은 사용자가 입력하는 동안 전체 제안을 보여주는 텍스트보기입니다. 사람들의 이름 목록과 클릭시 선택한 이름을 표시하는 버튼이 포함 된 자동 완성 텍스트보기를 만들 것입니다.

열다 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. Android 앱에 팝업 메뉴를 추가하는 방법을 살펴 보겠습니다.

새 프로젝트를 만들고 이름을 지정합니다. 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); 
      } 
   } 
}

이제 애플리케이션을 빌드하고 실행하십시오. 다음 출력을 생성해야합니다.

선형 레이아웃

선형 레이아웃에서 콘텐츠는 가로 또는 세로 방식으로 배열됩니다.

선형 레이아웃 ─ 수평

이 레이아웃의 내용은 가로로 정렬됩니다. 이 데모에서는 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.

이제 애플리케이션을 빌드하고 실행하십시오. 다음과 같은 출력이 표시됩니다.

테이블 레이아웃

이 레이아웃에서보기는 rowscolumns. 어떻게 작동하는지 봅시다.

<?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>

위의 코드는 다음을 사용하여 정렬 된 간단한 데이터 입력 양식을 만듭니다. tablesrows.

날짜 선택기

날짜를 표시하는 위젯입니다. 이 예에서는 텍스트보기에 설정된 날짜를 표시하는 날짜 선택기를 만들 것입니다.

우선 새 프로젝트를 만들고 이름을 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); 
};

위의 코드에서 우리는 datepicker, textview 및 button을 main.axml 파일 사용 FindViewById 수업.

참조 후 날짜 선택기에서 선택한 날짜를 textview로 전달하는 버튼 클릭 이벤트를 설정합니다.

다음으로 우리는 setCurrentDate()기본 현재 날짜를 textview에 표시하는 방법입니다. 다음 코드는 수행 방법을 설명합니다.

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 우리가 만든 textview에 설정된 날짜를 표시하는 기능을 추가합니다.

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 현재 시간을 표시하는 textview.

이제 애플리케이션을 빌드하고 실행하십시오. 다음과 같은 출력이 표시되어야합니다.

스피너

스피너는 세트에서 하나의 옵션을 선택하는 데 사용되는 위젯입니다. 드롭 다운 / 콤보 상자와 동일합니다. 우선 새 프로젝트를 만들고 이름을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() 선택한 요일을 표시하는 데 사용되었습니다.

경고 대화 상자

이 섹션에서는 클릭 할 때 경고 대화 상자를 표시하는 버튼을 만들 것입니다. 대화 상자에는 두 개의 버튼이 있습니다.DeleteCancel 버튼.

먼저 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(); 
   }; 
}

완료되면 애플리케이션을 빌드하고 실행하여 결과를 확인합니다.

위의 코드에서 다음 두 개의 버튼이있는 alertDiag라는 경고 대화 상자를 만들었습니다.

  • setPositiveButton − 여기에는 Delete 클릭하면 확인 메시지를 표시하는 버튼 동작 Deleted.

  • setNegativeButton − 여기에는 Cancel 버튼을 클릭하면 경고 대화 상자가 닫힙니다.

갤러리는 가로 스크롤 가능한 목록에 항목을 표시하는 데 사용되는보기 유형입니다. 그러면 선택한 항목이 중앙에 표시됩니다. 이 예제에서는 가로로 스크롤 할 수있는 이미지가 포함 된 갤러리를 만들 것입니다. 이미지를 클릭하면 선택한 이미지에 대한 번호가 표시됩니다.

먼저 새 프로젝트를 만들고 이름을 지정합니다 (예 : Gallery App Tutorial). 코딩을 시작하기 전에 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

Listview는 스크롤 가능한 항목 목록을 표시하는 사용자 인터페이스 요소입니다.

목록보기에 데이터 바인딩

이 예제에서는 요일을 표시하는 listView를 만들 것입니다. 먼저 새 XML 파일을 만들고 이름을 지정하겠습니다.listViewTemplate.xml.

listViewTemplate.xml, 우리는 아래와 같이 새로운 textview를 추가합니다.

<?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[] 단순히 항목을 배열로 보유합니다.

Array Adapter는 컬렉션의 항목을 뷰로 반환합니다. 기본적으로 어레이 어댑터는 기본 textView를 사용하여 각 항목을 표시합니다. 위의 코드에서 우리는ListViewTemplate.xml 아래 표시된 생성자를 사용하여 참조했습니다.

ArrayAdapter(this, Resource.Layout.ListViewTemplate, data);

마지막으로 애플리케이션을 빌드하고 실행하여 출력을 확인합니다.

GridView

gridView는 애플리케이션이 스크롤 가능한 그리드의 2 차원 방식으로 콘텐츠를 레이아웃 할 수 있도록하는보기 그룹입니다.

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(); 
};

위의 코드는 다음에서 gridView를 찾습니다. 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. 유일한 차이점은 버튼의 그라데이션 시작 및 종료 색상입니다.

변경 startColorendColorbtnSignUpStyle.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(); 
      } 
   }
}

위의 코드에서 우리는 getset속성. 그만큼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 페이지를 Android 대화 조각으로.

우리는 다른 것을 추가 할 것입니다 .axml 라는 파일 home.axml. 이 레이아웃은 사용자가 시스템에 성공적으로 로그인하면 시작 화면이됩니다. 이 레이아웃 안에 다음 코드와 같이 textview를 추가 할 것입니다.

<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.

마지막으로 앱을 빌드하고 실행합니다. 다음 화면이 출력으로 표시됩니다.

앱 빌드 프로세스를 완료 한 후 실제 Android 기기에서이 앱을 사용하거나 다른 사람이 앱을 다운로드하여 자신의 기기에 설치하도록 허용하는 것이 중요합니다.

앱 출시

앱을 출시하기 전에 Android 시스템에서 읽을 수있는 형식으로 변환하는 것이 중요합니다. 이러한 유형의 형식을apk file. 만들려면apk file.

  • 프로젝트를 엽니 다.

  • 이동 Build Menu 그리고 선택 Configuration Manager

  • 구성 관리자에서 Active Solution Configuration 앱을 출시합니다.

다음으로 Build Menu 다시 선택 Export Android Package(.apk).

완료되면 apk 파일은 프로젝트 폴더에 저장됩니다. /bin/Release.

앱 게시

앱을 게시하는 방법은 3 가지가 있습니다.

온라인 첨부

그것은 당신의 업로드를 포함합니다 apk첨부 파일로 온라인 파일. 그런 다음 Android 기기를 사용하는 사용자는 기기에 앱을 다운로드하여 직접 설치할 수 있습니다.

구글 플레이 스토어

PlayStore는 Android 앱을위한 가장 큰 시장입니다. PlayStore에 앱을 업로드하려면 Google 개발자 계정이 있어야합니다. 개발자 계정은 한 번 생성되며 라이선스를 얻는 데 $ 25의 비용이 듭니다.

수동 설치

수동 설치에는 .apk물리적 장치에서 직접 생성 된 파일. 파일을 Android 장치의 실제 메모리 또는 SD 카드에 복사 한 다음 장치에서 파일을 실행합니다.

Android는 기본적으로 PlayStore가 아닌 앱의 설치를 차단합니다. 앱을 설치하려면 다음에서 앱 설치를 수락하도록 활성화해야합니다.Settings. 이렇게하려면 다음으로 이동하십시오.Settings 장치에서 Security 메뉴를 클릭 한 다음 "알 수없는 출처의 앱 설치 허용"을 선택하십시오.