ফটো পিকার

আপনার ডিভাইসের মিডিয়া ফাইলগুলির সাথে ফটো পিকার ডায়ালগটি প্রদর্শিত হবে। অ্যাপের সাথে শেয়ার করার জন্য একটি ফটো নির্বাচন করুন।
চিত্র ১. ফটো পিকার আপনার অ্যাপের সাথে ছবি শেয়ার করার জন্য একটি স্বজ্ঞাত UI প্রদান করে।

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

যেসব ব্যবহারকারীর ডিভাইসে যোগ্য ক্লাউড মিডিয়া প্রোভাইডার আছে তারা দূরবর্তীভাবে সংরক্ষিত ফটো এবং ভিডিও থেকেও নির্বাচন করতে পারবেন। ক্লাউড মিডিয়া প্রোভাইডার সম্পর্কে আরও জানুন

এই টুলটি স্বয়ংক্রিয়ভাবে আপডেট হয়, যা সময়ের সাথে সাথে আপনার অ্যাপের ব্যবহারকারীদের কোনও কোড পরিবর্তন ছাড়াই বর্ধিত কার্যকারিতা প্রদান করে।

জেটপ্যাক অ্যাক্টিভিটি চুক্তি ব্যবহার করুন

ফটো পিকার ইন্টিগ্রেশন সহজ করার জন্য, androidx.activity লাইব্রেরির 1.7.0 বা তার বেশি সংস্করণ অন্তর্ভুক্ত করুন।

ফটো পিকার চালু করতে নিম্নলিখিত কার্যকলাপ ফলাফল চুক্তিগুলি ব্যবহার করুন:

যদি কোনও ডিভাইসে ফটো পিকার উপলব্ধ না থাকে, তাহলে লাইব্রেরি স্বয়ংক্রিয়ভাবে ACTION_OPEN_DOCUMENT ইন্টেন্ট অ্যাকশন চালু করে। এই ইন্টেন্টটি Android 4.4 (API লেভেল 19) বা তার বেশি চালিত ডিভাইসগুলিতে সমর্থিত। আপনি isPhotoPickerAvailable() কল করে কোনও নির্দিষ্ট ডিভাইসে ফটো পিকার উপলব্ধ কিনা তা যাচাই করতে পারেন।

একটি একক মিডিয়া আইটেম নির্বাচন করুন

একটি একক মিডিয়া আইটেম নির্বাচন করতে, নিম্নলিখিত কোড স্নিপেটে দেখানো PickVisualMedia কার্যকলাপ ফলাফল চুক্তি ব্যবহার করুন:

প্রকার

// Registers a photo picker activity launcher in single-select mode.
val pickMedia = registerForActivityResult(PickVisualMedia()) { uri ->
    // Callback is invoked after the user selects a media item or closes the
    // photo picker.
    if (uri != null) {
        Log.d("PhotoPicker", "Selected URI: $uri")
    } else {
        Log.d("PhotoPicker", "No media selected")
    }
}

// Include only one of the following calls to launch(), depending on the types
// of media that you want to let the user choose from.

// Launch the photo picker and let the user choose images and videos.
pickMedia.launch(PickVisualMediaRequest(PickVisualMedia.ImageAndVideo))

// Launch the photo picker and let the user choose only images.
pickMedia.launch(PickVisualMediaRequest(PickVisualMedia.ImageOnly))

// Launch the photo picker and let the user choose only videos.
pickMedia.launch(PickVisualMediaRequest(PickVisualMedia.VideoOnly))

// Launch the photo picker and let the user choose only images/videos of a
// specific MIME type, such as GIFs.
val mimeType = "image/gif"
pickMedia.launch(PickVisualMediaRequest(PickVisualMedia.SingleMimeType(mimeType)))

প্রকার

// Registers a photo picker activity launcher in single-select mode.
ActivityResultLauncher<PickVisualMediaRequest> pickMedia =
        registerForActivityResult(new PickVisualMedia(), uri -> {
    // Callback is invoked after the user selects a media item or closes the
    // photo picker.
    if (uri != null) {
        Log.d("PhotoPicker", "Selected URI: " + uri);
    } else {
        Log.d("PhotoPicker", "No media selected");
    }
});

