개발 플랫폼으로서의 Android 가상 장치

Android Virtual Device(AVD)를 사용하기 위해 Android Emulator는 그래픽 사용자 인터페이스(GUI)와 명령줄 인터페이스(CLI)를 지원합니다. 귀하의 환경에 가장 적합한 워크플로우를 선택하세요.

  • 가상 장치 생성 및 관리 GUI는 대부분의 앱 개발자와 사용자에게 제공되는 간단한 도구입니다.
  • 명령줄에서 에뮬레이터를 시작하면 고급 사용자와 자동화를 위한 유연한 방법이 제공됩니다. 예를 들어 여러 AVD를 사용하거나 지속적인 테스트 및 지속적인 통합을 설정하는 경우입니다. 시작하려면 도구 의 예를 참조하세요.

사전 빌드된 AOSP 자동차 AVD 실행

사전 빌드된 AOSP Car AVD를 사용하여 빠르게 실행하고 테스트하려면 오픈 소스 스크립트를 사용하여 ci.android.com 에서 에뮬레이터 빌드를 다운로드하고 실행하세요. 이 스크립트는 macOS 및 Linux에서 테스트되었습니다.

이 스크립트를 사용하려면 Curl이 필요합니다.

스크립트를 실행하려면:

  1. launch_emu.sh 로컬 파일 이름으로 사용한다고 가정하고 launch_emu.sh 스크립트 내용을 로컬 파일에 복사합니다.
  2. 로컬 스크립트를 실행 가능하게 만듭니다. 예를 들어 chmod +x ./launch_emu.sh 실행합니다.
  3. ./launch_emu.sh -h 로 스크립트를 실행하여 사용 가능한 옵션을 확인하세요.
  4. ci.android.com 에서 aosp-main-throttled 분기로 이동하여 sdk_car_x86_64 녹색인 최근 빌드를 선택합니다. 예: 11370359. 빌드 정보가 표시되지 않으면 Google 계정에서 로그아웃한 후 다시 시도하세요.
  5. 빌드 ID가 포함된 에뮬레이터 관련 바이너리 파일을 다운로드하고 설치합니다. 예를 들어 ./launch_emu.sh -i -a 11370359 .
  6. 그런 다음 ./launch_emu.sh 사용하여 다운로드 및 설치된 에뮬레이터를 시작할 수 있습니다( -i 또는 -a 옵션을 사용하지 마십시오).
  7. 다른 빌드 ID를 다운로드하고 설치하려면 ./launch_emu.sh -c 실행하여 작업 공간을 정리한 다음 위의 4단계와 5단계를 반복하세요.

에뮬레이터를 시작할 때 Android 에뮬레이터 명령줄 시작 옵션 옵션을 지정하려면 -v 옵션을 사용하세요. 예:

  ./launch_emu.sh -v “-cores 4 -memory 6144 -no-snapshot"

AOSP 자동차 AVD 구축

AOSP 자동차 AVD를 빌드하는 프로세스는 휴대폰용 AVD 이미지 빌드 (예: aosp_car_x86_64)와 유사합니다.

  1. 개발 환경을 설정하고 분기를 식별하려면 소스 제어 도구를 참조하세요. 그런 다음 소스 다운로드 :
    ANDROID_BRANCH="android12L-release"
    REPO_URL="https://android.googlesource.com/platform/manifest"
    mkdir $ANDROID_BRANCH && cd $ANDROID_BRANCH && repo init -u $REPO_URL -b $ANDROID_BRANCH --partial-clone && repo sync -c -j8
    검토하세요.
  2. AVD 이미지 빌드:
    . build/envsetup.sh && lunch sdk_car_x86_64-userdebug && m -j32
  3. AVD 이미지 실행(필요에 따라 추가 명령줄 시작 옵션 추가):
    emulator &

    예를 들어:

    그림 1. Android 가상 에뮬레이터 화면

    이 프로세스에 대한 참고 사항:

    • 빌드 프로세스는 실제 기기용 Android를 빌드하는 데 필요한 프로세스와 동일하므로 소스를 다운로드한 후 빌드하는 데 약간의 시간이 필요합니다.
    • 다른 브랜치에서 작업하려면 $ANDROID_BRANCH 다른 브랜치/태그 로 설정하세요.
    • system.img 와 같은 AVD 이미지는 $ANDROID_PRODUCT_OUT 에 빌드됩니다. 주요 이미지에 대해 자세히 알아보려면 AVD 시스템 디렉터리를 참조하세요.
    • Android 트리에 미리 빌드된 에뮬레이터 바이너리가 에뮬레이터를 실행하는 데 사용되는 방법을 알아보려면 README 파일을 참조하세요.

