MediaExtractorCompat ক্লাসটি প্ল্যাটফর্মের MediaExtractor ক্লাসের একটি ড্রপ-ইন প্রতিস্থাপন এবং এটি অভিন্ন API এবং কার্যকারিতা প্রদান করে। এটি একটি ডেটা উৎস থেকে ডিমাক্সড, সাধারণত এনকোডেড, মিডিয়া ডেটা নিষ্কাশন সহজতর করে।
এটি একটি কন্টেইনার ফাইল (যেমন MP4 বা MKV) কে তার পৃথক ট্র্যাকগুলিতে , যেমন ভিডিও, অডিও এবং সাবটাইটেলে আলাদা করে। এক্সট্র্যাক্টর তারপর এই ট্র্যাকগুলি থেকে কাঁচা, এনকোডেড ডেটা নমুনার ক্রম হিসাবে (উদাহরণস্বরূপ, একটি একক সংকুচিত ভিডিও ফ্রেম বা অডিওর ব্লক) ডিকোডারে পাঠানোর আগে পড়ে।
সাধারণ ব্যবহারের ক্ষেত্রে অন্তর্ভুক্ত:
- ট্রান্সকোডিং বা রিমাক্সিং : কোডেক (ট্রান্সকোডিং) পরিবর্তন করার জন্য অথবা স্ট্রিমগুলিকে একটি নতুন পাত্রে (রিমাক্সিং) পুনরায় প্যাকেজ করার জন্য একটি ট্র্যাক থেকে এনকোড করা নমুনা পড়া, যেমন একটি MP4 ফাইলকে MKV তে রূপান্তর করা।
- নির্বাচনী কন্টেন্ট নিষ্কাশন : একটি একক ট্র্যাক বিচ্ছিন্ন করা এবং সংরক্ষণ করা, যেমন একটি ভিডিও ফাইল থেকে একটি অডিও স্ট্রিম নিষ্কাশন করা।
- নিম্ন-স্তরের ডিবাগিং : ফাইল দুর্নীতি, টাইমস্ট্যাম্প সমস্যা, বা অন্যান্য সমস্যা ডিবাগ করার জন্য পৃথক নমুনা পরিদর্শন করা।
- কাস্টম প্লেয়ার তৈরি করা : বিশেষ ব্যবহারের ক্ষেত্রে, মিডিয়া পাইপলাইনের উপর সম্পূর্ণ নিয়ন্ত্রণ সহ একটি কাস্টম প্লেয়ার তৈরি করা।
সংক্ষিপ্ত বিবরণ
নিম্নলিখিত কোড নমুনাটি MediaExtractorCompat কীভাবে ব্যবহার করবেন তা দেখায়:
কোটলিন
fun extractSamples(context: Context, mediaPath: String) { val extractor = MediaExtractorCompat(context) try { // 1. Setup the extractor extractor.setDataSource(mediaPath) // Find and select available tracks for (i in 0 until extractor.trackCount) { val format = extractor.getTrackFormat(i) extractor.selectTrack(i) } // 2. Process samples val buffer = ByteBuffer.allocate(10 * 1024 * 1024) while (true) { // Read an encoded sample into the buffer. val bytesRead = extractor.readSampleData(buffer, 0) if (bytesRead < 0) break // Access sample metadata val trackIndex = extractor.sampleTrackIndex val presentationTimeUs = extractor.sampleTime val sampleSize = extractor.sampleSize extractor.advance() } } catch (e: IOException) { handleFailure(e) } finally { // 3. Release the extractor extractor.release() } }
জাভা
public void extractSamples(Context context, String mediaPath) { MediaExtractorCompat extractor = new MediaExtractorCompat(context); try { // 1. Setup the extractor extractor.setDataSource(mediaPath); // Find and select available tracks for (int i = 0; i < extractor.getTrackCount(); i++) { MediaFormat format = extractor.getTrackFormat(i); extractor.selectTrack(i); } // 2. Process samples ByteBuffer buffer = ByteBuffer.allocate(10 * 1024 * 1024); while (true) { // Read an encoded sample into the buffer. int bytesRead = extractor.readSampleData(buffer, 0); if (bytesRead < 0) { break; } // Access sample metadata int trackIndex = extractor.getSampleTrackIndex(); long presentationTimeUs = extractor.getSampleTime(); long sampleSize = extractor.getSampleSize(); extractor.advance(); } } catch (IOException e) { handleFailure(e); } finally { // 3. Release the extractor extractor.release(); } }