A player is the component of your app that facilitates playback of media items. The Media3 Player interface sets up an outline for functionality generally handled by a player. This includes:
- প্লেব্যাক নিয়ন্ত্রণগুলিকে প্রভাবিত করা, যেমন বাজানো, থামানো এবং খোঁজা
- বর্তমানে চলমান মিডিয়ার বৈশিষ্ট্য অনুসন্ধান করা, যেমন প্লেব্যাক অবস্থান
- মিডিয়া আইটেমের একটি প্লেলিস্ট/সারি পরিচালনা করা
- প্লেব্যাক বৈশিষ্ট্যগুলি কনফিগার করা, যেমন শাফলিং, পুনরাবৃত্তি, গতি এবং ভলিউম
- স্ক্রিনে ভিডিও রেন্ডার করা হচ্ছে
Media3 Player ইন্টারফেসের একটি বাস্তবায়নও প্রদান করে, যার নাম ExoPlayer ।
উপাদানগুলির মধ্যে একটি সাধারণ ইন্টারফেস
Media3 এর বেশ কিছু উপাদান প্লেয়ার ইন্টারফেস বাস্তবায়ন করে, উদাহরণস্বরূপ:
| উপাদান | বর্ণনা এবং আচরণের নোট |
|---|---|
ExoPlayer | একটি মিডিয়া প্লেয়ার API, এবং Player ইন্টারফেসের ডিফল্ট বাস্তবায়ন। |
MediaController | প্লেব্যাক কমান্ড পাঠানোর জন্য একটি MediaSession এর সাথে ইন্টারঅ্যাক্ট করে। যদি আপনার Player এবং MediaSession আপনার Player এর UI থাকা Activity বা Fragment থেকে আলাদা কোনও Service থাকে, তাহলে আপনি আপনার PlayerView UI এর জন্য আপনার MediaController কে প্লেয়ার হিসেবে বরাদ্দ করতে পারেন। প্লেব্যাক এবং প্লেলিস্ট পদ্ধতির কলগুলি আপনার MediaSession এর মাধ্যমে আপনার Player এ পাঠানো হয়। |
MediaBrowser | একটি MediaController দ্বারা প্রদত্ত কার্যকারিতা ছাড়াও, উপলব্ধ মিডিয়া সামগ্রী ব্রাউজ করার জন্য একটি MediaLibrarySession এর সাথে ইন্টারঅ্যাক্ট করে। |
SimpleBasePlayer | একটি Player বাস্তবায়ন যা বাস্তবায়নের জন্য প্রয়োজনীয় পদ্ধতির সংখ্যা সর্বনিম্ন করে দেয়। MediaSession এর সাথে সংযোগ স্থাপন করতে চান এমন একটি কাস্টম প্লেয়ার ব্যবহার করার সময় সহায়ক। |
ForwardingSimpleBasePlayer | একটি SimpleBasePlayer সাবক্লাস যা অন্য Player প্লেব্যাক অপারেশন ফরোয়ার্ড করার জন্য ডিজাইন করা হয়েছে এবং একই সাথে SimpleBasePlayer এর মতো একই ধারাবাহিক আচরণ কাস্টমাইজেশনের অনুমতি দেয়। নির্দিষ্ট প্লেব্যাক অপারেশন দমন বা পরিবর্তন করতে এই ক্লাসটি ব্যবহার করুন। |
RemoteCastPlayer | রিমোট কাস্ট রিসিভার অ্যাপে প্লেব্যাক নিয়ন্ত্রণের জন্য একটি Player বাস্তবায়ন। |
CastPlayer | স্থানীয় এবং দূরবর্তী কাস্ট প্লেব্যাক নিয়ন্ত্রণের জন্য একটি Player বাস্তবায়ন। |
যদিও MediaSession Player ইন্টারফেস বাস্তবায়ন করে না, তবুও এটি তৈরি করার সময় একটি Player প্রয়োজন হয়। এর উদ্দেশ্য হল অন্যান্য প্রক্রিয়া বা থ্রেড থেকে Player অ্যাক্সেস প্রদান করা।
মিডিয়া৩ প্লেব্যাক আর্কিটেকচার
যদি আপনার কাছে Player অ্যাক্সেস থাকে, তাহলে প্লেব্যাক কমান্ড ইস্যু করার জন্য আপনার সরাসরি এর পদ্ধতিগুলি কল করা উচিত। আপনি MediaSession প্রয়োগ করে আপনার প্লেব্যাকের বিজ্ঞাপন দিতে পারেন এবং বহিরাগত উৎসগুলিকে প্লেব্যাক নিয়ন্ত্রণ প্রদান করতে পারেন। এই বহিরাগত উৎসগুলি একটি MediaController প্রয়োগ করে, যা একটি মিডিয়া সেশনের সাথে সংযোগ স্থাপন এবং প্লেব্যাক কমান্ড অনুরোধ জারি করার সুবিধা প্রদান করে।
ব্যাকগ্রাউন্ডে মিডিয়া চালানোর সময়, আপনার মিডিয়া সেশন এবং প্লেয়ারকে একটি MediaSessionService বা MediaLibraryService মধ্যে রাখতে হবে যা একটি ফোরগ্রাউন্ড পরিষেবা হিসেবে চলে। যদি আপনি তা করেন, তাহলে আপনি আপনার অ্যাপের অ্যাক্টিভিটি থেকে আপনার প্লেয়ারকে আলাদা করতে পারেন যেখানে প্লেব্যাক নিয়ন্ত্রণের জন্য UI রয়েছে। এর জন্য আপনাকে একটি মিডিয়া কন্ট্রোলার ব্যবহার করতে হতে পারে।