// Include only one of the following calls to launch(), depending on the types
// of media that you want to let the user choose from.

// Launch the photo picker and let the user choose images and videos.
pickMedia.launch(new PickVisualMediaRequest.Builder()
        .setMediaType(PickVisualMedia.ImageAndVideo.INSTANCE)
        .build());

// Launch the photo picker and let the user choose only images.
pickMedia.launch(new PickVisualMediaRequest.Builder()
        .setMediaType(PickVisualMedia.ImageOnly.INSTANCE)
        .build());

// Launch the photo picker and let the user choose only videos.
pickMedia.launch(new PickVisualMediaRequest.Builder()
        .setMediaType(PickVisualMedia.VideoOnly.INSTANCE)
        .build());

// Launch the photo picker and let the user choose only images/videos of a
// specific MIME type, such as GIFs.
String mimeType = "image/gif";
pickMedia.launch(new PickVisualMediaRequest.Builder()
        .setMediaType(new PickVisualMedia.SingleMimeType(mimeType))
        .build());

রচনা করুন

// Registers a photo picker activity launcher in single-select mode.
val pickMedia = rememberLauncherForActivityResult(PickVisualMedia()) { uri ->
    // Callback is invoked after the user selects a media item or closes the
    // photo picker.
    if (uri != null) {
        Log.d("PhotoPicker", "Selected URI: $uri")
    } else {
        Log.d("PhotoPicker", "No media selected")
    }
}

// Include only one of the following calls to launch(), depending on the types
// of media that you want to let the user choose from.

// Launch the photo picker and let the user choose images and videos.
pickMedia.launch(PickVisualMediaRequest(PickVisualMedia.ImageAndVideo))

// Launch the photo picker and let the user choose only images.
pickMedia.launch(PickVisualMediaRequest(PickVisualMedia.ImageOnly))

// Launch the photo picker and let the user choose only videos.
pickMedia.launch(PickVisualMediaRequest(PickVisualMedia.VideoOnly))

// Launch the photo picker and let the user choose only images/videos of a
// specific MIME type, such as GIFs.
val mimeType = "image/gif"
pickMedia.launch(PickVisualMediaRequest(PickVisualMedia.SingleMimeType(mimeType)))

একাধিক মিডিয়া আইটেম নির্বাচন করুন

একাধিক মিডিয়া আইটেম নির্বাচন করতে, নিম্নলিখিত কোড স্নিপেটে দেখানো হিসাবে, সর্বাধিক সংখ্যক নির্বাচনযোগ্য মিডিয়া ফাইল সেট করুন।

প্রকার

// Registers a photo picker activity launcher in multi-select mode.
// In this example, the app lets the user select up to 5 media files.
val pickMultipleMedia =
        registerForActivityResult(PickMultipleVisualMedia(5)) { uris ->
    // Callback is invoked after the user selects media items or closes the
    // photo picker.
    if (uris.isNotEmpty()) {
        Log.d("PhotoPicker", "Number of items selected: ${uris.size}")
    } else {
        Log.d("PhotoPicker", "No media selected")
    }
}

// For this example, launch the photo picker and let the user choose images
// and videos. If you want the user to select a specific type of media file,
// use the overloaded versions of launch(), as shown in the section about how
// to select a single media item.
pickMultipleMedia.launch(PickVisualMediaRequest(PickVisualMedia.ImageAndVideo))

প্রকার

// Registers a photo picker activity launcher in multi-select mode.
// In this example, the app lets the user select up to 5 media files.
ActivityResultLauncher<PickVisualMediaRequest> pickMultipleMedia =
        registerForActivityResult(new PickMultipleVisualMedia(5), uris -> {
    // Callback is invoked after the user selects media items or closes the
    // photo picker.
    if (!uris.isEmpty()) {
        Log.d("PhotoPicker", "Number of items selected: " + uris.size());
    } else {
        Log.d("PhotoPicker", "No media selected");
    }
});

