মিডিয়াপ্রোভাইডার মডিউল ইনডেক্স করা মেটাডেটা (এসডি কার্ড এবং ইউএসবি ডিভাইস থেকে অডিও, ভিডিও এবং ছবি) অপ্টিমাইজ করে এবং সেই ডেটা মিডিয়াস্টোর পাবলিক API-এর মাধ্যমে অ্যাপগুলিতে উপলব্ধ করে। ব্যবহারকারীর গোপনীয়তা বজায় রাখতে, মিডিয়াপ্রোভাইডার মডিউলটি Android 10-এ প্রবর্তিত স্কোপড স্টোরেজ সিকিউরিটি মডেলটি প্রয়োগ করে, যার মধ্যে সংবেদনশীল অবস্থানের মেটাডেটা সংশোধন করা রয়েছে। এই মডিউলটি আপডেট করা যায়, যা Android-কে নিরাপত্তা সংক্রান্ত সমস্যায় দ্রুত সাড়া দিতে সক্ষম করে (ব্যবহারকারীর সংবেদনশীল ডেটা সুরক্ষিত রাখা) এবং দ্রুত নতুন মিডিয়া ফর্ম্যাট যোগ করে (ব্যবহারকারী এবং ডেভেলপার উভয়কেই সামঞ্জস্য প্রদান করে)।
Android 10 এ পরিবর্তন
অ্যান্ড্রয়েড 10 মিডিয়া ফাইলগুলি থেকে ডেটা সনাক্তকরণ এবং বের করার সাথে সম্পর্কিত বেশ কয়েকটি উন্নতি প্রবর্তন করেছে, বিশেষত:
একটি ফাইলের MIME প্রকারের প্রথম অংশ ব্যবহার করে ফাইল সামগ্রীর ধরন নির্ধারণ করা। উদাহরণস্বরূপ, ওএস জানে যে
image/pngএবংimage/x-newly-invented-formatউভয়ই ইমেজ, এবং এইভাবে শেষ ব্যবহারকারীর কাছে প্রাসঙ্গিক অনুমতিগুলি সঠিকভাবে বর্ণনা করতে পারে।শুধুমাত্র ফাইল এক্সটেনশন ব্যবহার করে MIME প্রকার নির্ধারণ করা (এবং নিরাপত্তা সমস্যা এড়াতে সামগ্রী স্নিফিং ব্যবহার না করে)।
আপস্ট্রিম ডেবিয়ান লিনাক্স এবং অ্যান্ড্রয়েড ম্যাপিং এর সংমিশ্রণ ব্যবহার করে একটি নির্বিচারে ফাইলের MIME প্রকার নির্ধারণ করা।
video/*এবংaudio/*ফাইল (MediaMetadataRetrieverএর মাধ্যমে) এবংimage/*ফাইল (ExifInterfaceএর মাধ্যমে) থেকে প্রাসঙ্গিক ডেটা ফেরত দেওয়া।
Android 11 এ পরিবর্তন
অ্যান্ড্রয়েড 11-এ, মিডিয়াপ্রোভাইডার মডিউল নিম্নলিখিত উন্নতিগুলির সাথে Android 10-এ করা পরিবর্তনগুলির উপর ভিত্তি করে তৈরি করে:
সূচীকরণের উন্নতি। MediaProvider মডিউল এখন MediaStore পাবলিক API-এর বিরুদ্ধে উপলব্ধ মেটাডেটা সমন্বয় করে মেটাডেটা সূচী করে। পরিবর্তন অন্তর্ভুক্ত:
নতুন
is_favoriteকলাম এবংQUERY_ARG_MATCH_FAVORITEআর্গুমেন্ট এই কলামের উপর ভিত্তি করে মিডিয়াকে দ্রুত ফিল্টার করতে গ্যালারি-স্টাইল অ্যাপগুলিকে সক্ষম করতে৷ইন্ডেক্সিং রঙ স্থান মেটাডেটা.
নতুন 'is_trashed' কলাম এবং
QUERY_ARG_MATCH_TRASHEDআর্গুমেন্ট এই কলামের উপর ভিত্তি করে ফিল্টার করার জন্য গ্যালারি-স্টাইলের অ্যাপগুলিকে সক্ষম করতে।নতুন এপিআই যা
createDeleteRequest(),createFavoriteRequest(),createTrashRequest(), এবংcreateWriteRequest()সহ একটি একক ব্যবহারকারী ডায়ালগ প্রম্পট সহ একাধিক আইটেমের বাল্ক-সংশোধন সক্ষম করে।নতুন
GENERATION_ADDEDএবংGENERATION_MODIFIEDকলামগুলি পূর্ববর্তী সিঙ্ক্রোনাইজেশন বিন্দু থেকে সংঘটিত পরিবর্তনগুলি দ্রুত এবং নির্ভরযোগ্যভাবে সনাক্ত করার জন্য ব্যবহারের জন্য৷উপরে উল্লিখিত নয় অতিরিক্ত মেটাডেটা কলামগুলির সাথে ব্যবহারের জন্য পাবলিক API
GROUP BY৷
PNG এবং WebP কন্টেইনার থেকে মেটাডেটা বের করতে
ExifInterfaceএর উন্নতি।স্ক্রীন ক্যাপচারে
DateTimeOriginalমেটাডেটা লেখার জন্যSystemUIতে উন্নতি।
উপরন্তু, আপনি এখন মিডিয়াপ্রোভাইডারকে নতুন মিডিয়া ফর্ম্যাট যোগ করে কাস্টমাইজ করতে পারেন, কোন স্টোরেজ ডিভাইসগুলিকে ইন্ডেক্স করা উচিত তা চিহ্নিত করে এবং এমনকি MTP স্ট্যাক প্রতিস্থাপন করে। বিস্তারিত জানার জন্য, কাস্টমাইজেশন দেখুন।
মডিউল সীমানা
অ্যান্ড্রয়েড 11 packages/providers/MediaProvider সমস্ত কোড এমটিপি-সম্পর্কিত যুক্তির উল্লেখযোগ্য ব্যতিক্রম সহ একটি নতুন অবস্থানে স্থানান্তরিত করে। উপরন্তু, frameworks/base/core/java/android/provider/MediaStore.java এখন packages/providers/MediaProvider এ মডিউল সীমানার ভিতরে রয়েছে।
প্যাকেজ বিন্যাস
MediaProvider মডিউল APK-in-APEX ফর্ম্যাটে রয়েছে।
নির্ভরতা
মিডিয়াপ্রোভাইডার নির্ভরতাগুলি কাস্টমাইজেশনের সাথে সম্পর্কিত (অর্থাৎ, আপনি মিডিয়াপ্রোভাইডারকে কাস্টমাইজ করলে, আপনাকে অবশ্যই নিশ্চিত করতে হবে যে আপনার বাস্তবায়ন আপনার কাস্টমাইজেশনের সাথে সম্পর্কিত নির্ভরতা পূরণ করে)।
কাস্টম বা নন-স্ট্যান্ডার্ড মিডিয়া ফাইল ফরম্যাট ব্যবহার করার সময় (উদাহরণস্বরূপ, একটি বিক্রেতা-নির্দিষ্ট ক্যামেরা অ্যাপ দ্বারা তৈরি একটি ফর্ম্যাট), আপনাকে MediaProvider দ্বারা সূচীকরণ সক্ষম করতে
MimeUtilsএবং মিডিয়া এক্সট্র্যাক্টর মডিউলের সাথে প্রতিটি কাস্টম ফর্ম্যাট নিবন্ধন করতে হবে।StorageManagerServiceবাস্তবায়নে ব্যবহৃত স্টোরেজ ডিভাইসের একটি কাস্টম সেট (যেমন SD কার্ড স্লট এবং USB পোর্ট) মিডিয়াপ্রোভাইডার সূচীকরণ নিশ্চিত করতে,VolumeInfo.MOUNT_FLAG_INDEXABLEপতাকা সেট করুন।একটি কাস্টম (নন-এওএসপি) এমটিপি বাস্তবায়ন ব্যবহার করার সময়, নিশ্চিত করুন যে বাস্তবায়নটি মিডিয়াস্টোরের সাথে ইন্টারঅ্যাক্ট করতে বাস্তবায়ন সক্ষম করার জন্য শুধুমাত্র পাবলিক এবং সিস্টেম API-এর উপর নির্ভর করে।
কাস্টমাইজেশন
আপনি এখন নতুন মিডিয়া ফর্ম্যাট যোগ করতে পারেন, কোন স্টোরেজ ডিভাইসগুলিকে ইন্ডেক্স করা হয়েছে তা প্রভাবিত করতে এবং MTP স্ট্যাক প্রতিস্থাপন করতে পারেন।
কাস্টম মিডিয়া ফরম্যাট। প্রতিটি নতুন কাস্টম মিডিয়া বিন্যাসের জন্য, আপনাকে অনন্য ফাইল এক্সটেনশন থেকে একটি MIME প্রকারে একটি ম্যাপিং প্রদান করতে হবে৷ আমরা দৃঢ়ভাবে আপনাকে IANA নিবন্ধন প্রক্রিয়া অনুসরণ করার জন্য উত্সাহিত করি।
আপনি একটি এক্সটেনশন বা MIME প্রকারকে পুনরায় সংজ্ঞায়িত করতে পারবেন না যা ইতিমধ্যে AOSP-এ সংজ্ঞায়িত করা হয়েছে৷
video/*এবংaudio/*ফাইলের জন্য, MediaProviderMediaMetadataRetrieverসাথে পরামর্শ করে চলেছে। কাস্টম ফর্ম্যাটের জন্য মেটাডেটা ফেরত দিতে Android 10 মিডিয়া এক্সট্র্যাক্টর ব্যবহার করুন।image/*ফাইলের জন্য, মিডিয়াপ্রোভাইডার মেটাডেটার জন্যExifএ স্ট্যান্ডার্ডাইজ করা চালিয়ে যাচ্ছে। যেকোনো কাস্টম ইমেজ ফরম্যাটের জন্যExifমেটাডেটা এক্সট্র্যাক্ট এবং রিটার্ন করতে আপনিandroid.media.ExifInterfaceপ্রসারিত করতে পারেন।
স্টোরেজ ডিভাইস ইনডেক্সিং পতাকা। মিডিয়াপ্রোভাইডার
StorageManager.getStorageVolumes()দ্বারা প্রত্যাবর্তিত সমস্ত ভলিউম সূচী করে যেখানেStorageVolume.getMediaStoreVolumeName()নন-নাল। আপনি যা সূচীকরণ করা হয়েছে তা প্রভাবিত করার জন্য প্রত্যাবর্তিত ভলিউমের তালিকা কাস্টমাইজ করতে পারেন, তবে আমরা ক্ষণস্থায়ী ভলিউম (যেমন USB OTG ড্রাইভ) অন্তর্ভুক্ত করার বিরুদ্ধে পরামর্শ দিই।MTP স্ট্যাক প্রতিস্থাপন। Android 11 MTP স্ট্যাককে সম্পূর্ণরূপে মডিউল সীমানার বাইরে রাখে এবং নিশ্চিত করে যে এটি সর্বজনীন API-এর বিরুদ্ধে কাজ করে।
টেস্টিং
আপনি নিম্নলিখিত পরীক্ষাগুলি ব্যবহার করে MediaProvider এর কার্যকারিতা যাচাই করতে পারেন:
MediaStore পাবলিক API-এর কার্যকারিতা যাচাই করতে, Android Compatibility Test Suite (CTS)-এর
CtsProviderTestCasesপ্যাকেজে পরীক্ষাগুলি ব্যবহার করুন৷MediaProvider ইন্টারনালের কার্যকারিতা যাচাই করতে,
MediaProviderTestsএ পরীক্ষাগুলি ব্যবহার করুন।
উভয় সেট পরীক্ষা একসাথে চালানোর জন্য, নিম্নলিখিত atest কমান্ডটি ব্যবহার করুন:
atest --test-mapping packages/providers/MediaProvider