একটি ক্লাউড মিডিয়া প্রদানকারী Android ফটো পিকারকে অতিরিক্ত ক্লাউড মিডিয়া সামগ্রী প্রদান করে৷ ব্যবহারকারীরা ক্লাউড মিডিয়া প্রদানকারীর দ্বারা সরবরাহ করা ফটো বা ভিডিও নির্বাচন করতে সক্ষম হয় যখন একটি অ্যাপ ব্যবহারকারীর কাছ থেকে মিডিয়া ফাইলের অনুরোধ করতে ACTION_PICK_IMAGES
বা ACTION_GET_CONTENT
ব্যবহার করে৷ একটি ক্লাউড মিডিয়া প্রদানকারী অ্যালবাম সম্পর্কে তথ্যও দিতে পারে, যা অ্যান্ড্রয়েড ফটো পিকারে ব্রাউজ করা যেতে পারে।
আপনি শুরু করার আগে
আপনি আপনার ক্লাউড মিডিয়া প্রদানকারী নির্মাণ শুরু করার আগে নিম্নলিখিত আইটেমগুলি বিবেচনা করুন।
যোগ্যতা
Android একটি পাইলট প্রোগ্রাম চালাচ্ছে যাতে OEM-মনোনীত অ্যাপগুলিকে ক্লাউড মিডিয়া প্রদানকারী হতে দেয়৷ এই সময়ে Android-এর জন্য ক্লাউড মিডিয়া প্রদানকারী হওয়ার জন্য শুধুমাত্র OEM-এর দ্বারা মনোনীত অ্যাপগুলি এই প্রোগ্রামে অংশগ্রহণের যোগ্য ৷ প্রতিটি OEM 3টি অ্যাপ পর্যন্ত মনোনীত করতে পারে। একবার অনুমোদিত হয়ে গেলে, এই অ্যাপগুলি যেকোন জিএমএস অ্যান্ড্রয়েড-চালিত ডিভাইসে ক্লাউড মিডিয়া প্রদানকারী হিসাবে অ্যাক্সেসযোগ্য হয়ে ওঠে যেখানে তারা ইনস্টল করা আছে।
অ্যান্ড্রয়েড সমস্ত যোগ্য ক্লাউড প্রদানকারীর সার্ভার-সাইড তালিকা বজায় রাখে। প্রতিটি OEM একটি কনফিগারযোগ্য ওভারলে ব্যবহার করে একটি ডিফল্ট ক্লাউড প্রদানকারী চয়ন করতে পারে৷ মনোনীত অ্যাপগুলিকে অবশ্যই সমস্ত প্রযুক্তিগত প্রয়োজনীয়তা পূরণ করতে হবে এবং সমস্ত মানের পরীক্ষায় উত্তীর্ণ হতে হবে৷ OEM ক্লাউড মিডিয়া প্রদানকারী পাইলট প্রোগ্রামের প্রক্রিয়া এবং প্রয়োজনীয়তা সম্পর্কে আরও জানতে, তদন্ত ফর্মটি সম্পূর্ণ করুন ৷
আপনার একটি ক্লাউড মিডিয়া প্রদানকারী তৈরি করতে হবে কিনা তা নির্ধারণ করুন
ক্লাউড মিডিয়া প্রদানকারীরা এমন অ্যাপ বা পরিষেবা যা ব্যাক আপ এবং ক্লাউড থেকে ফটো এবং ভিডিও পুনরুদ্ধার করার জন্য ব্যবহারকারীদের প্রাথমিক উত্স হিসাবে কাজ করে। যদি আপনার অ্যাপে দরকারী সামগ্রীর একটি লাইব্রেরি থাকে, কিন্তু এটি সাধারণত ফটো স্টোরেজ সমাধান হিসাবে ব্যবহৃত হয় না, তাহলে আপনার পরিবর্তে একটি নথি প্রদানকারী তৈরি করার কথা বিবেচনা করা উচিত।
প্রোফাইল প্রতি একটি সক্রিয় ক্লাউড প্রদানকারী
প্রতিটি অ্যান্ড্রয়েড প্রোফাইলের জন্য এক সময়ে সর্বাধিক একটি সক্রিয় ক্লাউড মিডিয়া প্রদানকারী থাকতে পারে৷ ব্যবহারকারীরা ফটো পিকার সেটিংস থেকে যেকোনো সময় তাদের নির্বাচিত ক্লাউড মিডিয়া প্রদানকারী অ্যাপটি সরিয়ে দিতে বা পরিবর্তন করতে পারে।
ডিফল্টরূপে, অ্যান্ড্রয়েড ফটো পিকার স্বয়ংক্রিয়ভাবে একটি ক্লাউড প্রদানকারী বেছে নেওয়ার চেষ্টা করবে।
- ডিভাইসে শুধুমাত্র একজন যোগ্য ক্লাউড প্রদানকারী থাকলে, সেই অ্যাপটি বর্তমান প্রদানকারী হিসেবে স্বয়ংক্রিয়ভাবে নির্বাচিত হবে।
যদি ডিভাইসে একাধিক যোগ্য ক্লাউড প্রদানকারী থাকে এবং তাদের মধ্যে একটি OEM নির্বাচিত ডিফল্টের সাথে মেলে, তাহলে OEM-নির্বাচিত অ্যাপটি নির্বাচন করা হবে।
যদি ডিভাইসে একাধিক যোগ্য ক্লাউড প্রদানকারী থাকে এবং তাদের কোনোটিই OEM নির্বাচিত ডিফল্টের সাথে মেলে না, তাহলে কোনো অ্যাপ নির্বাচন করা হবে না।
আপনার ক্লাউড মিডিয়া প্রদানকারী তৈরি করুন
নিম্নলিখিত চিত্রটি অ্যান্ড্রয়েড অ্যাপ, অ্যান্ড্রয়েড ফটো পিকার, স্থানীয় ডিভাইসের MediaProvider
এবং একটি CloudMediaProvider
-এর মধ্যে একটি ফটো নির্বাচন সেশনের আগে এবং সময় উভয় ইভেন্টের ক্রম চিত্রিত করে।
- সিস্টেমটি ব্যবহারকারীর পছন্দের ক্লাউড প্রদানকারীকে শুরু করে এবং পর্যায়ক্রমে অ্যান্ড্রয়েড ফটো পিকার ব্যাকএন্ডে মিডিয়া মেটাডেটা সিঙ্ক করে।
- যখন একটি অ্যান্ড্রয়েড অ্যাপ ফটো পিকার চালু করে, ব্যবহারকারীকে একটি মার্জ করা স্থানীয় বা ক্লাউড আইটেম গ্রিড দেখানোর আগে, ফটো পিকার ক্লাউড প্রদানকারীর সাথে একটি লেটেন্সি-সংবেদনশীল ইনক্রিমেন্টাল সিঙ্ক করে যাতে ফলাফলগুলি যতটা সম্ভব আপ-টু-ডেট হয় তা নিশ্চিত করা যায়। একটি প্রতিক্রিয়া পাওয়ার পরে, বা যখন সময়সীমা পৌঁছে যায়, ফটো পিকার গ্রিড এখন সমস্ত অ্যাক্সেসযোগ্য ফটোগুলি প্রদর্শন করে, আপনার ডিভাইসে স্থানীয়ভাবে সঞ্চিত সেগুলিকে ক্লাউড থেকে সিঙ্ক করাগুলির সাথে একত্রিত করে৷
- ব্যবহারকারী স্ক্রল করার সময়, ফটো বাছাইকারী UI-তে প্রদর্শনের জন্য ক্লাউড মিডিয়া প্রদানকারীর থেকে মিডিয়া থাম্বনেইলগুলি নিয়ে আসে।
- যখন ব্যবহারকারী সেশনটি সম্পূর্ণ করে এবং ফলাফলে একটি ক্লাউড মিডিয়া আইটেম অন্তর্ভুক্ত থাকে, ফটো পিকার কন্টেন্টের জন্য ফাইল বর্ণনাকারীর অনুরোধ করে, একটি URI তৈরি করে এবং কলিং অ্যাপ্লিকেশনে ফাইলটিতে অ্যাক্সেস মঞ্জুর করে।
- অ্যাপটি এখন URI খুলতে সক্ষম এবং মিডিয়া বিষয়বস্তুতে শুধুমাত্র-পঠন অ্যাক্সেস রয়েছে। ডিফল্টরূপে, সংবেদনশীল মেটাডেটা সংশোধন করা হয়। ফটো পিকার অ্যান্ড্রয়েড অ্যাপ এবং ক্লাউড মিডিয়া প্রদানকারীর মধ্যে ডেটা আদান-প্রদানের সমন্বয় করতে FUSE ফাইল সিস্টেম ব্যবহার করে।
সাধারণ সমস্যা
আপনার বাস্তবায়ন বিবেচনা করার সময় এখানে কিছু গুরুত্বপূর্ণ বিবেচ্য বিষয়গুলি মনে রাখতে হবে:
ডুপ্লিকেট ফাইল এড়িয়ে চলুন
যেহেতু অ্যান্ড্রয়েড ফটো পিকারের ক্লাউড মিডিয়া স্টেট পরিদর্শন করার কোনো উপায় নেই, তাই CloudMediaProvider
ক্লাউডে এবং স্থানীয় ডিভাইসে বিদ্যমান যেকোনো ফাইলের কার্সার সারিতে MEDIA_STORE_URI
প্রদান করতে হবে, অথবা ব্যবহারকারী ডুপ্লিকেট ফাইল দেখতে পাবেন ফটো পিকার।
পূর্বরূপ প্রদর্শনের জন্য চিত্রের আকার অপ্টিমাইজ করুন
এটা খুবই গুরুত্বপূর্ণ যে onOpenPreview
থেকে ফেরত আসা ফাইলটি সম্পূর্ণ রেজোলিউশন ইমেজ নয় এবং অনুরোধ করা Size
মেনে চলে। খুব বড় একটি ছবি UI-তে লোড হওয়ার সময় বহন করবে এবং খুব ছোট একটি ছবি ডিভাইসের স্ক্রীনের আকারের উপর ভিত্তি করে পিক্সেলেটেড বা ঝাপসা হতে পারে।
সঠিক অভিযোজন পরিচালনা করুন
যদি onOpenPreview
এ ফিরে আসা থাম্বনেইলগুলিতে তাদের EXIF ডেটা না থাকে, তাহলে প্রিভিউ গ্রিডে থাম্বনেইলগুলিকে ভুলভাবে ঘোরানো এড়াতে সেগুলিকে সঠিক অভিযোজনে ফেরত দেওয়া উচিত৷
অননুমোদিত প্রবেশ রোধ করুন
ContentProvider থেকে কলারকে ডেটা ফেরত দেওয়ার আগে MANAGE_CLOUD_MEDIA_PROVIDERS_PERMISSION
চেক করুন৷ এটি অননুমোদিত অ্যাপগুলিকে ক্লাউড ডেটা অ্যাক্সেস করতে বাধা দেবে।
ক্লাউডমিডিয়াপ্রোভাইডার ক্লাস
android.content.ContentProvider
থেকে প্রাপ্ত, CloudMediaProvider
ক্লাসে নিম্নলিখিত উদাহরণে দেখানো পদ্ধতিগুলির মতো পদ্ধতি অন্তর্ভুক্ত রয়েছে:
কোটলিন
abstract class CloudMediaProvider : ContentProvider() {
@NonNull
abstract override fun onGetMediaCollectionInfo(@NonNull bundle: Bundle): Bundle
@NonNull
override fun onQueryAlbums(@NonNull bundle: Bundle): Cursor = TODO("Implement onQueryAlbums")
@NonNull
abstract override fun onQueryDeletedMedia(@NonNull bundle: Bundle): Cursor
@NonNull
abstract override fun onQueryMedia(@NonNull bundle: Bundle): Cursor
@NonNull
abstract override fun onOpenMedia(
@NonNull string: String,
@Nullable bundle: Bundle?,
@Nullable cancellationSignal: CancellationSignal?
): ParcelFileDescriptor
@NonNull
abstract override fun onOpenPreview(
@NonNull string: String,
@NonNull point: Point,
@Nullable bundle: Bundle?,
@Nullable cancellationSignal: CancellationSignal?
): AssetFileDescriptor
@Nullable
override fun onCreateCloudMediaSurfaceController(
@NonNull bundle: Bundle,
@NonNull callback: CloudMediaSurfaceStateChangedCallback
): CloudMediaSurfaceController? = null
}
জাভা
public abstract class CloudMediaProvider extends android.content.ContentProvider {
@NonNull
public abstract android.os.Bundle onGetMediaCollectionInfo(@NonNull android.os.Bundle);
@NonNull
public android.database.Cursor onQueryAlbums(@NonNull android.os.Bundle);
@NonNull
public abstract android.database.Cursor onQueryDeletedMedia(@NonNull android.os.Bundle);
@NonNull
public abstract android.database.Cursor onQueryMedia(@NonNull android.os.Bundle);
@NonNull
public abstract android.os.ParcelFileDescriptor onOpenMedia(@NonNull String, @Nullable android.os.Bundle, @Nullable android.os.CancellationSignal) throws java.io.FileNotFoundException;
@NonNull
public abstract android.content.res.AssetFileDescriptor onOpenPreview(@NonNull String, @NonNull android.graphics.Point, @Nullable android.os.Bundle, @Nullable android.os.CancellationSignal) throws java.io.FileNotFoundException;
@Nullable
public android.provider.CloudMediaProvider.CloudMediaSurfaceController onCreateCloudMediaSurfaceController(@NonNull android.os.Bundle, @NonNull android.provider.CloudMediaProvider.CloudMediaSurfaceStateChangedCallback);
}
CloudMediaProviderContract ক্লাস
প্রাথমিক CloudMediaProvider
বাস্তবায়ন ক্লাস ছাড়াও, Android ফটো পিকার একটি CloudMediaProviderContract
ক্লাস অন্তর্ভুক্ত করে। এই শ্রেণীটি ফটো পিকার এবং ক্লাউড মিডিয়া প্রদানকারীর মধ্যে আন্তঃঅপারেবিলিটির রূপরেখা দেয়, সিঙ্ক্রোনাইজেশন অপারেশনের জন্য MediaCollectionInfo
, প্রত্যাশিত Cursor
কলাম এবং Bundle
এক্সট্রার মতো দিকগুলিকে অন্তর্ভুক্ত করে।
কোটলিন
object CloudMediaProviderContract {
const val EXTRA_ALBUM_ID = "android.provider.extra.ALBUM_ID"
const val EXTRA_LOOPING_PLAYBACK_ENABLED = "android.provider.extra.LOOPING_PLAYBACK_ENABLED"
const val EXTRA_MEDIA_COLLECTION_ID = "android.provider.extra.MEDIA_COLLECTION_ID"
const val EXTRA_PAGE_SIZE = "android.provider.extra.PAGE_SIZE"
const val EXTRA_PAGE_TOKEN = "android.provider.extra.PAGE_TOKEN"
const val EXTRA_PREVIEW_THUMBNAIL = "android.provider.extra.PREVIEW_THUMBNAIL"
const val EXTRA_SURFACE_CONTROLLER_AUDIO_MUTE_ENABLED = "android.provider.extra.SURFACE_CONTROLLER_AUDIO_MUTE_ENABLED"
const val EXTRA_SYNC_GENERATION = "android.provider.extra.SYNC_GENERATION"
const val MANAGE_CLOUD_MEDIA_PROVIDERS_PERMISSION = "com.android.providers.media.permission.MANAGE_CLOUD_MEDIA_PROVIDERS"
const val PROVIDER_INTERFACE = "android.content.action.CLOUD_MEDIA_PROVIDER"
object MediaColumns {
const val DATE_TAKEN_MILLIS = "date_taken_millis"
const val DURATION_MILLIS = "duration_millis"
const val HEIGHT = "height"
const val ID = "id"
const val IS_FAVORITE = "is_favorite"
const val MEDIA_STORE_URI = "media_store_uri"
const val MIME_TYPE = "mime_type"
const val ORIENTATION = "orientation"
const val SIZE_BYTES = "size_bytes"
const val STANDARD_MIME_TYPE_EXTENSION = "standard_mime_type_extension"
const val STANDARD_MIME_TYPE_EXTENSION_ANIMATED_WEBP = 3 // 0x3
const val STANDARD_MIME_TYPE_EXTENSION_GIF = 1 // 0x1
const val STANDARD_MIME_TYPE_EXTENSION_MOTION_PHOTO = 2 // 0x2
const val STANDARD_MIME_TYPE_EXTENSION_NONE = 0 // 0x0
const val SYNC_GENERATION = "sync_generation"
const val WIDTH = "width"
}
object AlbumColumns {
const val DATE_TAKEN_MILLIS = "date_taken_millis"
const val DISPLAY_NAME = "display_name"
const val ID = "id"
const val MEDIA_COUNT = "album_media_count"
const val MEDIA_COVER_ID = "album_media_cover_id"
}
object MediaCollectionInfo {
const val ACCOUNT_CONFIGURATION_INTENT = "account_configuration_intent"
const val ACCOUNT_NAME = "account_name"
const val LAST_MEDIA_SYNC_GENERATION = "last_media_sync_generation"
const val MEDIA_COLLECTION_ID = "media_collection_id"
}
}
জাভা
public final class CloudMediaProviderContract {
public static final String EXTRA_ALBUM_ID = "android.provider.extra.ALBUM_ID";
public static final String EXTRA_LOOPING_PLAYBACK_ENABLED = "android.provider.extra.LOOPING_PLAYBACK_ENABLED";
public static final String EXTRA_MEDIA_COLLECTION_ID = "android.provider.extra.MEDIA_COLLECTION_ID";
public static final String EXTRA_PAGE_SIZE = "android.provider.extra.PAGE_SIZE";
public static final String EXTRA_PAGE_TOKEN = "android.provider.extra.PAGE_TOKEN";
public static final String EXTRA_PREVIEW_THUMBNAIL = "android.provider.extra.PREVIEW_THUMBNAIL";
public static final String EXTRA_SURFACE_CONTROLLER_AUDIO_MUTE_ENABLED = "android.provider.extra.SURFACE_CONTROLLER_AUDIO_MUTE_ENABLED";
public static final String EXTRA_SYNC_GENERATION = "android.provider.extra.SYNC_GENERATION";
public static final String MANAGE_CLOUD_MEDIA_PROVIDERS_PERMISSION = "com.android.providers.media.permission.MANAGE_CLOUD_MEDIA_PROVIDERS";
public static final String PROVIDER_INTERFACE = "android.content.action.CLOUD_MEDIA_PROVIDER";
}
// Columns available for every media item
public static final class CloudMediaProviderContract.MediaColumns {
public static final String DATE_TAKEN_MILLIS = "date_taken_millis";
public static final String DURATION_MILLIS = "duration_millis";
public static final String HEIGHT = "height";
public static final String ID = "id";
public static final String IS_FAVORITE = "is_favorite";
public static final String MEDIA_STORE_URI = "media_store_uri";
public static final String MIME_TYPE = "mime_type";
public static final String ORIENTATION = "orientation";
public static final String SIZE_BYTES = "size_bytes";
public static final String STANDARD_MIME_TYPE_EXTENSION = "standard_mime_type_extension";
public static final int STANDARD_MIME_TYPE_EXTENSION_ANIMATED_WEBP = 3; // 0x3
public static final int STANDARD_MIME_TYPE_EXTENSION_GIF = 1; // 0x1
public static final int STANDARD_MIME_TYPE_EXTENSION_MOTION_PHOTO = 2; // 0x2
public static final int STANDARD_MIME_TYPE_EXTENSION_NONE = 0; // 0x0
public static final String SYNC_GENERATION = "sync_generation";
public static final String WIDTH = "width";
}
// Columns available for every album item
public static final class CloudMediaProviderContract.AlbumColumns {
public static final String DATE_TAKEN_MILLIS = "date_taken_millis";
public static final String DISPLAY_NAME = "display_name";
public static final String ID = "id";
public static final String MEDIA_COUNT = "album_media_count";
public static final String MEDIA_COVER_ID = "album_media_cover_id";
}
// Media Collection metadata that is cached by the OS to compare sync states.
public static final class CloudMediaProviderContract.MediaCollectionInfo {
public static final String ACCOUNT_CONFIGURATION_INTENT = "account_configuration_intent";
public static final String ACCOUNT_NAME = "account_name";
public static final String LAST_MEDIA_SYNC_GENERATION = "last_media_sync_generation";
public static final String MEDIA_COLLECTION_ID = "media_collection_id";
}
onGetMediaCollectionInfo
onGetMediaCollectionInfo()
পদ্ধতিটি অপারেটিং সিস্টেম দ্বারা এর ক্যাশে করা ক্লাউড মিডিয়া আইটেমগুলির বৈধতা মূল্যায়ন করতে এবং ক্লাউড মিডিয়া প্রদানকারীর সাথে প্রয়োজনীয় সিঙ্ক্রোনাইজেশন নির্ধারণ করতে ব্যবহৃত হয়। অপারেটিং সিস্টেম দ্বারা ঘন ঘন কলের সম্ভাবনার কারণে, onGetMediaCollectionInfo()
কর্মক্ষমতা-সমালোচনা হিসাবে বিবেচিত হয়; দীর্ঘস্থায়ী ক্রিয়াকলাপ বা পার্শ্ব প্রতিক্রিয়াগুলি এড়াতে গুরুত্বপূর্ণ যা কার্যকারিতাকে নেতিবাচকভাবে প্রভাবিত করতে পারে। অপারেটিং সিস্টেম এই পদ্ধতি থেকে পূর্ববর্তী প্রতিক্রিয়াগুলিকে ক্যাশ করে এবং উপযুক্ত ক্রিয়াগুলি নির্ধারণ করতে পরবর্তী প্রতিক্রিয়াগুলির সাথে তাদের তুলনা করে।
কোটলিন
abstract fun onGetMediaCollectionInfo(extras: Bundle): Bundle
জাভা
@NonNull
public abstract Bundle onGetMediaCollectionInfo(@NonNull Bundle extras);
ফিরে আসা MediaCollectionInfo
বান্ডেলে নিম্নলিখিত ধ্রুবকগুলি অন্তর্ভুক্ত রয়েছে:
onQueryMedia
onQueryMedia()
পদ্ধতিটি ফটো পিকারে প্রধান ফটো গ্রিডকে বিভিন্ন ভিউতে পপুলেট করতে ব্যবহৃত হয়। এই কলগুলি লেটেন্সি সংবেদনশীল হতে পারে এবং একটি ব্যাকগ্রাউন্ড প্রোঅ্যাকটিভ সিঙ্কের অংশ হিসাবে বা ফটো পিকার সেশনের সময় যখন একটি সম্পূর্ণ বা বর্ধিত সিঙ্ক অবস্থার প্রয়োজন হয় তখন কল করা যেতে পারে। ফটো বাছাইকারী ব্যবহারকারী ইন্টারফেস ফলাফল প্রদর্শনের প্রতিক্রিয়ার জন্য অনির্দিষ্টকালের জন্য অপেক্ষা করবে না এবং ব্যবহারকারী ইন্টারফেসের উদ্দেশ্যে এই অনুরোধগুলির সময়সীমা শেষ করতে পারে। ফিরে আসা কার্সারটি এখনও ভবিষ্যতের সেশনের জন্য ফটো পিকারের ডাটাবেসে প্রক্রিয়া করার চেষ্টা করবে।
এই পদ্ধতিটি মিডিয়া সংগ্রহের সমস্ত মিডিয়া আইটেমের প্রতিনিধিত্ব করে একটি Cursor
প্রদান করে যা ঐচ্ছিকভাবে প্রদত্ত অতিরিক্ত দ্বারা ফিল্টার করা হয় এবং MediaColumns#DATE_TAKEN_MILLIS
(সর্ব সাম্প্রতিক আইটেমগুলি প্রথমে) এর বিপরীত কালানুক্রমিক ক্রমে সাজানো হয়।
প্রত্যাবর্তিত CloudMediaProviderContract
বান্ডেলে নিম্নলিখিত ধ্রুবকগুলি অন্তর্ভুক্ত রয়েছে:
-
EXTRA_ALBUM_ID
-
EXTRA_LOOPING_PLAYBACK_ENABLED
-
EXTRA_MEDIA_COLLECTION_ID
-
EXTRA_PAGE_SIZE
-
EXTRA_PAGE_TOKEN
-
EXTRA_PREVIEW_THUMBNAIL
-
EXTRA_SURFACE_CONTROLLER_AUDIO_MUTE_ENABLED
-
EXTRA_SYNC_GENERATION
-
MANAGE_CLOUD_MEDIA_PROVIDERS_PERMISSION
-
PROVIDER_INTERFACE
ক্লাউড মিডিয়া প্রদানকারীকে অবশ্যই CloudMediaProviderContract#EXTRA_MEDIA_COLLECTION_ID
ফেরত দেওয়া Bundle
অংশ হিসেবে সেট করতে হবে। এটি সেট না করা একটি ত্রুটি এবং ফিরে আসা Cursor
অবৈধ করে। যদি ক্লাউড মিডিয়া প্রদানকারী প্রদত্ত অতিরিক্তগুলিতে কোনো ফিল্টার পরিচালনা করে, তাহলে এটিকে অবশ্যই ফিরে আসা Cursor#setExtras
এর অংশ হিসেবে ContentResolver#EXTRA_HONORED_ARGS
এ কী যোগ করতে হবে।
onQueryDeletedMedia
ক্লাউড অ্যাকাউন্টে মুছে ফেলা আইটেমগুলি ফটো পিকার ইউজার ইন্টারফেস থেকে সঠিকভাবে সরানো হয়েছে তা নিশ্চিত করতে onQueryDeletedMedia()
পদ্ধতি ব্যবহার করা হয়। তাদের সম্ভাব্য লেটেন্সি সংবেদনশীলতার কারণে, এই কলগুলি এর অংশ হিসাবে শুরু করা হতে পারে:
- ব্যাকগ্রাউন্ড প্রোঅ্যাকটিভ সিঙ্ক্রোনাইজেশন
- ফটো পিকার সেশন (যখন একটি পূর্ণ বা বর্ধিত সিঙ্ক অবস্থা প্রয়োজন হয়)
ফটো পিকারের ইউজার ইন্টারফেস একটি প্রতিক্রিয়াশীল ব্যবহারকারীর অভিজ্ঞতাকে অগ্রাধিকার দেয় এবং একটি প্রতিক্রিয়ার জন্য অনির্দিষ্টকালের জন্য অপেক্ষা করবে না। মসৃণ মিথস্ক্রিয়া বজায় রাখতে, টাইমআউট ঘটতে পারে। যেকোন ফিরে আসা Cursor
এখনও ভবিষ্যতের সেশনের জন্য ফটো পিকারের ডাটাবেসে প্রক্রিয়া করার চেষ্টা করবে।
এই পদ্ধতিটি onGetMediaCollectionInfo()
দ্বারা প্রত্যাবর্তিত বর্তমান সরবরাহকারী সংস্করণের মধ্যে সমগ্র মিডিয়া সংগ্রহের সমস্ত মুছে ফেলা মিডিয়া আইটেমগুলির প্রতিনিধিত্ব করে একটি Cursor
প্রদান করে। এই আইটেমগুলি ঐচ্ছিকভাবে অতিরিক্ত দ্বারা ফিল্টার করা যেতে পারে। ক্লাউড মিডিয়া প্রদানকারীকে অবশ্যই CloudMediaProviderContract#EXTRA_MEDIA_COLLECTION_ID
ফেরত দেওয়া Cursor#setExtras
সেট না করা এটি একটি ত্রুটি এবং Cursor
অকার্যকর করে। যদি প্রদানকারী প্রদত্ত অতিরিক্তগুলিতে কোনো ফিল্টার পরিচালনা করে, তাহলে এটি অবশ্যই ContentResolver#EXTRA_HONORED_ARGS
এ কী যোগ করতে হবে।
অন কোয়েরি অ্যালবাম
onQueryAlbums()
পদ্ধতিটি ক্লাউড সরবরাহকারীতে উপলব্ধ ক্লাউড অ্যালবামের একটি তালিকা এবং তাদের সম্পর্কিত মেটাডেটা আনতে ব্যবহৃত হয়। অতিরিক্ত বিবরণের জন্য CloudMediaProviderContract.AlbumColumns
দেখুন।
এই পদ্ধতিটি মিডিয়া সংগ্রহের সমস্ত অ্যালবাম আইটেমের প্রতিনিধিত্ব করে একটি Cursor
প্রদান করে যা ঐচ্ছিকভাবে প্রদত্ত অতিরিক্ত দ্বারা ফিল্টার করা হয় এবং AlbumColumns#DATE_TAKEN_MILLIS
এর বিপরীত কালানুক্রমিক ক্রমে সাজানো হয়, সবচেয়ে সাম্প্রতিক আইটেমগুলি প্রথমে। ক্লাউড মিডিয়া প্রদানকারীকে অবশ্যই CloudMediaProviderContract#EXTRA_MEDIA_COLLECTION_ID
ফিরে আসা Cursor
অংশ হিসেবে সেট করতে হবে। এটি সেট না করা একটি ত্রুটি এবং ফিরে আসা Cursor
অবৈধ করে। যদি প্রদানকারী প্রদত্ত অতিরিক্তগুলিতে কোনো ফিল্টার পরিচালনা করে, তাহলে এটিকে অবশ্যই ফিরে আসা Cursor
অংশ হিসাবে ContentResolver#EXTRA_HONORED_ARGS
এ কী যোগ করতে হবে।
ওপেনমিডিয়া
onOpenMedia()
পদ্ধতিটি প্রদত্ত mediaId
দ্বারা চিহ্নিত পূর্ণ আকারের মিডিয়া প্রদান করবে। ডিভাইসে সামগ্রী ডাউনলোড করার সময় যদি এই পদ্ধতিটি অবরুদ্ধ হয়, তবে পরিত্যক্ত অনুরোধগুলি বাতিল করার জন্য আপনাকে পর্যায়ক্রমে প্রদত্ত CancellationSignal
পরীক্ষা করা উচিত।
onOpenPreview
onOpenPreview()
পদ্ধতিটি প্রদত্ত মিডিয়াআইডির আইটেমের জন্য প্রদত্ত size
একটি থাম্বনেইল ফিরিয়ে দেবে। থাম্বনেইলটি মূল CloudMediaProviderContract.MediaColumns#MIME_TYPE
এ হওয়া উচিত এবং এটি onOpenMedia
দ্বারা ফেরত আইটেমের তুলনায় অনেক কম রেজোলিউশন হবে বলে আশা করা হচ্ছে। ডিভাইসে সামগ্রী ডাউনলোড করার সময় যদি এই পদ্ধতিটি অবরুদ্ধ করা হয়, তবে পরিত্যক্ত অনুরোধগুলি বাতিল করার জন্য আপনাকে পর্যায়ক্রমে প্রদত্ত CancellationSignal
পরীক্ষা করা উচিত।
onCreateCloudMediaSurfaceController
onCreateCloudMediaSurfaceController()
পদ্ধতিটি মিডিয়া আইটেমগুলির প্রিভিউ রেন্ডার করার জন্য ব্যবহৃত একটি CloudMediaSurfaceController
ফেরত দেওয়া উচিত, বা পূর্বরূপ রেন্ডারিং সমর্থিত না হলে null
।
CloudMediaSurfaceController
Surface
প্রদত্ত উদাহরণগুলিতে মিডিয়া আইটেমগুলির পূর্বরূপ রেন্ডারিং পরিচালনা করে। এই ক্লাসের পদ্ধতিগুলি অ্যাসিঙ্ক্রোনাস বোঝানো হয়, এবং কোনও ভারী অপারেশন করে ব্লক করা উচিত নয়। একটি একক CloudMediaSurfaceController
উদাহরণ একাধিক পৃষ্ঠের সাথে যুক্ত একাধিক মিডিয়া আইটেম রেন্ডার করার জন্য দায়ী।
CloudMediaSurfaceController
লাইফসাইকেল কলব্যাকের নিম্নলিখিত তালিকার জন্য সমর্থন রয়েছে:
-
onConfigChange
-
onDestroy
-
onMediaPause
-
onMediaPlay
-
onMediaSeekTo
-
onPlayerCreate
-
onPlayerRelease
-
onSurfaceChanged
-
onSurfaceCreated
-
onSurfaceDestroyed