// For this example, launch the photo picker and let the user choose images
// and videos. If you want the user to select a specific type of media file,
// use the overloaded versions of launch(), as shown in the section about how
// to select a single media item.
pickMultipleMedia.launch(new PickVisualMediaRequest.Builder()
        .setMediaType(PickVisualMedia.ImageAndVideo.INSTANCE)
        .build());

রচনা করুন

// Registers a photo picker activity launcher in multi-select mode.
// In this example, the app lets the user select up to 5 media files.
val pickMultipleMedia =
        rememberLauncherForActivityResult(PickMultipleVisualMedia(5)) { uris ->
    // Callback is invoked after the user selects media items or closes the
    // photo picker.
    if (uris.isNotEmpty()) {
        Log.d("PhotoPicker", "Number of items selected: ${uris.size}")
    } else {
        Log.d("PhotoPicker", "No media selected")
    }
}

// For this example, launch the photo picker and let the user choose images
// and videos. If you want the user to select a specific type of media file,
// use the overloaded versions of launch(), as shown in the section about how
// to select a single media item.
pickMultipleMedia.launch(PickVisualMediaRequest(PickVisualMedia.ImageAndVideo))

এই প্ল্যাটফর্মটি ব্যবহারকারীকে ফটো পিকারে সর্বোচ্চ কতগুলি ফাইল নির্বাচন করতে বলতে পারে তার সীমা নির্ধারণ করে। এই সীমা অ্যাক্সেস করতে, getPickImagesMaxLimit() এ কল করুন। যেসব ডিভাইসে ফটো পিকার সমর্থিত নয়, সেখানে এই সীমা উপেক্ষা করা হয়।

ডিভাইসের প্রাপ্যতা

নিম্নলিখিত মানদণ্ড পূরণ করে এমন ডিভাইসগুলিতে ফটো পিকার উপলব্ধ:

Android 4.4 (API লেভেল 19) থেকে Android 10 (API লেভেল 29) পর্যন্ত চলমান পুরোনো ডিভাইস এবং Google Play পরিষেবা সমর্থন করে এমন Android 11 বা 12 চালিত Android Go ডিভাইসগুলি ফটো পিকারের একটি ব্যাকপোর্টেড সংস্করণ ইনস্টল করতে পারে। Google Play পরিষেবাগুলির মাধ্যমে ব্যাকপোর্টেড ফটো পিকার মডিউলের স্বয়ংক্রিয় ইনস্টলেশন সক্ষম করতে, আপনার অ্যাপের ম্যানিফেস্ট ফাইলে <application> ট্যাগে নিম্নলিখিত এন্ট্রি যোগ করুন:

<!-- Trigger Google Play services to install the backported photo picker module. -->
<service android:name="com.google.android.gms.metadata.ModuleDependencies"
         android:enabled="false"
         android:exported="false"
         tools:ignore="MissingClass">
    <intent-filter>
        <action android:name="com.google.android.gms.metadata.MODULE_DEPENDENCIES" />
    </intent-filter>
    <meta-data android:name="photopicker_activity:0:required" android:value="" />
</service>

মিডিয়া ফাইল অ্যাক্সেস বজায় রাখুন

ডিফল্টরূপে, ডিভাইসটি পুনরায় চালু না হওয়া পর্যন্ত বা আপনার অ্যাপটি বন্ধ না হওয়া পর্যন্ত সিস্টেমটি আপনার অ্যাপটিকে মিডিয়া ফাইলগুলিতে অ্যাক্সেস দেয়। যদি আপনার অ্যাপটি দীর্ঘ সময় ধরে কাজ করে, যেমন ব্যাকগ্রাউন্ডে একটি বড় ফাইল আপলোড করা, তাহলে আপনার এই অ্যাক্সেসটি দীর্ঘ সময়ের জন্য বজায় রাখার প্রয়োজন হতে পারে। এটি করার জন্য, takePersistableUriPermission() পদ্ধতিটি কল করুন:

