FrameExtractor ক্লাসটি MediaItem থেকে ডিকোড করা ফ্রেমগুলি বের করার একটি কার্যকর উপায় প্রদান করে।
সাধারণ ব্যবহারের ক্ষেত্রে অন্তর্ভুক্ত:
- থাম্বনেইল তৈরি করা : ভিডিও গ্যালারি বা সিক বারের জন্য উচ্চমানের থাম্বনেইল তৈরি করা।
- ভিডিও এডিটিং প্রিভিউ : একটি এডিটর টাইমলাইনে সুনির্দিষ্ট ফ্রেম প্রিভিউ প্রদর্শন করা, ব্যবহারকারীদের বিষয়বস্তু অনুসন্ধান করতে এবং ফ্রেমগুলি সঠিকভাবে কল্পনা করতে দেয়।
- নিষ্কাশনের সময় সরাসরি স্কেলিং, ক্রপিং বা ঘূর্ণনের মতো রূপান্তর প্রয়োগ করা , প্রক্রিয়াকরণের পরে পৃথক পদক্ষেপ এড়ানো।
- বিষয়বস্তু বিশ্লেষণ : দৃশ্য সনাক্তকরণ, বস্তু সনাক্তকরণ, বা মান নিয়ন্ত্রণের মতো কাজের জন্য বিশ্লেষণ পাইপলাইনে পাঠানোর জন্য বিরতিতে ফ্রেমগুলি বের করা।
সংক্ষিপ্ত বিবরণ
FrameExtractor ব্যবহার একটি দুই ধাপের প্রক্রিয়া:
- এক্সট্র্যাক্টর তৈরি করুন :
FrameExtractor.Builderব্যবহার করে একটি ইনস্ট্যান্স তৈরি করুন। আপনি যেContextএবংMediaItemপরীক্ষা করতে চান তা বিল্ডারকে দিন। উন্নত সেটিংসের জন্য আপনিBuilderকনফিগারেশন পদ্ধতিগুলিও চেইন করতে পারেন। - ফ্রেম এক্সট্র্যাক্ট করুন : একটি নির্দিষ্ট টাইমস্ট্যাম্পে একটি ফ্রেম এক্সট্র্যাক্ট করতে
getFrame()কল করুন অথবা একটি প্রতিনিধিত্বমূলক থাম্বনেইল অনুরোধ করতেgetThumbnail()কল করুন। এই পদ্ধতিগুলি অ্যাসিঙ্ক্রোনাস এবং একটিListenableFutureপ্রদান করে। অতএব, জটিল ডিকোডিং কাজ মূল থ্রেডকে ব্লক করে না।
কোটলিন
suspend fun extractFrames(context: Context, mediaItem: MediaItem) { try { // 1. Build the frame extractor. // `FrameExtractor` implements `AutoCloseable`, so wrap it in // a Kotlin `.use` block, which calls `close()` automatically. FrameExtractor.Builder(context, mediaItem).build().use { extractor -> // 2. Extract frames asynchronously. val frame = extractor.getFrame(5000L).await() val thumbnail = extractor.thumbnail.await() handleFrame(frame, thumbnail) } } catch (e: Exception) { handleFailure(e) } }
জাভা
public void extractFrames(Context context, MediaItem mediaItem) { // 1. Build the frame extractor. // `FrameExtractor` implements `AutoCloseable`, so use try-with-resources // so that the resources are automatically released. try (FrameExtractor frameExtractor = new FrameExtractor.Builder(context, mediaItem).build()) { // 2. Extract frames asynchronously. ListenableFuture<FrameExtractor.Frame> frameFuture = frameExtractor.getFrame(5000L); ListenableFuture<FrameExtractor.Frame> thumbnailFuture = frameExtractor.getThumbnail(); ListenableFuture<List<Object>> allFutures = Futures.allAsList(frameFuture, thumbnailFuture); Futures.addCallback( allFutures, new FutureCallback<List<Object>>() { @Override public void onSuccess(List<Object> result) { handleFrame(Futures.getUnchecked(frameFuture), Futures.getUnchecked(thumbnailFuture)); } @Override public void onFailure(Throwable t) { handleFailure(t); } }, directExecutor()); } }