Player ইন্টারফেস একটি গুরুত্বপূর্ণ ভূমিকা পালন করে।খেলোয়াড়ের অবস্থা
Player ইন্টারফেস বাস্তবায়নকারী একটি মিডিয়া প্লেয়ারের অবস্থা মূলত 4 ধরণের তথ্য নিয়ে গঠিত:
- প্লেব্যাক অবস্থা
-
getPlaybackState()দিয়ে পুনরুদ্ধার করুন। - ইন্টারফেস দ্বারা সংজ্ঞায়িত স্টেট মান হল
STATE_IDLE,STATE_BUFFERING,STATE_READY, এবংSTATE_ENDED।
-
- মিডিয়া আইটেমের প্লেলিস্ট
- প্লেব্যাকের জন্য
MediaItemইনস্ট্যান্সের একটি ক্রম। -
getCurrentTimeline()দিয়ে পুনরুদ্ধার করুন -
Playerইনস্ট্যান্সগুলি প্লেলিস্ট অপারেশন পদ্ধতি যেমনMediaItemযোগ করা বা অপসারণ করা এবংgetCurrentMediaItem()এর মতো সুবিধাজনক পদ্ধতি প্রদান করতে পারে।
- প্লেব্যাকের জন্য
- প্লে/পজ প্রপার্টি, যেমন:
-
playWhenReady: ব্যবহারকারী যখন সম্ভব মিডিয়া চালাতে চান নাকি পজড রাখতে চান তা নির্দেশ করে। - প্লেব্যাক দমনের কারণ : প্লেব্যাক দমন কেন করা হচ্ছে তার একটি ইঙ্গিত, যদি প্রযোজ্য হয়, এমনকি যদি
playWhenReadytrueহয় -
isPlaying: প্লেয়ারটি বর্তমানে খেলছে কিনা তার একটি ইঙ্গিত, যা কেবল তখনইtrueহবে যদি প্লেব্যাক অবস্থাSTATE_READYহয়,playWhenReadytrueহয় এবং প্লেব্যাক দমন করা না হয়।
-
- প্লেব্যাক অবস্থান, সহ:
- বর্তমান মিডিয়া আইটেম সূচক : প্লেলিস্টে বর্তমান
MediaItemসূচক। -
isPlayingAd: একটি সন্নিবেশিত বিজ্ঞাপন চলছে কিনা তার একটি ইঙ্গিত। - বর্তমান প্লেব্যাক অবস্থান : বর্তমান
MediaItemবা সন্নিবেশিত বিজ্ঞাপনের মধ্যে বর্তমান প্লেব্যাক অবস্থান।
- বর্তমান মিডিয়া আইটেম সূচক : প্লেলিস্টে বর্তমান
এছাড়াও, Player ইন্টারফেসটি উপলব্ধ ট্র্যাক , মিডিয়া মেটাডেটা , প্লেব্যাকের গতি , ভলিউম এবং প্লেব্যাকের অন্যান্য সহায়ক বৈশিষ্ট্যগুলিতে অ্যাক্সেসের অনুমতি দেয়।
পরিবর্তনগুলি শুনুন
Player.Listener ব্যবহার করে Player এ পরিবর্তনগুলি শুনতে পারবেন। Listener তৈরি এবং ব্যবহার করার পদ্ধতি সম্পর্কে বিস্তারিত জানতে Player ইভেন্টের ExoPlayer ডকুমেন্টেশন দেখুন।
মনে রাখবেন যে লিসেনার ইন্টারফেসে স্বাভাবিক প্লেব্যাক অগ্রগতি ট্র্যাক করার জন্য কোনও কলব্যাক অন্তর্ভুক্ত নেই। প্লেব্যাক অগ্রগতি ক্রমাগত পর্যবেক্ষণ করতে, যেমন একটি অগ্রগতি বার UI সেট আপ করতে, আপনার সঠিক বিরতিতে বর্তমান অবস্থানটি জিজ্ঞাসা করা উচিত।
কোটলিন
fun checkPlaybackPosition(delayMs: Long): Boolean = handler.postDelayed( { val currentPosition = player.currentPosition // Update UI based on currentPosition checkPlaybackPosition(delayMs) }, delayMs, )
জাভা
boolean checkPlaybackPosition(long delayMs) { return handler.postDelayed( () -> { long currentPosition = player.getCurrentPosition(); // Update UI based on currentPosition checkPlaybackPosition(delayMs); }, delayMs); }
প্লেব্যাক নিয়ন্ত্রণ করুন
Player ইন্টারফেসটি অবস্থা নিয়ন্ত্রণ এবং প্লেব্যাক নিয়ন্ত্রণের অনেক উপায় অফার করে:
- মৌলিক প্লেব্যাক নিয়ন্ত্রণ যেমন
play(),pause(),prepare()এবংstop()। -
addMediaItem()অথবাremoveMediaItem()এর মতো প্লেলিস্ট অপারেশন । - বর্তমান আইটেম বা অবস্থান পরিবর্তন করতে চাইছেন ।
- পুনরাবৃত্তি মোড এবং শাফেল মোড সেট করুন।
- ট্র্যাক নির্বাচনের পছন্দগুলি আপডেট করুন।
- প্লেব্যাকের গতি সেট করুন।
কাস্টম Player বাস্তবায়ন
একটি কাস্টম প্লেয়ার তৈরি করতে, আপনি Media3-তে অন্তর্ভুক্ত SimpleBasePlayer প্রসারিত করতে পারেন। এই ক্লাসটি Player ইন্টারফেসের একটি বেস বাস্তবায়ন প্রদান করে যাতে আপনার প্রয়োগ করার জন্য প্রয়োজনীয় পদ্ধতির সংখ্যা সর্বনিম্ন করা যায়।
getState() পদ্ধতিটি ওভাররাইড করে শুরু করুন। কল করার সময় এই পদ্ধতিতে বর্তমান প্লেয়ার স্টেট পূরণ করা উচিত, যার মধ্যে রয়েছে:
- উপলব্ধ কমান্ডের সেট
- প্লেব্যাক বৈশিষ্ট্য, যেমন প্লেব্যাক অবস্থা
STATE_READYথাকাকালীন প্লেয়ারটি বাজানো শুরু করা উচিত কিনা, বর্তমানে চলমান মিডিয়া আইটেমের সূচী এবং বর্তমান আইটেমের মধ্যে প্লেব্যাক অবস্থান।
কোটলিন
class CustomPlayer(looper: Looper) : SimpleBasePlayer(looper) { override fun getState(): State { return State.Builder() .setAvailableCommands(Commands.EMPTY) // Set which playback commands the player can handle // Configure additional playback properties .setPlayWhenReady(true, PLAY_WHEN_READY_CHANGE_REASON_USER_REQUEST) .setCurrentMediaItemIndex(0) .setContentPositionMs(0) .build() } }
জাভা
private static final class CustomPlayer extends SimpleBasePlayer { public CustomPlayer(Looper looper) { super(looper); } @Override protected State getState() { return new State.Builder() .setAvailableCommands(Commands.EMPTY) // Set which playback commands the player can handle // Configure additional playback properties .setPlayWhenReady(true, PLAY_WHEN_READY_CHANGE_REASON_USER_REQUEST) .setCurrentMediaItemIndex(0) .setContentPositionMs(0) .build(); } }
SimpleBasePlayer বলবৎ করবে যে State তৈরি করা হয়েছে একটি বৈধ state মান সমন্বয়ে। এটি শ্রোতাদের এবং শ্রোতাদের state পরিবর্তন সম্পর্কে অবহিত করার কাজও করবে। যদি আপনার ম্যানুয়ালি state আপডেট ট্রিগার করার প্রয়োজন হয়, তাহলে invalidateState() কল করুন।
getState() পদ্ধতির বাইরে, আপনাকে কেবল সেই পদ্ধতিগুলি বাস্তবায়ন করতে হবে যা আপনার প্লেয়ার দ্বারা উপলব্ধ বলে ঘোষিত কমান্ডগুলির জন্য ব্যবহৃত হয়। আপনি যে কার্যকারিতাটি বাস্তবায়ন করতে চান তার সাথে সঙ্গতিপূর্ণ ওভাররাইডেবল হ্যান্ডলার পদ্ধতিটি খুঁজুন। উদাহরণস্বরূপ, COMMAND_SEEK_IN_CURRENT_MEDIA_ITEM এবং COMMAND_SEEK_TO_NEXT_MEDIA_ITEM এর মতো ক্রিয়াকলাপগুলিকে সমর্থন করার জন্য handleSeek() পদ্ধতিটি ওভাররাইড করুন।
Player বাস্তবায়ন পরিবর্তন করুন
Instead of creating a completely custom Player , you can use ForwardingSimpleBasePlayer to modify the state and behavior of an existing Player . See the guide on the Customization page for more details.