মিডিয়া আর্টওয়ার্ক প্রদর্শন করুন

মিডিয়া আইটেমগুলির আর্টওয়ার্ক অবশ্যই ContentResolver.SCHEME_CONTENT অথবা ContentResolver.SCHEME_ANDROID_RESOURCE ব্যবহার করে একটি লোকাল URI হিসেবে পাস করতে হবে। এই লোকাল URI-টি অবশ্যই একটি বিটম্যাপ অথবা একটি ভেক্টর ড্রয়েবল-এ রিজলভ হতে হবে।

আপনার অ্যাপের রিসোর্স থেকে আর্টওয়ার্ক প্রদান করুন।

আপনার অ্যাপের রিসোর্স থেকে ড্রয়েবল সরবরাহ করতে, নিম্নলিখিত বিন্যাসে একটি URI পাস করুন:

android.resource://PACKAGE_NAME/RESOURCE_TYPE/RESOURCE_NAME

// Example URI - note that there is no file extension at the end of the URI
android.resource://com.example.app/drawable/example_drawable

এই কোড স্নিপেটটি দেখায় কিভাবে একটি রিসোর্স আইডি থেকে এই ফরম্যাটের একটি URI তৈরি করতে হয়:

val resources = context.resources
val resourceId: Int = R.drawable.example_drawable

Uri.Builder()
    .scheme(ContentResolver.SCHEME_ANDROID_RESOURCE)
    .authority(resources.getResourcePackageName(resourceId))
    .appendPath(resources.getResourceTypeName(resourceId))
    .appendPath(resources.getResourceEntryName(resourceId))
    .build()

একটি কন্টেন্ট প্রোভাইডার ব্যবহার করে আর্টওয়ার্ক সরবরাহ করুন।

এই ধাপগুলিতে বর্ণনা করা হয়েছে কিভাবে একটি কন্টেন্ট প্রোভাইডার ব্যবহার করে ওয়েব ইউআরআই থেকে আর্ট ডাউনলোড করে লোকাল ইউআরআই-এর মাধ্যমে তা প্রকাশ করা যায়। একটি সম্পূর্ণ উদাহরণের জন্য, ইউনিভার্সাল অ্যান্ড্রয়েড মিউজিক প্লেয়ার স্যাম্পল অ্যাপে openFile এবং এর সংশ্লিষ্ট মেথডগুলোর ইমপ্লিমেন্টেশন দেখুন।

  1. ওয়েব ইউআরআই-এর সাথে সঙ্গতিপূর্ণ একটি content:// ইউআরআই তৈরি করুন। মিডিয়া ব্রাউজার সার্ভিস এবং মিডিয়া সেশন এই content ইউআরআই-টি অ্যান্ড্রয়েড অটো এবং AAOS-এর কাছে প্রেরণ করে।

    কোটলিন

    fun Uri.asAlbumArtContentURI(): Uri {
          return Uri.Builder()
            .scheme(ContentResolver.SCHEME_CONTENT)
            .authority(CONTENT_PROVIDER_AUTHORITY)
            .appendPath(this.getPath()) // Make sure you trust the URI
            .build()
      }
    

    জাভা

    public static Uri asAlbumArtContentURI(Uri webUri) {
          return new Uri.Builder()
            .scheme(ContentResolver.SCHEME_CONTENT)
            .authority(CONTENT_PROVIDER_AUTHORITY)
            .appendPath(webUri.getPath()) // Make sure you trust the URI!
            .build();
     }
    
  2. ContentProvider.openFile এর বাস্তবায়নে, সংশ্লিষ্ট URI-এর জন্য কোনো ফাইল আছে কিনা তা পরীক্ষা করুন। যদি না থাকে, তাহলে ইমেজ ফাইলটি ডাউনলোড করে ক্যাশে করুন। এই কোড স্নিপেটটি Glide ব্যবহার করে।

    কোটলিন

    override fun openFile(uri: Uri, mode: String): ParcelFileDescriptor? {
          val context = this.context ?: return null
          val file = File(context.cacheDir, uri.path)
          if (!file.exists()) {
            val remoteUri = Uri.Builder()
                .scheme("https")
                .authority("my-image-site")
                .appendPath(uri.path)
                .build()
            val cacheFile = Glide.with(context)
                .asFile()
                .load(remoteUri)
                .submit()
                .get(DOWNLOAD_TIMEOUT_SECONDS, TimeUnit.SECONDS)
    
            cacheFile.renameTo(file)
             file = cacheFile
          }
          return ParcelFileDescriptor.open(file, ParcelFileDescriptor.MODE_READ_ONLY)
     }
    

    জাভা

    @Nullable
      @Override
      public ParcelFileDescriptor openFile(@NonNull Uri uri, @NonNull String mode)
            throws FileNotFoundException {
          Context context = this.getContext();
          File file = new File(context.getCacheDir(), uri.getPath());
          if (!file.exists()) {
            Uri remoteUri = new Uri.Builder()
                .scheme("https")
                .authority("my-image-site")
                .appendPath(uri.getPath())
                .build();
            File cacheFile = Glide.with(context)
                .asFile()
                .load(remoteUri)
                .submit()
                .get(DOWNLOAD_TIMEOUT_SECONDS, TimeUnit.SECONDS);
    
            cacheFile.renameTo(file);
            file = cacheFile;
          }
          return ParcelFileDescriptor.open(file, ParcelFileDescriptor.MODE_READ_ONLY);
      }