আমি আজ খুশি

ডিফল্টরূপে, ExoPlayer শুধুমাত্র ত্রুটিগুলি লগ করে। প্লেয়ার ইভেন্ট লগ করতে, EventLogger ক্লাস ব্যবহার করা যেতে পারে। এটি যে অতিরিক্ত লগিং প্রদান করে তা প্লেয়ার কী করছে তা বোঝার পাশাপাশি প্লেব্যাক সমস্যাগুলি ডিবাগ করার জন্য সহায়ক হতে পারে। EventLogger AnalyticsListener প্রয়োগ করে, তাই ExoPlayer এর সাথে একটি উদাহরণ নিবন্ধন করা সহজ:

কোটলিন

player.addAnalyticsListener(EventLogger())

জাভা

player.addAnalyticsListener(new EventLogger());

লগ পর্যবেক্ষণ করার সবচেয়ে সহজ উপায় হল অ্যান্ড্রয়েড স্টুডিওর লগক্যাট ট্যাব ব্যবহার করা। আপনি প্যাকেজ নামের দ্বারা আপনার অ্যাপটিকে ডিবাগযোগ্য প্রক্রিয়া হিসাবে নির্বাচন করতে পারেন ( androidx.media3.demo.main যদি ডেমো অ্যাপ ব্যবহার করেন) এবং logcat ট্যাবটিকে শুধুমাত্র সেই অ্যাপের জন্য লগ-ইন করতে বলুন শুধুমাত্র নির্বাচিত অ্যাপ্লিকেশনটি দেখান নির্বাচন করে। EventLogger|ExoPlayerImpl অভিব্যক্তি দিয়ে লগিংকে আরও ফিল্টার করা সম্ভব, শুধুমাত্র EventLogger এবং প্লেয়ার থেকে লগিং পেতে।

অ্যান্ড্রয়েড স্টুডিওর লগক্যাট ট্যাব ব্যবহার করার একটি বিকল্প হল কনসোল ব্যবহার করা। উদাহরণ স্বরূপ:

adb logcat EventLogger:* ExoPlayerImpl:* *:s

প্লেয়ার তথ্য

ExoPlayerImpl ক্লাস প্লেয়ার সংস্করণ সম্পর্কে দুটি গুরুত্বপূর্ণ লাইন প্রদান করে, অ্যাপটি যে ডিভাইস এবং ওএসে চলছে এবং ExoPlayer এর মডিউলগুলি লোড করা হয়েছে:

ExoPlayerImpl: Init 59a18ab [AndroidXMedia3/1.0.0-rc02] [flame, Pixel 4, Google, 33]
ExoPlayerImpl: Release 59a18ab [AndroidXMedia3/1.0.0-rc02] [flame, Pixel 4, Google, 33] [media3.common, media3.datasource, media3.ui, media3.exoplayer, media3.decoder, media3.exoplayer.dash, media3.extractor]

প্লেব্যাক অবস্থা

প্লেয়ার স্টেট পরিবর্তনগুলি এই মত লাইনে লগ ইন করা হয়:

EventLogger: playWhenReady [eventTime=0.00, mediaPos=0.00, window=0, true, USER_REQUEST]
EventLogger: state [eventTime=0.01, mediaPos=0.00, window=0, BUFFERING]
EventLogger: state [eventTime=0.93, mediaPos=0.00, window=0, period=0, READY]
EventLogger: isPlaying [eventTime=0.93, mediaPos=0.00, window=0, period=0, true]
EventLogger: playWhenReady [eventTime=9.40, mediaPos=8.40, window=0, period=0, false, USER_REQUEST]
EventLogger: isPlaying [eventTime=9.40, mediaPos=8.40, window=0, period=0, false]
EventLogger: playWhenReady [eventTime=10.40, mediaPos=8.40, window=0, period=0, true, USER_REQUEST]
EventLogger: isPlaying [eventTime=10.40, mediaPos=8.40, window=0, period=0, true]
EventLogger: state [eventTime=20.40, mediaPos=18.40, window=0, period=0, ENDED]
EventLogger: isPlaying [eventTime=20.40, mediaPos=18.40, window=0, period=0, false]