자동차 AVD 만들기

새 자동차 AVD를 추가하는 것은 새 장치 추가 와 거의 동일합니다. 예를 들어 1660554는 새로운 avd_car AVD를 생성합니다.

자동차 AVD를 만들려면 다음 안내를 따르세요.

  1. 필요에 따라 회사 및 장치 폴더를 생성합니다. 이 예에서는 $ANDROID_BUILD_TOP/device/google_car/avd_car 사용합니다.
  2. AVD 빌드 방법을 정의하는 제품 makefile avd_car.mk 만듭니다.
  3. BoardConfig.mksource.properties 포함할 장치 폴더 avd_car_device 만듭니다.
  4. AndroidProducts.mk 에 새로운 makefile 과 새로운 lunch 선택을 추가하세요.
  5. 새로운 avd_car AVD를 빌드하고 실행하려면:
    . build/envsetup.sh && lunch acar-userdebug && m -j32 && emulator &
이제 새 AVD에서 대부분의 HMI 및 앱 기능을 프로토타입할 준비가 되었습니다.

AVD 이미지 zip 파일 압축

AVD를 압축하여 다른 사람과 공유하거나 다른 컴퓨터에서 사용할 수 있습니다. emu_img_zip.mk 사용하여 AVD 이미지 zip 파일을 생성합니다.

  1. AVD를 빌드한 후 emu_img_zip 대상으로 만듭니다:
    m emu_img_zip
  2. sdk-repo-linux-system-images 접두사가 붙은 AVD 이미지 zip 파일은 $ANDROID_PRODUCT_OUT 폴더에 생성됩니다.

AVD 커널 빌드

AVD 커널은 모두 사전 빌드된 이미지라는 점에서 다른 Android 커널과 유사합니다. 일반적으로 각 Android 릴리스의 표준 금붕어 커널 사전 빌드 이미지를 있는 그대로 사용할 수 있습니다.

커널 변경을 실험하려면 다음을 수행하십시오.

  1. 다음 일련의 지침을 실행하십시오:
    mkdir goldfish-kernel-54
    cd goldfish-kernel-54
    repo init -u https://android.googlesource.com/kernel/manifest -b
    common-android11-5.4
    repo sync
    BUILD_CONFIG=common/build.config.gki.x86_64 build/build.sh
    BUILD_CONFIG=common-modules/virtual-device/build.config.goldfish.x86_64
    build/build.sh
    ls -l ./out/android11-5.4/dist/
    
  2. AVD makefile에 따라 코드베이스의 커널 바이너리를 교체합니다. 예를 들어 x86_64-vendor.mk 에는 x86_64-kernel.mk 포함됩니다.

커널 코드와 구성은 다음과 같습니다.

안건
나뭇가지 common-android11-5.4 (Android 11에서 사용됨)
명백한 kernel/manifest/common-android11-5.4
공통 모듈/가상 장치 kernel/common-modules/virtual-device/android11-5.4
핵심 kernel/common/android11-5.4

새 장치 프로필 만들기

