हमारा सुझाव है कि 27 मार्च, 2025 से AOSP को बनाने और उसमें योगदान देने के लिए, aosp-main
के बजाय android-latest-release
का इस्तेमाल करें. ज़्यादा जानकारी के लिए, AOSP में हुए बदलाव लेख पढ़ें.
ऑडियो
संग्रह की मदद से व्यवस्थित रहें
अपनी प्राथमिकताओं के आधार पर, कॉन्टेंट को सेव करें और कैटगरी में बांटें.
Android का ऑडियो हार्डवेयर एब्स्ट्रैक्शन लेयर (एचएएल), android.media में मौजूद, ऑडियो से जुड़े फ़्रेमवर्क के एपीआई को ऑडियो ड्राइवर और हार्डवेयर से जोड़ता है. इस सेक्शन में, लागू करने के निर्देश और परफ़ॉर्मेंस को बेहतर बनाने के लिए सलाह शामिल हैं.
Android ऑडियो आर्किटेक्चर से यह तय होता है कि ऑडियो फ़ंक्शन को कैसे लागू किया जाता है. साथ ही, यह लागू करने में शामिल काम के सोर्स कोड की जानकारी भी देता है.
पहली इमेज. Android ऑडियो आर्किटेक्चर
-
ऐप्लिकेशन फ़्रेमवर्क
-
ऐप्लिकेशन फ़्रेमवर्क में ऐप्लिकेशन कोड शामिल होता है. यह ऑडियो हार्डवेयर के साथ इंटरैक्ट करने के लिए, android.media एपीआई का इस्तेमाल करता है. अंदरूनी तौर पर, यह कोड ऑडियो हार्डवेयर के साथ इंटरैक्ट करने वाले नेटिव कोड को ऐक्सेस करने के लिए, उससे जुड़ी JNI glue क्लास को कॉल करता है.
-
JNI
-
android.media से जुड़ा JNI कोड, ऑडियो हार्डवेयर को ऐक्सेस करने के लिए, निचले लेवल के नेटिव कोड को कॉल करता है. JNI,
frameworks/base/core/jni/
और
frameworks/base/media/jni
में मौजूद है.
-
नेटिव फ़्रेमवर्क
-
नेटिव फ़्रेमवर्क, android.media पैकेज के बराबर नेटिव सुविधा देता है. यह मीडिया सर्वर की ऑडियो से जुड़ी सेवाओं को ऐक्सेस करने के लिए, Binder IPC प्रॉक्सी को कॉल करता है.
नेटिव फ़्रेमवर्क कोड
frameworks/av/media/libmedia
में मौजूद है.
-
Binder IPC
-
Binder IPC प्रॉक्सी, प्रोसेस की सीमाओं के बीच कम्यूनिकेशन को आसान बनाते हैं. प्रोक्सी,
frameworks/av/media/libmedia
में मौजूद होती हैं और "I" अक्षर से शुरू होती हैं.
-
मीडिया सर्वर
-
मीडिया सर्वर में ऑडियो सेवाएं होती हैं. ये असल कोड होते हैं, जो आपके एचएएल लागू करने के साथ इंटरैक्ट करते हैं. मीडिया सर्वर,
frameworks/av/services/audioflinger
में मौजूद है.
-
HAL
-
एचएएल, स्टैंडर्ड इंटरफ़ेस तय करता है. ऑडियो सेवाएं इस इंटरफ़ेस का इस्तेमाल करती हैं. साथ ही, आपको अपने ऑडियो हार्डवेयर को सही तरीके से काम करने के लिए, यह इंटरफ़ेस लागू करना होगा. ज़्यादा जानकारी के लिए, ऑडियो HAL इंटरफ़ेस देखें. साथ ही, HAL वर्शन डायरेक्ट्री की
*.hal
फ़ाइलों में मौजूद टिप्पणियां देखें.
-
कर्नेल ड्राइवर
-
ऑडियो ड्राइवर, आपके हार्डवेयर और एचएएल लागू करने के साथ इंटरैक्ट करता है. Advanced Linux Sound Architecture (ALSA), Open Sound System (OSS) या पसंद के मुताबिक ड्राइवर का इस्तेमाल किया जा सकता है. HAL, ड्राइवर के हिसाब से काम नहीं करता.
ध्यान दें: अगर ALSA का इस्तेमाल किया जाता है, तो हमारा सुझाव है कि ड्राइवर के उपयोगकर्ता वाले हिस्से के लिए external/tinyalsa
का इस्तेमाल करें. ऐसा इसलिए, क्योंकि यह लाइसेंस के साथ काम करता है (स्टैंडर्ड यूज़र-मोड लाइब्रेरी का लाइसेंस GPL है).
-
Open SL ES पर आधारित Android नेटिव ऑडियो (दिखाया नहीं गया)
-
यह एपीआई,
Android NDK के हिस्से के तौर पर उपलब्ध है और यह android.media के जैसे ही आर्किटेक्चर लेवल पर है.
इस पेज पर मौजूद कॉन्टेंट और कोड सैंपल कॉन्टेंट के लाइसेंस में बताए गए लाइसेंस के हिसाब से हैं. Java और OpenJDK, Oracle और/या इससे जुड़ी हुई कंपनियों के ट्रेडमार्क या रजिस्टर किए हुए ट्रेडमार्क हैं.
आखिरी बार 2025-07-27 (UTC) को अपडेट किया गया.
[[["समझने में आसान है","easyToUnderstand","thumb-up"],["मेरी समस्या हल हो गई","solvedMyProblem","thumb-up"],["अन्य","otherUp","thumb-up"]],[["वह जानकारी मौजूद नहीं है जो मुझे चाहिए","missingTheInformationINeed","thumb-down"],["बहुत मुश्किल है / बहुत सारे चरण हैं","tooComplicatedTooManySteps","thumb-down"],["पुराना","outOfDate","thumb-down"],["अनुवाद से जुड़ी समस्या","translationIssue","thumb-down"],["सैंपल / कोड से जुड़ी समस्या","samplesCodeIssue","thumb-down"],["अन्य","otherDown","thumb-down"]],["आखिरी बार 2025-07-27 (UTC) को अपडेट किया गया."],[],[],null,["# Audio\n\nAndroid's audio Hardware Abstraction Layer (HAL) connects the higher-level,\naudio-specific framework APIs in [android.media](http://developer.android.com/reference/android/media/package-summary.html) to the underlying audio driver and\nhardware. This section includes implementation instructions and tips for\nimproving performance.\n\n\nAndroid audio architecture defines how audio functionality is implemented and\npoints to the relevant source code involved in the implementation.\n\n\n**Figure 1.** Android audio architecture\n\n\nApplication framework\n:\n The application framework includes the app code, which uses the [android.media](http://developer.android.com/reference/android/media/package-summary.html) APIs to\n interact with audio hardware. Internally, this code calls corresponding JNI glue\n classes to access the native code that interacts with audio hardware.\n\n\nJNI\n:\n The JNI code associated with [android.media](http://developer.android.com/reference/android/media/package-summary.html) calls lower level native code to access audio\n hardware. JNI is located in `frameworks/base/core/jni/` and\n `frameworks/base/media/jni`.\n\n\nNative framework\n:\n The native framework provides a native equivalent to the [android.media](http://developer.android.com/reference/android/media/package-summary.html) package, calling\n Binder IPC proxies to access the audio-specific services of the media server.\n Native framework code is located in `frameworks/av/media/libmedia`.\n\n\nBinder IPC\n:\n Binder IPC proxies facilitate communication over process boundaries. Proxies are\n located in `frameworks/av/media/libmedia` and begin with the letter\n \"I\".\n\n\nMedia server\n:\n The media server contains audio services, which are the actual code that\n interacts with your HAL implementations. The media server is located in\n `frameworks/av/services/audioflinger`.\n\n\nHAL\n:\n The HAL defines the standard interface that audio services call into and that\n you must implement for your audio hardware to function correctly. For more details, refer to the [audio HAL\n interface](https://android.googlesource.com/platform/hardware/interfaces/+/refs/heads/android16-release/audio/) and comments in the `*.hal` files of the corresponding HAL version directory.\n\n\nKernel driver\n\n: The audio driver interacts with your hardware and HAL implementation. You can use Advanced Linux Sound Architecture (ALSA), Open Sound System (OSS), or a custom driver (HAL is driver-agnostic). **Note** : If you use ALSA, we recommend\n `external/tinyalsa` for the user portion of the driver because of its\n compatible licensing (the standard user-mode library is GPL-licensed).\n\n\nAndroid native audio based on Open SL ES *(not shown)*\n:\n This API is exposed as part of\n [Android NDK](https://developer.android.com/tools/sdk/ndk/index.html)\n and is at the same architecture level as\n [android.media](http://developer.android.com/reference/android/media/package-summary.html)."]]