Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 321. Visual Studio Emulator for Android 소개 [링크 복사], [링크+제목 복사],
조회: 23584
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

Visual Studio Emulator for Android 소개

모바일 관련 설치 옵션과 함께 Visual Studio 2017을 설치한 경우 Xamarin 모바일 앱을 빌드하면 기본적으로 에뮬레이터가 "VisualStudio_android-23_x86_phone (Android 6.0 - API 23)"과 같은 항목이 선택됩니다. 이름에서 알 수 있듯이 "x86" 프로세서 용으로 빌드된 것으로 ARM 빌드 버전보다 속도가 빠릅니다. 그런데, Hyper-V가 설치된 환경에서 이를 실행하면 다음과 같은 오류 메시지와 함께 에뮬레이터가 동작하지 않습니다.

1>------ Build started: Project: MyFirstApp.Android, Configuration: Debug Any CPU ------
1>  MyFirstApp.Android -> C:\temp\MyFirstApp\MyFirstApp\MyFirstApp.Android\bin\Debug\MyFirstApp.Android.dll
2>Starting deploy VisualStudio_android-23_x86_phone ...
2>Starting emulator VisualStudio_android-23_x86_phone ...
2>C:\PROGRA~2\Android\ANDROI~1\tools\emulator.EXE -partition-size 512 -no-boot-anim -avd VisualStudio_android-23_x86_phone -prop monodroid.avdname=VisualStudio_android-23_x86_phone
2>emulator: ERROR: x86 emulation currently requires hardware acceleration!
2>Please ensure Intel HAXM is properly installed and usable.
2>CPU acceleration status: Please disable Hyper-V before using the Android Emulator.  Start a command prompt as Administrator, run 'bcdedit /set hypervisorlaunchtype off', reboot.
2>Emulator VisualStudio_android-23_x86_phone cannot be started.
========== Build: 1 succeeded, 0 failed, 1 up-to-date, 0 skipped ==========
========== Deploy: 0 succeeded, 1 failed, 0 skipped ==========

이것 때문에 Hyper-V를 끄자니 여러 가지로 불편하게 되었는데요. 물론, 다음과 같이 설정해서 원하는 모드로 부팅할 수 있지만,

윈도우 8에서 Hyper-V 유무에 따른 듀얼 부트 설정하는 방법
; https://www.sysnet.pe.kr/2/0/1676

역시 부팅 자체가 불편합니다. 그렇다고 ARM 버전의 "VisualStudio_android-23_arm_phone (Android 6.0 - API 23)" 에뮬레이터를 이용하자니, 속도가 10배나 느리다는 말은 둘째치고, 정말 느린 속도에 에뮬 환경을 포기하고 싶어집니다. ^^;

그런데, 이런 불편함을 마이크로소프트가 전용 에뮬레이터를 내놓음으로써 말끔히 해결했습니다. ^^

Visual Studio Emulator for Android
; https://www.visualstudio.com/ko/vs/msft-android-emulator

Visual Studio Android Emulator
; https://developer.xamarin.com/guides/android/deployment,_testing,_and_metrics/debug-on-emulator/visual-studio-android-emulator/

Visual Studio 2015 사용자는 위의 링크에서 다운로드할 수 있고, 2017 사용자는 설치 파일에서 다음과 같이 "Visual Studio Emulator for Android" 구성 요소를 선택하면 됩니다.

