Xamarin.Forms 항목 자습서
이 자습서를 시도하기 전에 다음 작업을 성공적으로 완료해야 합니다.
- 첫 번째 Xamarin.Forms 앱을 빌드하세요 빠른 시작.
- StackLayout 자습서
이 자습서에서는 다음을 하는 방법을 알아볼 수 있습니다.
- XAML에서 Xamarin.Forms
Entry
을 만듭니다. - 변경 중인
Entry
에 있는 텍스트에 응답합니다. Entry
의 동작을 사용자 지정합니다.
Visual Studio 2019 또는 Mac용 Visual Studio를 사용하여 Entry
의 동작을 사용자 지정하는 방법을 보여 주는 간단한 애플리케이션을 만들겠습니다. 다음 스크린샷은 최종 애플리케이션을 보여 줍니다.
또한 Xamarin.Forms용 XAML 핫 다시 로드를 사용하여 애플리케이션을 다시 빌드하지 않고 UI 변경 내용을 확인할 수 있습니다.
항목 만들기
이 자습서를 완료하려면 .NET을 사용한 모바일 개발 워크로드가 설치된 Visual Studio 2019(최신 릴리스)가 있어야 합니다. 또한 iOS에서 자습서 애플리케이션을 빌드하려면 페어링된 Mac이 필요합니다. Xamarin 플랫폼 설치에 대한 자세한 내용은 Xamarin 설치를 참조하세요. Visual Studio 2019를 Mac 빌드 호스트에 연결하는 방법에 대한 자세한 내용은 Xamarin.iOS 개발을 위해 Mac에 페어링을 참조하세요.
Visual Studio를 실행하고, EntryTutorial이라는 이름의 빈 Xamarin.Forms 앱을 새로 만듭니다.
Important
이 자습서의 C# 및 XAML 코드 조각은 솔루션의 이름이 EntryTutorial이어야 합니다. 이 자습서에서 코드를 솔루션으로 복사할 때 다른 이름을 사용하면 빌드 오류가 발생합니다.
생성된 .NET Standard 라이브러리에 대한 자세한 내용은 Xamarin.Forms 빠른 시작 심층 분석에서 Xamarin.Forms 애플리케이션 분석을 참조하세요.
솔루션 탐색기의 EntryTutorial 프로젝트에서 MainPage.xaml을 두 번 클릭하여 엽니다. 그런 다음, MainPage.xaml에서 템플릿 코드를 모두 제거하고 다음 코드로 바꿉니다.
<?xml version="1.0" encoding="utf-8"?> <ContentPage xmlns="http://xamarin.com/schemas/2014/forms" xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml" x:Class="EntryTutorial.MainPage"> <StackLayout Margin="20,35,20,20"> <Entry Placeholder="Enter text" /> </StackLayout> </ContentPage>
이 코드는
StackLayout
에서Entry
로 구성된 페이지에 대한 사용자 인터페이스를 선언적으로 정의합니다.Entry.Placeholder
속성은Entry
가 처음 표시될 때 표시되는 자리 표시자 텍스트를 지정합니다.Visual Studio 도구 모음에서 선택한 원격 iOS 시뮬레이터 또는 Android 에뮬레이터 내에서 애플리케이션을 시작하려면 시작 단추(재생 단추와 비슷한 삼각형 모양의 단추)를 누릅니다.
Visual Studio에서 애플리케이션을 중지합니다.
텍스트 변경 내용에 대응
MainPage.xaml에서
Entry
선언을 수정하여TextChanged
및Completed
이벤트에 대한 처리기를 설정합니다.<Entry Placeholder="Enter text" TextChanged="OnEntryTextChanged" Completed="OnEntryCompleted" />
이 코드는
TextChanged
이벤트를OnEntryTextChanged
라는 이벤트 처리기로 설정하고,Completed
이벤트를OnEntryCompleted
라는 이벤트 처리기로 설정합니다. 두 가지 이벤트 처리기는 다음 단계에서 생성됩니다.솔루션 탐색기의 EntryTutorial 프로젝트에서 MainPage.xaml을 확장하고 MainPage.xaml.cs를 두 번 클릭하여 엽니다. 그런 다음, MainPage.xaml.cs에서
OnEntryTextChanged
및OnEntryCompleted
이벤트 처리기를 클래스에 추가합니다.void OnEntryTextChanged(object sender, TextChangedEventArgs e) { string oldText = e.OldTextValue; string newText = e.NewTextValue; } void OnEntryCompleted(object sender, EventArgs e) { string text = ((Entry)sender).Text; }
Entry
에 있는 텍스트가 변경되면OnEntryTextChanged
메서드가 실행됩니다.sender
인수는TextChanged
이벤트의 실행을 담당하는Entry
개체이며Entry
개체에 액세스하는 데 사용될 수 있습니다.TextChangedEventArgs
인수는 앞뒤의 텍스트 변경 내용에서 이전 및 새 텍스트 값을 제공합니다.반환 키를 사용하여
Entry
에서 텍스트 입력을 완료하면OnEntryCompleted
메서드가 실행됩니다.sender
인수는TextChanged
이벤트의 실행을 담당하는Entry
개체이며Entry
개체에 액세스하는 데 사용될 수 있습니다.Visual Studio 도구 모음에서 선택한 원격 iOS 시뮬레이터 또는 Android 에뮬레이터 내에서 애플리케이션을 시작하려면 시작 단추(재생 단추와 비슷한 삼각형 모양의 단추)를 누릅니다.
두 개의 이벤트 처리기에서 중단점을 설정하고,
Entry
에 텍스트를 입력하고,TextChanged
및Completed
이벤트가 발생하는지 살펴봅니다.Entry
이벤트에 관한 자세한 내용은 Xamarin.Forms 항목 가이드의 이벤트 및 대화형 작업을 참조하세요.
동작 사용자 지정
MainPage.xaml에서
Entry
선언을 수정하여 해당 동작을 사용자 지정합니다.<Entry Placeholder="Enter password" MaxLength="15" IsSpellCheckEnabled="false" IsTextPredictionEnabled="false" IsPassword="true" />
이 코드는
Entry
의 동작을 사용자 지정하는 속성을 설정합니다.MaxLength
속성은Entry
에 허용되는 입력 길이를 제한하고,IsSpellCheckEnabled
속성은false
로 설정되어 맞춤법 검사를 사용하지 않도록 설정합니다. 마찬가지로,IsTextPredictionEnabled
속성은false
로 설정되어 텍스트 예측 및 자동 텍스트 예측을 사용하지 않도록 설정합니다. 또한IsPassword
속성은 입력된 문자가 암호 문자(검은색 원)로 표시되어 있는지 확인합니다.참고 항목
일부 텍스트 항목 시나리오(예: 암호 입력)의 경우 맞춤법 검사 및 텍스트 예측은 부정적인 환경을 제공하므로 사용되지 않도록 설정되어야 합니다.
애플리케이션이 계속 실행 중인 경우 변경 내용을 파일에 저장하면 애플리케이션 사용자 인터페이스가 시뮬레이터나 에뮬레이터에서 자동으로 업데이트됩니다. 또는 Visual Studio 도구 모음에서 선택한 원격 iOS 시뮬레이터 또는 Android Emulator 내에서 애플리케이션을 시작하려면 시작 단추(재생 단추와 비슷한 삼각형 모양의 단추)를 누릅니다.
Entry
에 텍스트를 입력한 다음, 각 문자를 암호 마스크 문자로 바꾸고 입력할 수 있는 최대 문자 수가 15개인지를 확인합니다.Visual Studio에서 애플리케이션을 중지합니다.
Entry
동작을 사용자 지정하는 방법은 Xamarin.Forms 항목 가이드를 참조하세요.
축하합니다!
축하합니다. 자습서를 마쳤습니다. 여기서는 다음과 같은 방법을 알아보았습니다.
- XAML에서 Xamarin.Forms
Entry
을 만듭니다. - 변경 중인
Entry
에 있는 텍스트에 응답합니다. Entry
의 동작을 사용자 지정합니다.
다음 단계
Xamarin.Forms를 사용하여 모바일 애플리케이션을 만드는 기본적인 내용에 대해 자세히 알아보려면 편집기 자습서를 참조하세요.
관련 링크
본 섹션과 관련하여 문제가 있으십니까? 문제가 있으시면 본 섹션을 개선하기 위해 피드백을 제출해 주세요.