티스토리 뷰
2016년 12월 14일 오프라인 모임을 통해서 추가된 트러블슈팅 내용입니다.
1. Hyper-V기능의 활성화는 Windows 10 Pro 이상 버전에서만 가능합니다. Home버전에서는 사용할 수 없습니다.
->윈도우 버전을 Pro버전 이상으로 변경하신후 진행하셔야합니다.
2. 자마린 탬플릿으로 프로젝트를 생성하기전에 Windows 10 SDK가 설치되어 있어야지만, Windows 10 UWP 앱 개발 프로젝트 템플릿이 추가됩니다. Windows 8.1 SDK 필요 여부는 명확하게 확인하지 않았습니다.
다운로드를 할 때 주의할 사항은 Windows 10 버전과 맞는 SDK를 설치해야 한다는 것입니다.
Windows 10 Version 1607 (OS Build 14393.x)인 경우에만 최신 SDK를 설치하셔야 하고, 이전 버전이라고 생각되면 해당버전에 맞는 SDK를 설치하셔야 합니다.
가장 좋은 시나리오는 Windows 10 버전을 최신 버전으로 업그레이드를 하고 난 후에 최신 버전 SDK를 설치하는 것입니다.
3. 소소한 팁
한번 에물레이터를 실행해서 가상 네트워크 설정을 한 후 컨넥션(Wi-Fi 접속 경로)이 변경된 경우에도 다시 네트워크 설정을 새로 추가할지를 물어보는데, 이때는 No를 눌러서 기존 가상 네트워크 사용을 유지하도록 하면 됩니다.
4.
the emulator is unable to connect to the device operating system
couldn't auto-detect the guest system ip address.
some functionality might be disabled
->...
5. Build Error
Severity Code Description Project File Line Suppression State
Error Could not find android.jar for API Level 23. This means the Android SDK platform for API Level 23 is not installed. Either install it in the Android SDK Manager (Tools > Open Android SDK Manager...), or change your Xamarin.Android project to target an API version that is installed.
해결방법 :
https://forums.xamarin.com/discussion/71633/android-api-level-24-is-not-installed
아래 이미지 처럼 23.0.1~3까지 설치를 진행하고, 최신 업데이트를 진행합니다.
그리고, Clean Solution을 한 후 다시 빌드합니다.
----------------------------------------------------------------------------------------------------------------------------
이번 트러블슈팅의 핵심은 에뮬레이터 실행입니다. 장장 2일에 걸쳐 삽질한 내용입니다.
집 PC와 서피스에 모두 Hyper-V 안드로이드 에뮬레이터로 앱 실행을 완료했습니다. ^^/
1. 안드로이드 에뮬레이터 종류
Visual Studio 2015에서 사용할 수 있는 에뮬레이터는 크게 2가지가 있습니다.
1) Android_Accelerated_x86 (Android 6.0 - API 23) 을 선택해서 실행하면 볼 수 있는 에뮬레이터
Hyper-V가 활성화된 상태에서는 실행이 않됩니다. 덕분에 안드로이드 게임실행용 블루스택이나 MEmu 등도 실행이 않됩니다;;;
2) 5" KitKat (4.4) XXHDPI Phone (Android 4.4 - API 19)를 선택했을 때 볼 수 있는 에뮬레이터
Visual Studio Emulator for Android
https://www.visualstudio.com/vs/msft-android-emulator/
위 사이트에서 다운로드 받을 수 있는 것으로 겉 모양은 윈도우폰 에뮬레이터와 동일하고, Hyper-V 환경에서 실행이 됩니다.
2. 트러블...
기존에 PC에 윈도우폰 에뮬레이터가 설치되어 있었는데, 추가로 안드로이드 에뮬레이터 설치하고 Deploy를 하는 과정에서 더 이상 진행이 되지 않아서..삽질을 시작했습니다.
확인해 봐야하는 곳은 3곳입니다. 3곳을 모두 봐야할 수도 있고 한곳만 수정해도 가능할 수 있습니다.
1) Hyper-V Manager
Virtual Machines에 여러개가 실행되어 있는 경우 다 삭제 하고,
Control Panel -> Program and Features 실행 -> Turn Windows features on or off 선택 -> Hyper-V 선택을 풀고, 컴퓨터 재부팅 후 다시 Hyper-V를 선택 후 재부팅 -> Visual Studio 2015에서 에뮬레이터 실행해서 처음부터 다시 합니다.
Virtual Machines을 추가할 때 아래와 같이 물어보면 Yes를 선택해서 추가를 완료합니다.
2) Android SDK Update
음 생각해보니 업데이트랑 관련이 있는지 확실하지 않네요..하지만..그냥 설치하시는 걸로..ㅎㅎ
Tools -> Android -> Android SDK Manager... 를 선택합니다.
7개 설치 및 업데이트, 그 아래 Google APIs, Google APIs ARM EABI v7a System Image, Google APIs Intel x86 Atom System Image가 설치 되어있는지 확인합니다.
3) regedit를 이용해서 SDK 경로 확인
RegEdit 실행 -> HKEY_LOCAL_MACHINE -> SOFTWARE -> WOW6432Node -> Android SDK Tools -> Path 를 수정합니다.
Path에 입력할 값은
Tools -> Options -> Xamarin -> Android Settings -> Android SDK Location의 값을 입력하면 됩니다.
Options에서 Xamarin이 나오지 않으면 Xamarin for Visual Studio가 설치 되어 있어야 합니다.
Output verbosity를 Diagnostic를 선택하면 Output -> Xamarin Diagnostics를 선택하시면 더 많은 정보가 출력됩니다.
4) Visual Studio 2015를 Administrator로 실행하기를 하는 경우에도 가능하다고 하는군요..
3. 결과~
4. 기본 트러블슈팅
Troubleshooting the Visual Studio Emulator for Android
5. 빌드 오류
Severity Code Description Project File Line Suppression State
Error CS5001 Program does not contain a static 'Main' method suitable for an entry point HelloWorldXamarinForms.UWP C:\Sample\HelloWorldXamarinForms\HelloWorldXamarinForms\HelloWorldXamarinForms.UWP\CSC 1 Active
해결 방법
App.xaml 파일을 선택하고 Build Action을 확인해서 ApplicationDefinition으로 선택해야 합니다.
6. Could not connect to the debugger.
Debug창에 위와 같은 메시지가 출력되면서, 앱이 배포가 된 후 바로 종료되고 끝나는 경우로, 디버그 모드가 아닌 경우에는 정상 실행이 됩니다.
해결 방법..
http://dotnetbyexample.blogspot.kr/2016/02/fix-for-could-not-connect-to-debugger.html
'Xamarin Forms' 카테고리의 다른 글
Accessing Native Features with DependencyService (0) | 2017.02.12 |
---|---|
Hyper-V 안드로이드 에뮬레이터에 구글 플레이 설치하기 (0) | 2016.12.26 |
Hello World for Xamarin Forms part1 (0) | 2016.12.01 |
- Total
- Today
- Yesterday
- LINQ
- Microsoft
- Cross-platform
- #uwp
- #MVVM
- kiosk
- Behavior
- Windows 10
- #Windows Template Studio
- PRISM
- visual studio 2019
- uno platform
- ComboBox
- Always Encrypted
- UWP
- ef core
- dotNETconf
- Bot Framework
- MVVM
- XAML
- .net
- .net 5.0
- windows 11
- C#
- #prism
- IOT
- uno-platform
- Visual Studio 2022
- Build 2016
- WPF
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |