एचडीआर या हाई डाइनैमिक रेंज, रंगों की एक बड़ी रेंज और सबसे ज़्यादा चमकदार सफ़ेद रंग और सबसे गहरे काले रंग के बीच ज़्यादा कंट्रास्ट उपलब्ध कराता है. इससे वीडियो की क्वालिटी ऐसी होती है जैसी आंखों से दिखती है.
अपने ऐप्लिकेशन में एचडीआर वीडियो चलाने की सुविधा सेट अप की जा सकती है, ताकि एचडीआर वीडियो कॉन्टेंट को देखा और चलाया जा सके.
इस लेख में यह माना गया है कि आपने अपने ऐप्लिकेशन में वीडियो चलाने की बुनियादी सुविधा पहले ही जोड़ ली है. वीडियो चलाने के बारे में ज़्यादा जानकारी के लिए, ExoPlayer का दस्तावेज़ देखें.
डिवाइस से जुड़ी ज़रूरी शर्तें
सभी Android डिवाइसों पर एचडीआर में वीडियो चलाने की सुविधा काम नहीं करती. अपने ऐप्लिकेशन में एचडीआर वीडियो कॉन्टेंट चलाने से पहले, यह पता लगाएं कि आपका डिवाइस इन ज़रूरी शर्तों को पूरा करता है या नहीं:
- Android 7.0 या इसके बाद के वर्शन (एपीआई लेयर 24) को टारगेट करता हो.
- एचडीआर क्वालिटी के वीडियो के साथ काम करने वाला डिकोडर हो और एचडीआर क्वालिटी के वीडियो के साथ काम करने वाले डिसप्ले का ऐक्सेस हो.
देखें कि एचडीआर प्लेबैक की सुविधा उपलब्ध है या नहीं
डिसप्ले की एचडीआर क्षमताओं के बारे में क्वेरी करने के लिए, Display.getHdrCapabilities()
का इस्तेमाल करें. यह तरीका, डिसप्ले के लिए एचडीआर की सुविधा के साथ काम करने वाली प्रोफ़ाइलों और ल्यूमिनेंस रेंज के बारे में जानकारी देता है.
यहां दिया गया कोड यह जांच करता है कि डिवाइस पर HLG10 फ़ॉर्मैट में वीडियो चलाया जा सकता है या नहीं. Android 13 से, डिवाइस बनाने वाली कंपनियों को यह पक्का करना होगा कि उनके डिवाइस में एचडीआर वीडियो चलाने की सुविधा हो. साथ ही, डिवाइस में कम से कम HLG10 स्टैंडर्ड काम करता हो:
Kotlin
// Check if display supports the HDR type val capabilities = display?.hdrCapabilities?.supportedHdrTypes ?: intArrayOf() if (!capabilities.contains(HDR_TYPE_HLG)) { throw RuntimeException("Display does not support desired HDR type"); }
Java
// Check if display supports the HDR type int[] list = getDisplay().getHdrCapabilities().getSupportedHdrTypes(); Listcapabilities = Arrays.stream(list).boxed().collect(Collectors.toList()); if (!capabilities.contains(HDR_TYPE_HLG)) { throw new RuntimeException("Display does not support desired HDR type"); }
अपने ऐप्लिकेशन में एचडीआर प्लेबैक की सुविधा सेट अप करना
अगर आपका ऐप्लिकेशन ExoPlayer का इस्तेमाल करता है, तो उसमें डिफ़ॉल्ट रूप से एचडीआर में वीडियो चलाने की सुविधा होती है. अगले चरणों के लिए, एचडीआर प्लेबैक की सुविधा उपलब्ध है या नहीं, यह देखना लेख पढ़ें.
अगर आपका ऐप्लिकेशन ExoPlayer का इस्तेमाल नहीं करता है, तो SurfaceView
के ज़रिए MediaCodec
का इस्तेमाल करके, एचडीआर वीडियो चलाने की सुविधा सेट अप करें.
SurfaceView का इस्तेमाल करके MediaCodec सेट अप करना
SurfaceView
का इस्तेमाल करके, MediaCodec
चलाने का स्टैंडर्ड फ़्लो सेट अप करें. इससे, एचडीआर वीडियो कॉन्टेंट को बिना किसी खास सेटिंग के दिखाया जा सकता है:
MediaCodec
: एचडीआर वीडियो कॉन्टेंट को डिकोड करता है.SurfaceView
: एचडीआर वीडियो कॉन्टेंट दिखाता है.
यहां दिया गया कोड यह जांच करता है कि कोडेक, एचडीआर प्रोफ़ाइल के साथ काम करता है या नहीं. इसके बाद, SurfaceView
का इस्तेमाल करके MediaCodec
को सेट अप करता है:
Kotlin
// Check if there's a codec that supports the specific HDR profile val list = MediaCodecList(MediaCodecList.REGULAR_CODECS) var format = MediaFormat() /* media format from the container */; format.setInteger(MediaFormat.KEY_PROFILE, MediaCodecInfo.CodecProfileLevel.AV1ProfileMain10) val codecName = list.findDecoderForFormat (format) ?: throw RuntimeException ("No codec supports the format") // Here is a standard MediaCodec playback flow val codec: MediaCodec = MediaCodec.createByCodecName(codecName); val surface: Surface = surfaceView.holder.surface val callback: MediaCodec.Callback = (object : MediaCodec.Callback() { override fun onInputBufferAvailable(codec: MediaCodec, index: Int) { queue.offer(index) } override fun onOutputBufferAvailable( codec: MediaCodec, index: Int, info: MediaCodec.BufferInfo ) { codec.releaseOutputBuffer(index, timestamp) } override fun onError(codec: MediaCodec, e: MediaCodec.CodecException) { // handle error } override fun onOutputFormatChanged( codec: MediaCodec, format: MediaFormat ) { // handle format change } }) codec.setCallback(callback) codec.configure(format, surface, crypto, 0 /* flags */) codec.start() while (/* until EOS */) { val index = queue.poll() val buffer = codec.getInputBuffer(index) buffer?.put(/* write bitstream */) codec.queueInputBuffer(index, offset, size, timestamp, flags) } codec.stop() codec.release()
Java
// Check if there's a codec that supports the specific HDR profile MediaCodecList list = new MediaCodecList(MediaCodecList.REGULAR_CODECS); MediaFormat format = /* media format from the container */; format.setInteger( MediaFormat.KEY_PROFILE, CodecProfileLevel.AV1ProfileMain10); String codecName = list.findDecoderForFormat(format); if (codecName == null) { throw new RuntimeException("No codec supports the format"); } // Below is a standard MediaCodec playback flow MediaCodec codec = MediaCodec.getCodecByName(codecName); Surface surface = surfaceView.getHolder().getSurface(); MediaCodec.Callback callback = new MediaCodec.Callback() { @Override void onInputBufferAvailable(MediaCodec codec, int index) { queue.offer(index); } @Override void onOutputBufferAvailable(MediaCodec codec, int index) { // release the buffer for render codec.releaseOutputBuffer(index, timestamp); } @Override void onOutputFormatChanged(MediaCodec codec, MediaFormat format) { // handle format change } @Override void onError(MediaCodec codec, MediaCodec.CodecException ex) { // handle error } }; codec.setCallback(callback); codec.configure(format, surface, crypto, 0 /* flags */); codec.start(); while (/* until EOS */) { int index = queue.poll(); ByteBuffer buffer = codec.getInputBuffer(index); buffer.put(/* write bitstream */); codec.queueInputBuffer(index, offset, size, timestamp, flags); } codec.stop(); codec.release();
SurfaceView
का इस्तेमाल करके लागू करने के ज़्यादा MediaCodec
तरीकों के लिए, Android Camera के सैंपल देखें.
संसाधन
HDR वीडियो चलाने के बारे में ज़्यादा जानने के लिए, यहां दिए गए संसाधन देखें:
एचडीआर
- एचडीआर वीडियो कैप्चर करना: Camera2 API का इस्तेमाल करके, एचडीआर वीडियो कैप्चर करने की सुविधा सेट अप करने का तरीका जानें.
- Github पर Camera2Video का सैंपल: एचडीआर कैप्चर और प्लेबैक की सुविधा वाला ऐप्लिकेशन देखें.
मीडिया
- Media API के बारे में जानकारी: Media API के बारे में ज़्यादा जानें.
- ExoPlayer: ExoPlayer लाइब्रेरी के साथ अपना ऐप्लिकेशन सेट अप करने का तरीका जानें.