এই উদাহরণে প্লেব্যাক প্লেয়ার প্রস্তুত হওয়ার 0.93 সেকেন্ড পরে শুরু হয়। ব্যবহারকারী 9.4 সেকেন্ডের পরে প্লেব্যাক বিরতি দেয় এবং এক সেকেন্ড পরে 10.4 সেকেন্ডে প্লেব্যাক পুনরায় শুরু করে। প্লেব্যাক দশ সেকেন্ড পরে 20.4 সেকেন্ডে শেষ হয়। বর্গাকার বন্ধনীর মধ্যে সাধারণ উপাদানগুলি হল:

  • [eventTime=float] : প্লেয়ার তৈরির পর থেকে দেয়াল ঘড়ির সময়।
  • [mediaPos=float] : বর্তমান প্লেব্যাক অবস্থান।
  • [window=int] : বর্তমান উইন্ডো সূচক।
  • [period=int] : সেই উইন্ডোতে বর্তমান সময়কাল।

প্রতিটি লাইনের চূড়ান্ত উপাদানগুলি রিপোর্ট করা রাষ্ট্রের মান নির্দেশ করে।

মিডিয়া ট্র্যাক

উপলব্ধ বা নির্বাচিত ট্র্যাক পরিবর্তন হলে ট্র্যাক তথ্য লগ করা হয়। প্লেব্যাকের শুরুতে অন্তত একবার এটি ঘটে। নীচের উদাহরণটি একটি অভিযোজিত স্ট্রিমের জন্য ট্র্যাক লগিং দেখায়:

EventLogger: tracks [eventTime=0.30, mediaPos=0.00, window=0, period=0,
EventLogger:   group [
EventLogger:     [X] Track:0, id=133, mimeType=video/avc, bitrate=261112, codecs=avc1.4d4015, res=426x240, fps=30.0, supported=YES
EventLogger:     [X] Track:1, id=134, mimeType=video/avc, bitrate=671331, codecs=avc1.4d401e, res=640x360, fps=30.0, supported=YES
EventLogger:     [X] Track:2, id=135, mimeType=video/avc, bitrate=1204535, codecs=avc1.4d401f, res=854x480, fps=30.0, supported=YES
EventLogger:     [X] Track:3, id=160, mimeType=video/avc, bitrate=112329, codecs=avc1.4d400c, res=256x144, fps=30.0, supported=YES
EventLogger:     [ ] Track:4, id=136, mimeType=video/avc, bitrate=2400538, codecs=avc1.4d401f, res=1280x720, fps=30.0, supported=NO_EXCEEDS_CAPABILITIES
EventLogger:   ]
EventLogger:   group [
EventLogger:     [ ] Track:0, id=139, mimeType=audio/mp4a-latm, bitrate=48582, codecs=mp4a.40.5, channels=2, sample_rate=22050, supported=YES
EventLogger:     [X] Track:1, id=140, mimeType=audio/mp4a-latm, bitrate=127868, codecs=mp4a.40.2, channels=2, sample_rate=44100, supported=YES
EventLogger:   ]
EventLogger: ]

এই উদাহরণে, প্লেয়ার পাঁচটি উপলব্ধ ভিডিও ট্র্যাকের মধ্যে চারটি নির্বাচন করেছে৷ supported=NO_EXCEEDS_CAPABILITIES দ্বারা নির্দেশিত হিসাবে পঞ্চম ভিডিও ট্র্যাকটি নির্বাচন করা হয়নি কারণ এটি ডিভাইসের ক্ষমতাকে অতিক্রম করেছে। প্লেয়ার প্লেব্যাকের সময় নির্বাচিত ভিডিও ট্র্যাকগুলির মধ্যে মানিয়ে নেবে। যখন প্লেয়ারটি একটি ট্র্যাক থেকে অন্য ট্র্যাকে মানিয়ে নেয়, তখন এটি নীচের একটি লাইনের মতো একটি লাইনে লগ ইন করে:

EventLogger: downstreamFormat [eventTime=3.64, mediaPos=3.00, window=0, period=0, id=134, mimeType=video/avc, bitrate=671331, codecs=avc1.4d401e, res=640x360, fps=30.0]

এই লগ লাইনটি নির্দেশ করে যে প্লেয়ারটি মিডিয়াতে তিন সেকেন্ডের 640x360 রেজোলিউশনের ভিডিও ট্র্যাকে স্যুইচ করেছে।

ডিকোডার নির্বাচন

বেশিরভাগ ক্ষেত্রে, ExoPlayer অন্তর্নিহিত প্ল্যাটফর্ম থেকে অর্জিত একটি MediaCodec ব্যবহার করে মিডিয়া রেন্ডার করে। যখন একটি ডিকোডার আরম্ভ করা হয়, এটি এই ধরনের লাইনে লগ ইন করা হয়:

EventLogger: videoDecoderInitialized [0.77, 0.00, window=0, period=0, video, OMX.qcom.video.decoder.avc]
EventLogger: audioDecoderInitialized [0.79, 0.00, window=0, period=0, audio, OMX.google.aac.decoder]