अपने Android प्रोजेक्ट में C और C++ कोड जोड़ें. इसके लिए, कोड को अपने प्रोजेक्ट मॉड्यूल में cpp
डायरेक्ट्री में डालें. प्रोजेक्ट बनाने पर, इस कोड को एक नेटिव लाइब्रेरी में कंपाइल किया जाता है. Gradle, इस लाइब्रेरी को आपके ऐप्लिकेशन के साथ पैकेज कर सकता है. इसके बाद, आपका Java या Kotlin कोड, Java नेटिव इंटरफ़ेस (JNI) की मदद से, नेटिव लाइब्रेरी में मौजूद फ़ंक्शन को कॉल कर सकता है. JNI फ़्रेमवर्क का इस्तेमाल करने के बारे में ज़्यादा जानने के लिए, Android के लिए JNI के बारे में सलाह पढ़ें.
Android Studio में CMake का इस्तेमाल किया जा सकता है. यह क्रॉस-प्लैटफ़ॉर्म प्रोजेक्ट के लिए मददगार है.
Android Studio में ndk-build
का भी इस्तेमाल किया जा सकता है. यह CMake से ज़्यादा तेज़ हो सकता है, लेकिन सिर्फ़ Android के साथ काम करता है. फ़िलहाल, एक ही मॉड्यूल में CMake और
ndk-build
, दोनों का इस्तेमाल नहीं किया जा सकता.
अपने Android Studio प्रोजेक्ट में किसी मौजूदा ndk-build
लाइब्रेरी को इंपोर्ट करने के लिए, Gradle को अपनी नेटिव लाइब्रेरी प्रोजेक्ट से लिंक करने का तरीका जानें.
इस पेज पर, ज़रूरी बिल्ड टूल की मदद से Android Studio सेट अप करने, C/C++ के साथ नया प्रोजेक्ट बनाने, और अपने प्रोजेक्ट में नई C/C++ फ़ाइलें जोड़ने का तरीका बताया गया है.
अगर आपको किसी मौजूदा प्रोजेक्ट में नेटिव कोड जोड़ना है, तो यह तरीका अपनाएं:
-
नई नेटिव सोर्स फ़ाइलें बनाएं और उन फ़ाइलों को अपने Android Studio प्रोजेक्ट में जोड़ें.
- अगर आपके पास पहले से ही नेटिव कोड है या आपको पहले से बनी नेटिव लाइब्रेरी को इंपोर्ट करना है, तो इस चरण को छोड़ दें.
-
अपने नेटिव सोर्स कोड को लाइब्रेरी में बनाने के लिए, CMake को कॉन्फ़िगर करें. अगर पहले से बनी या प्लैटफ़ॉर्म लाइब्रेरी को इंपोर्ट और लिंक किया जा रहा है, तो यह बिल्ड स्क्रिप्ट ज़रूरी है.
- अगर आपके पास कोई मौजूदा नेटिव लाइब्रेरी है जिसमें पहले से ही
CMakeLists.txt
बिल्ड स्क्रिप्ट है याndk-build
का इस्तेमाल किया जाता है और उसमेंAndroid.mk
बिल्ड स्क्रिप्ट शामिल है, तो यह चरण छोड़ें.
- अगर आपके पास कोई मौजूदा नेटिव लाइब्रेरी है जिसमें पहले से ही
-
अपनी CMake या
ndk-build
स्क्रिप्ट फ़ाइल का पाथ देकर, Gradle को कॉन्फ़िगर करें. Gradle, बंडल स्क्रिप्ट का इस्तेमाल करके सोर्स कोड को आपके Android Studio प्रोजेक्ट में इंपोर्ट करता है और आपकी नेटिव लाइब्रेरी को ऐप्लिकेशन में पैकेज करता है.
प्रोजेक्ट को कॉन्फ़िगर करने के बाद, JNI फ़्रेमवर्क का इस्तेमाल करके, Java या Kotlin कोड से अपने नेटिव फ़ंक्शन ऐक्सेस करें. अपना ऐप्लिकेशन बनाने और चलाने के लिए, चालू करें पर क्लिक करें.
ध्यान दें: अगर आपका मौजूदा प्रोजेक्ट, इस्तेमाल में न होने वाले
ndkCompile
टूल का इस्तेमाल करता है, तो CMake या
ndk-build
का इस्तेमाल करने के लिए माइग्रेट करें.
NDK और बिल्ड टूल डाउनलोड करना
अपने ऐप्लिकेशन के लिए नेटिव कोड को कंपाइल और डीबग करने के लिए, आपको इन कॉम्पोनेंट की ज़रूरत होगी:
- Android नेटिव डेवलपमेंट किट (NDK): यह एक टूलसेट है, जिसकी मदद से Android के साथ C और C++ कोड का इस्तेमाल किया जा सकता है. NDK, प्लैटफ़ॉर्म लाइब्रेरी उपलब्ध कराता है. इनकी मदद से, नेटिव ऐक्टिविटी मैनेज की जा सकती हैं. साथ ही, सेंसर और टच इनपुट जैसे डिवाइस के फ़िज़िकल कॉम्पोनेंट को ऐक्सेस किया जा सकता है.
-
CMake: यह एक बाहरी बिल्ड टूल है, जो आपकी नेटिव लाइब्रेरी बनाने के लिए, Gradle के साथ काम करता है. अगर आपको सिर्फ़
ndk-build
का इस्तेमाल करना है, तो आपको इस कॉम्पोनेंट की ज़रूरत नहीं है. - LLDB: Android Studio में मौजूद वह डीबगर जो नेटिव कोड को डीबग करता है.
इन कॉम्पोनेंट को इंस्टॉल करने के बारे में जानने के लिए, NDK और CMake इंस्टॉल और कॉन्फ़िगर करना लेख पढ़ें.
C/C++ के साथ काम करने वाला नया प्रोजेक्ट बनाना
नेटिव कोड के साथ काम करने वाला नया प्रोजेक्ट बनाने के लिए, Android Studio में कोई दूसरा प्रोजेक्ट बनाने की प्रोसेस से मिलती-जुलती प्रोसेस अपनाएं. हालांकि, इसमें एक और चरण शामिल होता है:
- विज़र्ड के अपना प्रोजेक्ट चुनें सेक्शन में, नेटिव C++ प्रोजेक्ट टाइप चुनें.
- आगे बढ़ें पर क्लिक करें.
- विज़र्ड के अगले सेक्शन में, बाकी सभी फ़ील्ड भरें.
- आगे बढ़ें पर क्लिक करें.
-
विजर्ड के C++ सहायता को पसंद के मुताबिक बनाएं सेक्शन में, C++ स्टैंडर्ड फ़ील्ड की मदद से, अपने प्रोजेक्ट को पसंद के मुताबिक बनाया जा सकता है.
- ड्रॉप-डाउन सूची का इस्तेमाल करके, C++ के किस स्टैंडर्ड का इस्तेमाल करना है, यह चुनें. टूलचेन के लिए डिफ़ॉल्ट चुनने पर, CMake की डिफ़ॉल्ट सेटिंग का इस्तेमाल किया जाता है.
- पूरा करें पर क्लिक करें.
Android Studio आपका नया प्रोजेक्ट बनाने के बाद, IDE की बाईं ओर मौजूद प्रोजेक्ट पैनल खोलें और मेन्यू से Android व्यू चुनें. जैसा कि पहले चित्र में दिखाया गया है, Android Studio, cpp ग्रुप को जोड़ता है:
ध्यान दें: यह व्यू, डिस्क पर मौजूद फ़ाइलों की असल हैरारकी नहीं दिखाता. हालांकि, यह आपके प्रोजेक्ट में नेविगेट करने की प्रोसेस को आसान बनाने के लिए, मिलती-जुलती फ़ाइलों को एक साथ ग्रुप में रखता है.
cpp ग्रुप में, आपको अपने प्रोजेक्ट का हिस्साndk-build
नए प्रोजेक्ट के लिए, Android Studio एक सैंपल C++ सोर्स फ़ाइल, native-lib.cpp
बनाता है और उसे आपके ऐप्लिकेशन मॉड्यूल की src/main/cpp/
डायरेक्ट्री में डालता है. इस सैंपल कोड में, stringFromJNI()
नाम का एक आसान C++ फ़ंक्शन दिया गया है. यह फ़ंक्शन "Hello from C++"
स्ट्रिंग दिखाता है. नई नेटिव सोर्स फ़ाइलें बनाने के तरीके के बारे में बताने वाले सेक्शन में, अपने प्रोजेक्ट में अतिरिक्त सोर्स फ़ाइलें जोड़ने का तरीका जानें.
जिस तरह build.gradle
फ़ाइलें, Gradle को आपके ऐप्लिकेशन को बनाने का तरीका बताती हैं उसी तरह CMake और ndk-build
को आपकी नेटिव लाइब्रेरी बनाने का तरीका जानने के लिए, बिल्ड स्क्रिप्ट की ज़रूरत होती है. नए प्रोजेक्ट के लिए, Android Studio एक CMake बिल्ड स्क्रिप्टCMakeLists.txt
बनाता है और उसे आपके मॉड्यूल की रूट डायरेक्ट्री में डाल देता है.
इस बिल्ड स्क्रिप्ट के कॉन्टेंट के बारे में ज़्यादा जानने के लिए, CMake कॉन्फ़िगर करना लेख पढ़ें.
सैंपल ऐप्लिकेशन बनाना और चलाना
चालू करें पर क्लिक करने पर, Android Studio एक ऐप्लिकेशन बनाता है और उसे लॉन्च करता है. यह ऐप्लिकेशन आपके Android डिवाइस या एमुलेटर पर "C++ से नमस्ते" टेक्स्ट दिखाता है. यहां दी गई खास जानकारी में, सैंपल ऐप्लिकेशन को बनाने और चलाने के लिए होने वाले इवेंट के बारे में बताया गया है:
- Gradle, आपकी बाहरी बिल्ड स्क्रिप्ट को कॉल करता है,
CMakeLists.txt
. - CMake, C++ सोर्स फ़ाइल
native-lib.cpp
को शेयर की गई ऑब्जेक्ट लाइब्रेरी में कंपाइल करने के लिए, बिल्ड स्क्रिप्ट में दिए गए निर्देशों का पालन करता है और इसेlibnative-lib.so
नाम देता है. इसके बाद, Gradle इसे ऐप्लिकेशन में पैकेज करता है. - रनटाइम के दौरान, ऐप्लिकेशन का
MainActivity
,System.loadLibrary()
का इस्तेमाल करके नेटिव लाइब्रेरी को लोड करता है. लाइब्रेरी का नेटिव फ़ंक्शन,stringFromJNI()
, अब ऐप्लिकेशन के लिए उपलब्ध है. -
MainActivity.onCreate()
,stringFromJNI()
को कॉल करता है, जो"Hello from C++"
दिखाता है औरTextView
को अपडेट करने के लिए इसका इस्तेमाल करता है.
यह पुष्टि करने के लिए कि Gradle, ऐप्लिकेशन में नेटिव लाइब्रेरी को पैकेज करता है, APK विश्लेषक का इस्तेमाल करें:
- बिल्ड > बंडल / APK बनाना > APK बनाना चुनें.
- बिल्ड करें > APK का विश्लेषण करें चुनें.
app/build/outputs/
डायरेक्ट्री से APK या AAB चुनें और ठीक है पर क्लिक करें.- जैसा कि दूसरे चित्र में दिखाया गया है,
lib/<ABI>/
में APK विश्लेषक विंडो मेंlibnative-lib.so
दिख सकता है.
सलाह: अगर आपको नेटिव कोड का इस्तेमाल करने वाले अन्य Android ऐप्लिकेशन आज़माने हैं, तो फ़ाइल > नया > सैंपल इंपोर्ट करें पर क्लिक करें. इसके बाद, Ndk सूची से कोई सैंपल प्रोजेक्ट चुनें.
नई C/C++ सोर्स फ़ाइलें बनाना
किसी मौजूदा प्रोजेक्ट में नई C/C++ सोर्स फ़ाइलें जोड़ने के लिए, यह तरीका अपनाएं:
- अगर आपके ऐप्लिकेशन के मुख्य सोर्स सेट में पहले से कोई
cpp/
डायरेक्ट्री नहीं है, तो यहां दिया गया तरीका अपनाकर एक डायरेक्ट्री बनाएं: - IDE की बाईं ओर मौजूद प्रोजेक्ट पैनल खोलें और मेन्यू से प्रोजेक्ट व्यू चुनें.
- your-module > src पर जाएं.
- main डायरेक्ट्री पर राइट क्लिक करें और नया > डायरेक्ट्री चुनें.
- डायरेक्ट्री के नाम के तौर पर
cpp
डालें और ठीक है पर क्लिक करें. cpp/
डायरेक्ट्री पर राइट क्लिक करें और नया > C/C++ सोर्स फ़ाइल चुनें.- अपनी सोर्स फ़ाइल के लिए कोई नाम डालें, जैसे कि
native-lib
. - टाइप मेन्यू से, अपनी सोर्स फ़ाइल के लिए फ़ाइल एक्सटेंशन चुनें, जैसे कि
.cpp
.- मेन्यू में अन्य फ़ाइल टाइप जोड़ने के लिए, फ़ाइल टाइप में बदलाव करें
पर क्लिक करें. जैसे,
.cxx
या.hxx
. इसके बाद, आपको एक डायलॉग बॉक्स दिखेगा. उसमें, नए फ़ाइल एक्सटेंशन डायलॉग बॉक्स में, सोर्स एक्सटेंशन और हेडर एक्सटेंशन मेन्यू से कोई दूसरा फ़ाइल एक्सटेंशन चुनें और ठीक है पर क्लिक करें.
- मेन्यू में अन्य फ़ाइल टाइप जोड़ने के लिए, फ़ाइल टाइप में बदलाव करें
पर क्लिक करें. जैसे,
- हेडर फ़ाइल बनाने के लिए, इससे जुड़ा हेडर बनाएं चेकबॉक्स चुनें.
- ठीक है पर क्लिक करें.
अपने प्रोजेक्ट में नई C/C++ फ़ाइलें जोड़ने के बाद भी, आपको अपनी नेटिव लाइब्रेरी में फ़ाइलें शामिल करने के लिए, CMake को कॉन्फ़िगर करना होगा.
अन्य संसाधन
अपने ऐप्लिकेशन में C/C++ कोड इस्तेमाल करने के बारे में ज़्यादा जानने के लिए, यहां दिया गया संसाधन देखें.
कोडलैब
- Android Studio की मदद से Hello-CMake बनाएं इस कोडलैब में, Android NDK प्रोजेक्ट डेवलप करने के लिए, Android Studio के CMake टेंप्लेट का इस्तेमाल करने का तरीका बताया गया है.