[그림 출처: https://social.msdn.microsoft.com/Forums/vstudio/en-US/34d06dea-0bb4-4c67-a115-d739f7be91c7/visual-studio-2017-emulator-for-android]
and_emul_0.png

그럼 다음과 같이 "Tools" / "Visual Studio Emulator for Android..." 메뉴가 제공되고,

[그림 출처: https://developer.xamarin.com/guides/android/deployment,_testing,_and_metrics/debug-on-emulator/visual-studio-android-emulator/]
and_emul_1.png

동작 속도는, 예전 Windows Phone 에뮬레이터만큼의 쾌적함을 제공합니다. ^^




참고로, Visual Studio에서 Emulator를 시작할 때 다음과 같은 오류가 발생할 수 있습니다.

2>Starting deploy 5" KitKat (4.4) XXHDPI Phone ...
2>Starting emulator 5" KitKat (4.4) XXHDPI Phone ...
2>An error occured. See full exception on logs for more details.
2>Object reference not set to an instance of an object.

이런 경우에는, "Tools" / "Visual Studio Emulator for Android..." 메뉴를 실행해 직접 해당 Emulator를 시작, 다음과 같이 권한 승인을 요구하는 창을 거치기만 하면 됩니다. (한 번만 필요합니다.)

and_emul_2.png




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/11/2017]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2017-07-14 12시01분
Visual Studio 2017의 경우 설치 파일을 "C:\Program Files (x86)\Microsoft Visual Studio\Installer" 폴더의 vs_installer.exe를 실행시키면 됩니다.
정성태
2018-05-08 11시00분
Android emulator를 아예 hyper-v 호환으로 내놓는군요. ^^

Hyper-V Android emulator support
; https://devblogs.microsoft.com/visualstudio/hyper-v-android-emulator-support/

HAXM v7.8.0 (INTEL CPU)
; https://github.com/intel/haxm/releases

Android Emulator hypervisor driver 2.1 (AMD & INTEL CPU)
; https://github.com/google/android-emulator-hypervisor-driver/releases
정성태

... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12886정성태12/20/202114696스크립트: 37. 파이썬 - uwsgi의 --enable-threads 옵션 [2]
12885정성태12/20/202115726오류 유형: 776. uwsgi-plugin-python3 환경에서 MySQLdb 사용 환경
12884정성태12/20/202114652개발 환경 구성: 620. Windows 10+에서 WMI root/Microsoft/Windows/WindowsUpdate 네임스페이스 제거
12883정성태12/19/202115085오류 유형: 775. uwsgi-plugin-python3 환경에서 "ModuleNotFoundError: No module named 'django'" 오류 발생
12882정성태12/18/202114575개발 환경 구성: 619. Windows Server에서 WSL을 위한 리눅스 배포본을 설치하는 방법
12881정성태12/17/202114175개발 환경 구성: 618. WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법 (2)
12880정성태12/16/202115172VS.NET IDE: 170. Visual Studio에서 .NET Core/5+ 역어셈블 소스코드 확인하는 방법
12879정성태12/16/202121710오류 유형: 774. Windows Server 2022 + docker desktop 설치 시 WSL 2로 선택한 경우 "Failed to deploy distro docker-desktop to ..." 오류 발생
12878정성태12/15/202115970개발 환경 구성: 617. 윈도우 WSL 환경에서 같은 종류의 리눅스를 다중으로 설치하는 방법
12877정성태12/15/202115290스크립트: 36. 파이썬 - pymysql 기본 예제 코드
12876정성태12/14/202115146개발 환경 구성: 616. Custom Sources를 이용한 Azure Monitor Metric 만들기
12875정성태12/13/202114016스크립트: 35. python - time.sleep(...) 호출 시 hang이 걸리는 듯한 문제
12874정성태12/13/202113856오류 유형: 773. shell script 실행 시 "$'\r': command not found" 오류
12873정성태12/12/202115240오류 유형: 772. 리눅스 - PATH에 등록했는데도 "command not found"가 나온다면?
12872정성태12/12/202115645개발 환경 구성: 615. GoLang과 Python 빌드가 모두 가능한 docker 이미지 만들기
12871정성태12/12/202114688오류 유형: 771. docker: Error response from daemon: OCI runtime create failed
12870정성태12/9/202113769개발 환경 구성: 614. 파이썬 - PyPI 패키지 만들기 (4) package_data 옵션
12869정성태12/8/202116463개발 환경 구성: 613. git clone 실행 시 fingerprint 묻는 단계를 생략하는 방법
12868정성태12/7/202114833오류 유형: 770. twine 업로드 시 "HTTPError: 400 Bad Request ..." 오류 [1]
12867정성태12/7/202114599개발 환경 구성: 612. 파이썬 - PyPI 패키지 만들기 (3) entry_points 옵션
12866정성태12/7/202121516오류 유형: 769. "docker build ..." 시 "failed to solve with frontend dockerfile.v0: failed to read dockerfile ..." 오류
12865정성태12/6/202114860개발 환경 구성: 611. 파이썬 - PyPI 패키지 만들기 (2) long_description, cmdclass 옵션
12864정성태12/6/202112524Linux: 46. WSL 환경에서 find 명령을 사용해 파일을 찾는 방법
12863정성태12/4/202114707개발 환경 구성: 610. 파이썬 - PyPI 패키지 만들기
12862정성태12/3/202112655오류 유형: 768. Golang - 빌드 시 "cmd/go: unsupported GOOS/GOARCH pair linux /amd64" 오류
12861정성태12/3/202116484개발 환경 구성: 609. 파이썬 - "Windows embeddable package"로 개발 환경 구성하는 방법 [1]
... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...