انتخابگر عکس یک رابط قابل مرور ارائه می دهد که کتابخانه رسانه ای خود را به کاربر ارائه می دهد که بر اساس تاریخ از جدیدترین به قدیمی ترین مرتب شده است. همانطور که در بهترین شیوههای حریم خصوصی نشان داده شده است، انتخابگر عکس راهی ایمن و داخلی را در اختیار کاربران قرار میدهد تا به برنامه شما به جای کل کتابخانه رسانه خود، فقط به تصاویر و ویدیوهای انتخابی دسترسی داشته باشند.
کاربرانی که ارائه دهندگان رسانه ابری واجد شرایط را در دستگاه خود دارند همچنین می توانند از بین عکس ها و ویدیوهای ذخیره شده از راه دور انتخاب کنند. درباره ارائه دهندگان رسانه ابری بیشتر بیاموزید .
این ابزار بهطور خودکار بهروزرسانی میشود و در طول زمان بدون نیاز به تغییر کد، قابلیتهای گستردهتری را به کاربران برنامه شما ارائه میدهد.
از قراردادهای Jetpack Activity استفاده کنید
برای سادهسازی ادغام انتخابگر عکس، نسخه 1.7.0 یا بالاتر از کتابخانه androidx.activity
را اضافه کنید.
از قراردادهای نتیجه فعالیت زیر برای راه اندازی انتخابگر عکس استفاده کنید:
- برای انتخاب یک تصویر یا ویدیو،
PickVisualMedia
. -
PickMultipleVisualMedia
برای انتخاب چندین تصویر یا ویدیو انتخاب کنید .
اگر انتخابگر عکس در دستگاهی در دسترس نباشد، کتابخانه بهجای آن بهطور خودکار عمل قصد ACTION_OPEN_DOCUMENT
را فراخوانی میکند. این هدف در دستگاههایی که اندروید 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()
فراخوانی کنید. در دستگاههایی که انتخابگر عکس پشتیبانی نمیشود، این محدودیت نادیده گرفته میشود.
در دسترس بودن دستگاه
انتخابگر عکس در دستگاههایی موجود است که معیارهای زیر را دارند:
- اندروید 11 (سطح API 30) یا بالاتر را اجرا کنید
- تغییرات اجزای سیستم مدولار را از طریق بهروزرسانیهای سیستم Google دریافت کنید
دستگاههای قدیمیتر که از Android 4.4 (سطح API 19) تا Android 10 (سطح API 29) استفاده میکنند و دستگاههای Android Go دارای Android 11 یا 12 که از خدمات Google Play پشتیبانی میکنند، میتوانند نسخه پشتیبانشده انتخابگر عکس را نصب کنند. برای فعال کردن نصب خودکار ماژول انتخابگر عکس پشتیبانشده از طریق سرویسهای 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);