কোটলিন

val flag = Intent.FLAG_GRANT_READ_URI_PERMISSION
context.contentResolver.takePersistableUriPermission(uri, flag)

জাভা

int flag = Intent.FLAG_GRANT_READ_URI_PERMISSION;
context.contentResolver.takePersistableUriPermission(uri, flag);

ট্রান্সকোডিং সহ HDR ভিডিও পরিচালনা করুন

অ্যান্ড্রয়েড ১৩ (এপিআই ৩৩) হাই ডাইনামিক রেঞ্জ (এইচডিআর) ভিডিও ক্যাপচার করার ক্ষমতা চালু করেছে। যদিও এইচডিআর আরও সমৃদ্ধ ভিজ্যুয়াল অভিজ্ঞতা প্রদান করে, কিছু পুরানো অ্যাপ এই নতুন ফর্ম্যাটগুলি পরিচালনা করার জন্য সজ্জিত নাও হতে পারে, যার ফলে প্লেব্যাকের সময় অস্বাভাবিক রঙের উপস্থাপনা (যেমন সবুজ রঙের মুখ) এর মতো সমস্যা দেখা দেয়। এই সামঞ্জস্যের ব্যবধান দূর করার জন্য, ফটো পিকার একটি ট্রান্সকোডিং বৈশিষ্ট্য অফার করে যা অনুরোধকারী অ্যাপে সরবরাহ করার আগে স্বয়ংক্রিয়ভাবে এইচডিআর ভিডিওগুলিকে স্ট্যান্ডার্ড ডাইনামিক রেঞ্জ (এসডিআর) ফর্ম্যাটে রূপান্তর করতে পারে।

ফটো পিকার ট্রান্সকোডিংয়ের প্রাথমিক লক্ষ্য হল বিস্তৃত অ্যাপ্লিকেশনগুলিতে, এমনকি যেসব অ্যাপ্লিকেশনে এখনও স্পষ্ট HDR সমর্থন নেই, সেগুলিতেও একটি ধারাবাহিক এবং দৃশ্যত নির্ভুল মিডিয়া অভিজ্ঞতা নিশ্চিত করা। HDR ভিডিওকে SDR-তে ট্রান্সকোড করার মাধ্যমে, ফটো পিকার অ্যাপের সামঞ্জস্য উন্নত করতে এবং একটি নির্বিঘ্ন ব্যবহারকারীর অভিজ্ঞতা প্রদানের লক্ষ্য রাখে।

ফটো পিকার ট্রান্সকোডিং কীভাবে কাজ করে

ফটো পিকার HDR ট্রান্সকোডিং ডিফল্টভাবে সক্ষম করা থাকে না। এই বৈশিষ্ট্যটি সক্ষম করতে, ফটো পিকার চালু করার সময় আপনার অ্যাপকে তার মিডিয়া ফর্ম্যাট পরিচালনার ক্ষমতা স্পষ্টভাবে ঘোষণা করতে হবে।

আপনার অ্যাপটি ফটো পিকারকে তার মিডিয়া প্রসেসিং ক্ষমতা প্রদান করে। PickVisualMediaRequest.BuildermediaCapabilities যোগ করে AndroidX Activity লাইব্রেরি ব্যবহার করে ফটো পিকার চালু করার সময় এটি করা হয়। এটি সহজতর করার জন্য PickVisualMediaRequest.Builder এ একটি নতুন API, setMediaCapabilitiesForTranscoding(capabilities: MediaCapabilities?) যোগ করা হয়েছে।

আপনি MediaCapabilities ক্লাস ব্যবহার করে HDR ট্রান্সকোডিং আচরণ নিয়ন্ত্রণ করতে পারেন। আপনার অ্যাপ কোন HDR প্রকারগুলি সমর্থন করে তা নির্দিষ্ট করে একটি MediaCapabilities অবজেক্ট সরবরাহ করুন (যেমন, TYPE_HLG10 , TYPE_HDR10 , TYPE_HDR10_PLUS , TYPE_DOLBY_VISION )।

