মিডিয়া প্রদর্শন এবং প্লেব্যাক নিয়ন্ত্রণ করার জন্য একটি অ্যাপ প্লেয়িং মিডিয়ার ব্যবহারকারী ইন্টারফেস উপাদান প্রয়োজন। Media3 লাইব্রেরিতে একটি UI মডিউল রয়েছে যাতে অনেকগুলি UI উপাদান থাকে। UI মডিউলের উপর নির্ভর করতে নিম্নলিখিত নির্ভরতা যোগ করুন:
কোটলিন
implementation("androidx.media3:media3-ui:1.4.1")
গ্রোভি
implementation "androidx.media3:media3-ui:1.4.1"
সবচেয়ে গুরুত্বপূর্ণ উপাদান হল PlayerView
, মিডিয়া প্লেব্যাকের জন্য একটি দৃশ্য। PlayerView
প্লেব্যাকের সময় ভিডিও, ছবি, সাবটাইটেল এবং অ্যালবাম আর্ট প্রদর্শন করে, সেইসাথে প্লেব্যাক নিয়ন্ত্রণও।
PlayerView
প্লেয়ারের দৃষ্টান্ত সংযুক্ত এবং বিচ্ছিন্ন করার জন্য একটি setPlayer
পদ্ধতি রয়েছে ( null
পাস করে)।
প্লেয়ারভিউ
PlayerView
ভিডিও, ইমেজ এবং অডিও প্লেব্যাক উভয়ের জন্য ব্যবহার করা যেতে পারে। এটি ভিডিও প্লেব্যাকের ক্ষেত্রে ভিডিও এবং সাবটাইটেল রেন্ডার করে, ইমেজ প্লেব্যাকের জন্য বিটম্যাপ এবং অডিও ফাইলে মেটাডেটা হিসেবে অন্তর্ভুক্ত আর্টওয়ার্ক প্রদর্শন করতে পারে। আপনি অন্য যেকোনো UI উপাদানের মতো আপনার লেআউট ফাইলে এটি অন্তর্ভুক্ত করতে পারেন। উদাহরণস্বরূপ, একটি PlayerView
নিম্নলিখিত XML এর সাথে অন্তর্ভুক্ত করা যেতে পারে:
<androidx.media3.ui.PlayerView
android:id="@+id/player_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:show_buffering="when_playing"
app:show_shuffle_button="true"/>
উপরের স্নিপেটটি ব্যাখ্যা করে যে PlayerView
বিভিন্ন বৈশিষ্ট্য প্রদান করে। এই বৈশিষ্ট্যগুলি ভিউ এর আচরণ, সেইসাথে এর চেহারা এবং অনুভূতি কাস্টমাইজ করতে ব্যবহার করা যেতে পারে। এই বৈশিষ্ট্যগুলির বেশিরভাগেরই সংশ্লিষ্ট সেটার পদ্ধতি রয়েছে, যা রানটাইমে ভিউ কাস্টমাইজ করতে ব্যবহার করা যেতে পারে। PlayerView
জাভাডোক এই বৈশিষ্ট্যগুলি এবং সেটার পদ্ধতিগুলিকে আরও বিশদে তালিকাভুক্ত করে।
একবার লেআউট ফাইলে ভিউ ঘোষণা করা হলে, এটি কার্যকলাপের onCreate
পদ্ধতিতে দেখা যেতে পারে:
কোটলিন
override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) // ... playerView = findViewById(R.id.player_view) }
জাভা
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // ... playerView = findViewById(R.id.player_view); }
যখন একটি প্লেয়ার শুরু করা হয়, setPlayer
কল করে এটি ভিউতে সংযুক্ত করা যেতে পারে:
কোটলিন
// Instantiate the player. val player = ExoPlayer.Builder(context).build() // Attach player to the view. playerView.player = player // Set the media item to be played. player.setMediaItem(mediaItem) // Prepare the player. player.prepare()
জাভা
// Instantiate the player. player = new ExoPlayer.Builder(context).build(); // Attach player to the view. playerView.setPlayer(player); // Set the media item to be played. player.setMediaItem(mediaItem); // Prepare the player. player.prepare();
একটি পৃষ্ঠের ধরন চয়ন করুন
PlayerView
এর surface_type
অ্যাট্রিবিউট আপনাকে ভিডিও প্লেব্যাকের জন্য ব্যবহৃত সারফেসের ধরন সেট করতে দেয়। spherical_gl_surface_view
(যা গোলাকার ভিডিও প্লেব্যাকের জন্য একটি বিশেষ মান) এবং video_decoder_gl_surface_view
(যা এক্সটেনশন রেন্ডারার ব্যবহার করে ভিডিও রেন্ডারিংয়ের জন্য) মান ছাড়াও অনুমোদিত মানগুলি হল surface_view
, texture_view
এবং none
। যদি ভিউটি শুধুমাত্র অডিও প্লেব্যাকের জন্য হয়, তবে পৃষ্ঠ তৈরি করা এড়াতে none
ব্যবহার করা উচিত নয় কারণ এটি করা ব্যয়বহুল হতে পারে।
যদি ভিউটি নিয়মিত ভিডিও প্লেব্যাকের জন্য হয় তবে surface_view
বা texture_view
ব্যবহার করা উচিত। ভিডিও প্লেব্যাকের জন্য TextureView
এর তুলনায় SurfaceView
অনেকগুলি সুবিধা রয়েছে:
- অনেক ডিভাইসে উল্লেখযোগ্যভাবে কম পাওয়ার খরচ ।
- আরও সঠিক ফ্রেম টাইমিং, যার ফলে ভিডিও প্লেব্যাক মসৃণ হয়।
- সক্ষম ডিভাইসগুলিতে উচ্চ মানের HDR ভিডিও আউটপুটের জন্য সমর্থন।
- DRM-সুরক্ষিত বিষয়বস্তু চালানোর সময় সুরক্ষিত আউটপুটের জন্য সমর্থন।
- অ্যান্ড্রয়েড টিভি ডিভাইসগুলিতে ডিসপ্লের সম্পূর্ণ রেজোলিউশনে ভিডিও সামগ্রী রেন্ডার করার ক্ষমতা যা UI স্তরকে উন্নত করে।
SurfaceView
তাই যেখানে সম্ভব TextureView
চেয়ে অগ্রাধিকার দেওয়া উচিত। TextureView
শুধুমাত্র ব্যবহার করা উচিত যদি SurfaceView
আপনার চাহিদা পূরণ না করে। একটি উদাহরণ হল যেখানে Android 7.0 (API স্তর 24) এর আগে ভিডিও পৃষ্ঠের মসৃণ অ্যানিমেশন বা স্ক্রোলিং প্রয়োজন, যেমনটি নিম্নলিখিত নোটগুলিতে বর্ণনা করা হয়েছে। এই ক্ষেত্রে, SDK_INT
24 (Android 7.0) এর কম হলে TextureView
ব্যবহার করা বাঞ্ছনীয় এবং অন্যথায় SurfaceView
।
অ্যান্ড্রয়েড টিভিতে ডি-প্যাড নেভিগেশন
অ্যান্ড্রয়েড টিভির রিমোট কন্ট্রোলে একটি ডি-প্যাড কন্ট্রোল রয়েছে যা আপনার Activity
dispatchKeyEvent(KeyEvent)
এ কী ইভেন্ট হিসেবে আসা কমান্ড পাঠায়। এগুলি প্লেয়ার ভিউতে অর্পণ করা দরকার:
কোটলিন
override fun dispatchKeyEvent(event: KeyEvent?): Boolean{ return playerView.dispatchKeyEvent(event!!) || super.dispatchKeyEvent(event) }
জাভা
@Override public boolean dispatchKeyEvent(KeyEvent event) { return playerView.dispatchKeyEvent(event) || super.dispatchKeyEvent(event); }
প্লেব্যাক কন্ট্রোল নেভিগেট করার জন্য এবং বিজ্ঞাপনগুলি এড়িয়ে যাওয়ার জন্য প্লেয়ার ভিউয়ের জন্য ফোকাসের অনুরোধ করা গুরুত্বপূর্ণ। Activity
onCreate
ফোকাস করার অনুরোধ বিবেচনা করুন:
কোটলিন
override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) // ... playerView.requestFocus() // ... }
জাভা
@Override public void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); // ... playerView.requestFocus(); // ... }
আপনি যদি Android TV-তে কম্পোজ ব্যবহার করেন, তাহলে আপনাকে AndroidView
ফোকাসযোগ্য করে তুলতে হবে এবং সেই অনুযায়ী AndroidView
এ মডিফায়ার প্যারামিটার পাস করে ইভেন্টটি অর্পণ করতে হবে:
AndroidView(
modifier = modifier
.focusable()
.onKeyEvent { playerView.dispatchKeyEvent(it.nativeKeyEvent) },
factory = { playerView }
)
অঙ্কনযোগ্য ওভাররাইড করুন
PlayerView
প্লেব্যাক নিয়ন্ত্রণ এবং অগ্রগতি বার প্রদর্শন করতে PlayerControlView
ব্যবহার করে। PlayerControlView
দ্বারা ব্যবহৃত অঙ্কনযোগ্যগুলি আপনার অ্যাপ্লিকেশনে সংজ্ঞায়িত একই নামের সাথে অঙ্কনযোগ্য দ্বারা ওভাররাইড করা যেতে পারে। ওভাররাইড করা যেতে পারে এমন নিয়ন্ত্রণ অঙ্কনযোগ্য তালিকার জন্য PlayerControlView
Javadoc দেখুন।
আরও কাস্টমাইজেশন
যেখানে উপরে বর্ণিত এর বাইরে কাস্টমাইজেশন প্রয়োজন, আমরা আশা করি যে অ্যাপ ডেভেলপাররা Media3 এর UI মডিউল দ্বারা প্রদত্ত সেগুলি ব্যবহার করার পরিবর্তে তাদের নিজস্ব UI উপাদানগুলি প্রয়োগ করবে৷