Android वर्चुअल डिवाइस (एवीडी) का इस्तेमाल करने के लिए, Android एम्युलेटर ग्राफ़िकल यूज़र इंटरफ़ेस (जीयूआई) और कमांड लाइन इंटरफ़ेस (सीएलआई) के साथ काम करता है. आप आपके वातावरण के लिए सबसे अच्छा वर्कफ़्लो.
- वर्चुअल डिवाइसों को बनाना और मैनेज करना जीयूआई, ज़्यादातर ऐप्लिकेशन डेवलपर और उपयोगकर्ताओं के लिए उपलब्ध कराया गया एक आसान टूल है.
- एम्युलेटर शुरू करें कमांड लाइन से यह पावर उपयोगकर्ताओं और ऑटोमेशन के लिए, आसान तरीका उपलब्ध कराता है. उदाहरण के लिए, एक से ज़्यादा एवीडी सेट अप करना या लगातार टेस्टिंग और लगातार इंटिग्रेशन सेट अप करना. शुरू करने के लिए, यह देखें इसमें उदाहरण टूल).
प्री-बिल्ट का इस्तेमाल करके, एओएसपी कार का एवीडी लॉन्च करना
पहले से बनी एओएसपी कार एवीडी की मदद से, इसे तुरंत लॉन्च और टेस्ट करने के लिए, ओपन सोर्स स्क्रिप्ट का इस्तेमाल करके डाउनलोड करें
और इससे एम्युलेटर बिल्ड को लॉन्च किया जा सकता है.
ci.android.com
. स्क्रिप्ट की जांच यहां की गई है
macOS और Linux.
इस स्क्रिप्ट का इस्तेमाल करने के लिए, आपको Curl की ज़रूरत होगी.
स्क्रिप्ट चलाने के लिए:
- कॉपी करें
launch_emu.sh
यह मानते हुए कि आपlaunch_emu.sh
का उपयोग फ़ाइल का लोकल नाम. - अपनी लोकल स्क्रिप्ट को एक्ज़ीक्यूटेबल बनाएं. उदाहरण के लिए,
chmod +x ./launch_emu.sh
चलाएं. ./launch_emu.sh -h
की मदद से स्क्रिप्ट चलाकर, उपलब्ध विकल्प देखें.ci.android.com
पर, इस लिंक पर जाएंaosp-main-throttled
ब्रांच को चुनें और हाल ही में बनाया गया ऐसा बिल्ड चुनें जिसमेंsdk_car_x86_64
का रंग हरा है. उदाहरण के लिए, 11370359. अगर आपको बिल्ड नहीं दिखता है जानकारी, अपने Google खाते से लॉग आउट करें और पुनः प्रयास करें.- बिल्ड आईडी के साथ एम्युलेटर से जुड़ी बाइनरी फ़ाइलें डाउनलोड और इंस्टॉल करें. उदाहरण के लिए,
./launch_emu.sh -i -a 11370359
. - इसके बाद,
./launch_emu.sh
का इस्तेमाल करके, डाउनलोड और इंस्टॉल किए गए वर्शन को लॉन्च किया जा सकता है एम्युलेटर (-i
या-a
विकल्पों का इस्तेमाल न करें). - कोई दूसरा बिल्ड आईडी डाउनलोड और इंस्टॉल करने के लिए,
./launch_emu.sh -c
चलाकर, अपने पर क्लिक करें और फिर ऊपर दिए गए चौथे और चरण 5 को दोहराएं.
Android एम्युलेटर तय करने के लिए
कमांड-लाइन स्टार्टअप के विकल्प
एम्युलेटर लॉन्च करते समय, -v
विकल्प का इस्तेमाल करें. जैसे:
./launch_emu.sh -v “-cores 4 -memory 6144 -no-snapshot"अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
एओएसपी कार का एवीडी बनाएं
एओएसपी कार का एवीडी बनाने की प्रोसेस, फ़ोन के लिए एवीडी इमेज बनाना (उदाहरण के लिए, aosp_car_x86_64):
- डेवलपमेंट एनवायरमेंट को सेट अप करने और ब्रांच की पहचान करने के लिए, यह देखें
सोर्स कंट्रोल टूल. इसके बाद, देखें
सोर्स डाउनलोड करना:
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 - एवीडी इमेज बनाएं:
. build/envsetup.sh && lunch sdk_car_x86_64-userdebug && m -j32
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है - एवीडी इमेज चलाएं (कमांड-लाइन शुरू करने के अन्य विकल्प जोड़ें
ज़रूरत के हिसाब से):
emulator &
उदाहरण के लिए:
पहला डायग्राम. Android वर्चुअल एम्युलेटर की स्क्रीन
इस प्रोसेस के बारे में ज़रूरी जानकारी:
- बिल्ड की प्रोसेस वही है जो Android को बनाने के लिए ज़रूरी है को डाउनलोड करने और उसे बनाने के लिए थोड़ा समय दें.
- अन्य ब्रांच पर काम करने के लिए,
$ANDROID_BRANCH
को दूसरे ब्रांच पर सेट करें ब्रांच/टैग. - एवीडी इमेज, जैसे कि
system.img
,$ANDROID_PRODUCT_OUT
पर बनाई गई हैं. मुख्य इमेज के बारे में ज़्यादा जानने के लिए, यह देखें एवीडी सिस्टम डायरेक्ट्री. - ज़्यादा जानकारी के लिए, README फ़ाइल, ताकि यह पता लगाया जा सके कि आपके Android ट्री में पहले से बनी एम्युलेटर बाइनरी का इस्तेमाल इन कामों के लिए कैसे किया जाता है एम्युलेटर को चला सकते हैं.
कार का एवीडी बनाएं
नई कार का एवीडी जोड़ना करीब-करीब इसके जैसा है
नया डिवाइस जोड़ना. उदाहरण के लिए,
1660554
, एक नया avd_car
एवीडी बनाता है.
कार एवीडी बनाने के लिए:
- ज़रूरत के हिसाब से कंपनी और डिवाइस फ़ोल्डर बनाएं. इस उदाहरण में,
$ANDROID_BUILD_TOP/device/google_car/avd_car
. avd_car.mk
नाम से प्रॉडक्ट बनाएं. इससे एवीडी बनाने का तरीका पता चलता है.avd_car_device
ऐसा डिवाइस फ़ोल्डर बनाएं जिसमें फ़ोल्डर को सेव करना हैBoardConfig.mk
औरsource.properties
.- इसमें नया
makefile
और नयाlunch
विकल्प जोड़ेंAndroidProducts.mk
. avd_car
का नया एवीडी बनाने और उसे चलाने के लिए:. build/envsetup.sh && lunch acar-userdebug && m -j32 && emulator &
एवीडी इमेज की ज़िप फ़ाइल पैक करें
एवीडी को पैक करके, दूसरों के साथ शेयर किया जा सकता है या किसी दूसरे पर इस्तेमाल किया जा सकता है
कंप्यूटर पर सेव करें. emu_img_zip.mk
का इस्तेमाल करें
AVD इमेज ज़िप फ़ाइल जनरेट करने के लिए:
- एवीडी बनाने के बाद,
emu_img_zip
को टारगेट करें:m emu_img_zip
- AVD इमेज ज़िप फ़ाइल, जिसके पहले
sdk-repo-linux-system-images
है, यह है$ANDROID_PRODUCT_OUT
नाम के फ़ोल्डर में बनाया गया.
कोई AVD कर्नेल बनाएं
एवीडी कर्नेल, दूसरे Android कर्नेल की तरह होते हैं, जिनमें पहले से बनी इमेज होती हैं. आम तौर पर, स्टैंडर्ड गोल्डफ़िश कर्नेल के तौर पर पहले से बनी इमेज का इस्तेमाल किया जा सकता है, जैसा कि Android के हर रिलीज़ के लिए उपलब्ध है.
कर्नेल के बदलावों के साथ प्रयोग करने के लिए:
- निर्देशों की इस सीरीज़ को चलाएं:
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/
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है - एवीडी मेकफ़ाइल के हिसाब से, कोड बेस में कर्नेल बाइनरी को बदलें. उदाहरण के लिए,
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 Studio एवीडी मैनेजर में उपयोगकर्ताओं को एवीडी बनाने की सुविधा देने के लिए, यहां जाएं:
वर्चुअल डिवाइस बनाएं और उन्हें मैनेज करें.
डिवाइस बनाने वाली कंपनियां, हार्डवेयर की खास जानकारी खुद तय कर सकती हैं. जैसे, स्क्रीन का साइज़ और DPI,
AVD इमेज में शामिल devices.xml
फ़ाइल का इस्तेमाल करके.
- उदाहरण के लिए,
automotive.xml
में Automotive डिवाइस की प्रोफ़ाइलें देखें. - HMI डेवलपमेंट या प्रोटोटाइपिंग के लिए, फ़ाइल से ही कॉपी किया जा सकता है.
- OEM की AVD इमेज ज़िप फ़ाइल में,
[ABI]
फ़ोल्डर में फ़ाइल शामिल करें. उदाहरण के लिए,x86_64
के तौर पर. - डिवाइस निर्माता भी किसी उपयोगकर्ता की ओर से एम्युलेटर स्किन. उदाहरण के लिए, बेहतर फ़िडेलिटी UX के लिए हार्डवेयर के अतिरिक्त बटन तय करना. यह सिर्फ़ डेवलपर वर्कफ़्लो में नहीं, बल्कि UX रिसर्च जैसे दूसरे कामों में भी मददगार है और समीक्षा करें.
एवीडी इमेज की एक्सएमएल फ़ाइल बनाएं
डिवाइस मैन्युफ़ैक्चरर, Android Studio के लिए AVD इमेज की एक्सएमएल फ़ाइल बना सकते हैं, ताकि उसे डाउनलोड किया जा सके इसे.
- उदाहरण के लिए, AAOS एवीडी इमेज एक्सएमएल फ़ाइल,
sys-img2-1.xml
देखें. - डिवाइस बनाने वाली कंपनियां, टारगेट किए गए उपयोगकर्ताओं के लिए, OEM के एवीडी लाइसेंस का अपना कानूनी समझौता तय कर सकती हैं (ऑनर सिस्टम का इस्तेमाल करते हुए). Android पर अगर ऐसा लाइसेंस शामिल किया जाता है, तो Studio को उपयोगकर्ता की सहमति मिल जाती है.
इमेज बनाने के लिए:
- एक AVD इमेज ज़िप फ़ाइल तैयार करें.
${ANDROID_PRODUCT_OUT}/sdk-repo-linux-system-images-*.zip
को अनज़िप करें.devices.xml
कोx86_64
फ़ोल्डर में जोड़ें. इसके बाद, फ़ाइल को कंप्रेस करें एक ZIP फ़ाइल है. उदाहरण के लिए,oem_avd_img_x86_64.zip
के तौर पर.oem-sys-img2-1.xml
अपडेट करें.- ज़िप फ़ाइल का नाम, साइज़, और शसम अपडेट करें (एक्सएमएल फ़ाइलों के नमूने यहां दिए गए हैं
tools
).
उदाहरण के लिए, Google Cloud Storage पर एवीडी होस्ट करने के लिए, बनाना देखें स्टोरेज बकेट.
एवीडी को सार्वजनिक तौर पर उपलब्ध कराने और अपलोड करने के लिए, यहां जाएं डेटा को सार्वजनिक बनाना:
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 टूल के ऐड-ऑन का यूआरएल फ़ॉर्मैट ऐसा है: https://storage.googleapis.com/$BUCKET_NAME/oem-sys-img2-1.xml
.
उदाहरण के लिए, अगर BUCKET_NAME aaos-avd है, तो यूआरएल यह होगा: https://storage.googleapis.com/aaos-avd/oem-sys-img2-1.xml
.
Android Studio इस्तेमाल करने वालों के साथ एवीडी इमेज शेयर करना
ताकि आपके उपयोगकर्ता AVD इमेज डाउनलोड कर सकें और Android Studio के ज़रिए आपके AVD का इस्तेमाल कर सकें. कोई SDK ऐड-ऑन एक्सएमएल फ़ाइल उपलब्ध कराएं. जानकारी के लिए, यह देखें IDE और SDK टूल अपडेट करें.
नेटवर्क से एवीडी डाउनलोड करने के लिए:
- सर्वर पर इमेज की ZIP फ़ाइल और एक्सएमएल फ़ाइलें होस्ट करें.
- टारगेट किए गए लोगों को यूआरएल दें.
- (ज़रूरी नहीं) उपयोगकर्ता नाम और पासवर्ड से ऐक्सेस सीमित करें.
इसके अलावा, डेवलपमेंट की रफ़्तार को तेज़ करने के लिए, एवीडी को लोकल डायरेक्ट्री में डाउनलोड करें:
- एक्सएमएल फ़ाइल और सभी आर्टफ़ैक्ट को किसी फ़ोल्डर में सेव करें
(उदाहरण के लिए, सभी एवीडी इमेज ज़िप फ़ाइलें) को
ADDON_DIR
नाम दिया गया. - यूआरएल को
file://$ADDON_DIR/oem-sys-img2-1.xml
के तौर पर बताएं.