사용자가 Android 스튜디오 AVD 관리자에서 특정 AVD를 생성할 수 있도록 하려면 가상 기기 생성 및 관리를 참조하세요. 기기 제조업체는 AVD 이미지에 포함된 devices.xml 파일을 사용하여 화면 크기, DPI 등 자체 하드웨어 사양을 정의할 수 있습니다.

  • 예를 들어 automotive.xml 의 자동차 장치 프로필을 참조하세요.
  • HMI 개발 또는 프로토타입 제작을 위해 동일한 AVD 이미지에 대한 파일에 여러 장치를 추가할 수 있습니다.
  • [ABI] 폴더에 OEM AVD 이미지 zip 파일에 파일을 포함합니다. 예를 들어 x86_64 와 같습니다.
  • 장치 제조업체는 에뮬레이터 스킨을 만들 수도 있습니다. 예를 들어, 더 높은 충실도의 UX를 위해 추가 하드웨어 버튼을 정의합니다. 이는 개발자 워크플로우뿐만 아니라 UX 연구 및 검토와 같은 다른 작업에도 유용합니다.

AVD 이미지 XML 파일 만들기

기기 제조업체는 Android Studio용 AVD 이미지 XML 파일을 생성하여 다운로드할 수 있습니다.

  • 예를 들어 AAOS AVD 이미지 XML 파일 sys-img2-1.xml 참조하세요.
  • 기기 제조업체는 Android Emulator용 라이선스를 사용하여 대상 사용자를 위한 자체 OEM AVD 라이선스 계약(명예 시스템 사용)을 정의할 수 있습니다. Android Studio는 이러한 라이선스가 포함되면 사용자 합의를 얻습니다.

이미지를 생성하려면:

  1. AVD 이미지 zip 파일을 준비합니다.
  2. ${ANDROID_PRODUCT_OUT}/sdk-repo-linux-system-images-*.zip 압축을 풉니다.
  3. x86_64 폴더에 devices.xml 추가한 후 zip 파일로 압축하세요. 예를 들어 oem_avd_img_x86_64.zip 과 같습니다.
  4. oem-sys-img2-1.xml 업데이트합니다.
  5. zip 파일 이름, 크기 및 shasum을 업데이트합니다(샘플 XML 파일은 tools 에 제공됨).

예를 들어 Google Cloud Storage 에서 AVD를 호스팅하려면 스토리지 버킷 생성을 참조하세요.

AVD를 업로드하고 공개적으로 액세스할 수 있도록 하려면 데이터 공개를 참조하세요.

BUCKET_NAME="aaos-avd"
gsutil mb gs://$BUCKET_NAME
gsutil cp oem_avd_img_x86_64.zip gs://$BUCKET_NAME
gsutil cp oem-sys-img2-1.xml gs://$BUCKET_NAME
gsutil iam ch allUsers:objectViewer gs://$BUCKET_NAME

AVD 이미지 SDK 추가 기능 URL 형식은 https://storage.googleapis.com/$BUCKET_NAME/oem-sys-img2-1.xml 입니다. 예를 들어 BUCKET_NAME이 aaos-avd인 경우 URL은 https://storage.googleapis.com/aaos-avd/oem-sys-img2-1.xml 입니다.

Android Studio 사용자와 AVD 이미지 공유

사용자가 AVD 이미지를 다운로드하고 Android Studio에서 AVD를 사용할 수 있도록 SDK 추가 기능 XML 파일을 제공할 수 있습니다. 자세한 내용은 IDE 및 SDK 도구 업데이트를 참조하세요.

네트워크에서 AVD를 다운로드하려면:

  1. 서버에서 이미지 zip 파일과 XML 파일을 호스팅합니다.
  2. 대상 사용자에게 URL을 제공하십시오.
  3. ( 선택 사항 ) 사용자 이름과 비밀번호로 액세스를 제한합니다.

또는 개발 속도를 높이려면 AVD를 로컬 디렉터리에 다운로드하세요.

  1. XML 파일과 XML 파일에 지정된 모든 아티팩트를 ADDON_DIR 이라는 폴더(예: 모든 AVD 이미지 zip 파일)에 저장합니다.
  2. URL을 file://$ADDON_DIR/oem-sys-img2-1.xml 로 지정합니다.