এই দস্তাবেজটি আসল সরঞ্জাম প্রস্তুতকারকদের (OEMs) সঠিকভাবে Android মিডিয়া রিসোর্স ম্যানেজার এবং সম্পর্কিত APIগুলির জন্য সমর্থন কার্যকর করতে সহায়তা করার উদ্দেশ্যে তৈরি করা হয়েছে৷
সর্বাধিক সমবর্তী কোডেক উদাহরণ
CodecCapabilities.getMaxSupportedInstances
ইন্টারফেস সমর্থিত সমসাময়িক কোডেক উদাহরণগুলির সর্বাধিক সংখ্যা প্রদান করে।
CTS টেস্ট testGetMaxSupportedInstances(android.media.cts.MediaCodecCapabilitiesTest)
ব্যবহার করা হয় সঠিক সর্বোচ্চটি /etc/media_codecs.xml
এ সেট করা আছে।
এখানে একটি উদাহরণ:
... <MediaCodecs> ... <Encoders> <MediaCodec name="OMX.<vendor>.video.encoder.avc" type="video/avc" > ... <Limit name="concurrent-instances" max="13" /> </MediaCodec> ... </Encoders> ... </MediaCodecs>
OEMs এই পরীক্ষাটি পরীক্ষায় উত্তীর্ণ সমকালীন সীমা তৈরি করতে ব্যবহার করতে পারে। এটি করতে:
- cts-tradefed ব্যবহার করে প্রথমে পরীক্ষাটি চালান।
- ফলাফল ব্যর্থতা বার্তা মূল্যায়ন. এখানে একটি উদাহরণ:
There was 1 failure: 1) testGetMaxSupportedInstances(android.media.cts.MediaCodecCapabilitiesTest) junit.framework.AssertionFailedError: In order to pass the test, please publish following codecs' concurrent instances limit in /etc/media_codecs.xml: <MediaCodec name="OMX.<vendor>.video.encoder.mpeg4" type="video/mp4v-es" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.encoder.h263" type="video/3gpp" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.encoder.avc" type="video/avc" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.encoder.vp8" type="video/x-vnd.on2.vp8" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.avc" type="video/avc" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.avc.secure" type="video/avc" > <Limit name="concurrent-instances" max="4" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.mpeg4" type="video/mp4v-es" > <Limit name="concurrent-instances" max="12" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.h263" type="video/3gpp" > <Limit name="concurrent-instances" max="12" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.vp8" type="video/x-vnd.on2.vp8" > <Limit name="concurrent-instances" max="12" /> </MediaCodec>
/etc/media_codecs.xml
ফাইলে পরীক্ষা ব্যর্থতার বার্তায় প্রস্তাবিতconcurrent-instances
লাইনগুলি যোগ করুন।- এর সাফল্য যাচাই করতে পরীক্ষাটি পুনরায় চালান।
ভিডিও কোডেকগুলির জন্য অর্জনযোগ্য ফ্রেম রেট
VideoCapabilities.getAchievableFrameRatesFor
ইন্টারফেস একটি ভিডিও আকারের জন্য অর্জনযোগ্য ভিডিও ফ্রেম হারের পরিসীমা প্রদান করে। /etc/media_codecs_performance.xml
এ স্থাপিত একটি XML ফাইলের মাধ্যমে প্রতিটি ডিভাইসের জন্য OEM দ্বারা এই তথ্য প্রদান করা আবশ্যক। এই সেটিংস com.android.cts.videoperf.VideoEncoderDecoderTest
এবং android.media.cts.VideoDecoderPerfTest
CTS পরীক্ষা দ্বারা পরীক্ষা করা হয়।
OEMs পরীক্ষায় উত্তীর্ণ XML ফাইলগুলি তৈরি করতে CTS পরীক্ষাগুলি ব্যবহার করতে পারে। এটি করতে:
- cts-tradefed ব্যবহার করে প্রথমে পরীক্ষা চালান। অ্যান্ড্রয়েড কর্মক্ষমতার পরিবর্তনশীলতার পরিপ্রেক্ষিতে, আরও সঠিক ন্যূনতম এবং সর্বোচ্চ মান পেতে পরীক্ষাগুলি একাধিকবার চালানোর পরামর্শ দেওয়া হয়।
- XML ফাইল তৈরি করতে দেওয়া get_achievable_rates.py স্ক্রিপ্ট ব্যবহার করুন।
- XML ফাইলটি এখানে রাখুন:
/etc/media_codecs_performance.xml
এটি সাধারণত ডিভাইস প্রকল্পে (device/ <vendor> / <product> ) XML ফাইল স্থাপন করে এবংdevice.mk
এ একটিPRODUCT_COPY_FILES
লাইন যোগ করার মাধ্যমে করা হয়:PRODUCT_COPY_FILES += \ ... device/moto/shamu/media_codecs.xml:system/etc/media_codecs.xml \ + device/moto/shamu/media_codecs_performance.xml:system/etc/media_codecs_performance.xml
- তাদের সাফল্য যাচাই করতে পারফরম্যান্স পরীক্ষাগুলি পুনরায় চালান।
নিরাপদ কোডেক এবং অ-সুরক্ষিত কোডেক এর সহাবস্থান
- supports-secure-with-non-secure-codec — যদি সুরক্ষিত কোডেক এবং নন-সিকিউর কোডেক-এর উদাহরণ একই সময়ে সহাবস্থান করতে না পারে, তাহলে সেটাকে
media_codecs.xml
ফাইলে গ্লোবাল সেটিং হিসাবে নির্দেশ করা উচিত।<MediaCodecs> <Settings> <Setting name="supports-secure-with-non-secure-codec" value="false" /> </Settings> <Encoders> …
- supports-multiple-secure-codecs — একাধিক সুরক্ষিত কোডেক দৃষ্টান্তের সহাবস্থান সমর্থিত না হলে, এটি
media_codecs.xml
ফাইলে একটি গ্লোবাল সেটিং হিসাবে নির্দেশ করা উচিত।<MediaCodecs> <Settings> <Setting name="supports-multiple-secure-codecs" value="false" /> </Settings> <Encoders> …
- মনে রাখবেন যে উভয় সেটিংসই ডিফল্টরূপে সত্য, মানে যদি সেগুলি সমর্থিত হয়, তাহলে
media_codecs.xml
এ সেটিং লাইন যোগ করার দরকার নেই। -
ResourceManagerTest
CTS পরীক্ষা ব্যর্থ হতে পারে যদি এই দুটি সেটিংস সঠিকভাবে সেট না করা হয়।