ট্রান্সকোডিং সম্পূর্ণরূপে অক্ষম করতে, MediaCapabilities এর জন্য null পাস করুন। আপনার প্রদত্ত ক্ষমতাগুলিতে স্পষ্টভাবে তালিকাভুক্ত না থাকা যেকোনো HDR প্রকার অসমর্থিত বলে বিবেচিত হবে। এই APIটি Android 13 (API লেভেল 33) এবং উচ্চতর সংস্করণে সমর্থিত এবং @RequiresApi(Build.VERSION_CODES.TIRAMISU) দিয়ে টীকাযুক্ত।

import androidx.activity.result.PickVisualMediaRequest
import androidx.activity.result.contract.ActivityResultContracts.PickVisualMedia
import androidx.annotation.RequiresApi
import android.os.Build
import android.util.Log
import android.provider.MediaStore

// Registers a photo picker activity launcher.
val pickMedia = registerForActivityResult(PickVisualMedia()) { uri ->
    // Callback invoked after media selected or picker activity closed.
    if (uri != null) {
        Log.d("photo picker", "Selected URI: $uri")
    } else {
        Log.d("photo picker", "No media selected")
    }
}

@RequiresApi(Build.VERSION_CODES.TIRAMISU)
fun launchPhotoPickerWithTranscodingSupport() {
    val mediaCapabilities = MediaCapabilities.Builder()
        .addSupportedHdrType(MediaCapabilities.HdrType.TYPE_HLG10)
        .build()

    // Launch the photo picker and let the user choose only videos with
    // transcoding enabled.
    pickMedia.launch(PickVisualMediaRequest.Builder()
        .setMediaType(PickVisualMedia.VideoOnly)
        .setMediaCapabilitiesForTranscoding(mediaCapabilities)
        .build())
}

ফটো পিকারের মাধ্যমে ট্রান্সকোডিং অ্যাপের মিডিয়া ক্ষমতা এবং নির্বাচিত ভিডিও উভয়ের উপর ভিত্তি করে করা হয়। ট্রান্সকোডিং করা হলে ট্রান্সকোড করা ভিডিওতে একটি URI ফেরত পাঠানো হয়।

এইচডিআর ট্রান্সকোডিংয়ের জন্য গুরুত্বপূর্ণ বিবেচ্য বিষয়গুলি

  • কর্মক্ষমতা এবং সঞ্চয়স্থান: ট্রান্সকোডিং প্রক্রিয়াকরণে সময় নেয় এবং একটি নতুন ফাইল তৈরি করে, যা সঞ্চয়স্থানের স্থান গ্রহণ করে।
  • ভিডিও দৈর্ঘ্যের সীমা: ব্যবহারকারীর অভিজ্ঞতা এবং স্টোরেজ সীমাবদ্ধতার ভারসাম্য বজায় রাখার জন্য, ভিডিও দৈর্ঘ্যের সীমা ১ মিনিট।
  • ক্যাশেড ফাইল ব্যবস্থাপনা: অতিরিক্ত স্টোরেজ ব্যবহার রোধ করার জন্য নিষ্ক্রিয় রক্ষণাবেক্ষণের সময় ক্যাশেড ট্রান্সকোডেড ফাইলগুলি পর্যায়ক্রমে সাফ করা হয়।
  • ডিভাইসের উপলব্ধতা: ফটো পিকার ট্রান্সকোডিং Android 13 (API লেভেল 33) এবং পরবর্তী সংস্করণগুলিতে সমর্থিত।
  • AndroidX অ্যাক্টিভিটি ইন্টিগ্রেশন: নিশ্চিত করুন যে আপনি AndroidX অ্যাক্টিভিটি লাইব্রেরির 1.11.0-alpha01 সংস্করণ অথবা পরবর্তী আলফা/বিটা/আরসি/স্টেবল রিলিজ ব্যবহার করছেন, কারণ এতে প্রয়োজনীয় setMediaCapabilitiesForTranscoding API অন্তর্ভুক্ত রয়েছে।