एंबेड किया गया फ़ोटो पिकर: आपके ऐप्लिकेशन में, निजी तौर पर फ़ोटो और वीडियो का अनुरोध करने का एक आसान तरीका
Android के फ़ोटो पिकर का इस्तेमाल करने के नए और शानदार तरीके से, अपने ऐप्लिकेशन के उपयोगकर्ता अनुभव को बेहतर बनाने के लिए तैयार हो जाएं! एंबेड किया गया नया फ़ोटो पिकर, उपयोगकर्ताओं को आपके ऐप्लिकेशन के इंटरफ़ेस में ही फ़ोटो और वीडियो चुनने का आसान और निजता को ध्यान में रखकर बनाया गया तरीका उपलब्ध कराता है. अब आपका ऐप्लिकेशन, फ़ोटो पिकर के साथ मिलने वाले सभी फ़ायदों का इस्तेमाल कर सकता है. इनमें क्लाउड पर मौजूद कॉन्टेंट का ऐक्सेस भी शामिल है, जिसे सीधे तौर पर आपके ऐप्लिकेशन के अनुभव में इंटिग्रेट किया गया है.
एंबेड करने की सुविधा क्यों?
हम जानते हैं कि कई ऐप्लिकेशन, फ़ोटो या वीडियो चुनते समय उपयोगकर्ताओं को बेहतर तरीके से इंटिग्रेट किया गया और आसान अनुभव देना चाहते हैं. एंबेड किया गया फ़ोटो पिकर, ठीक यही काम करता है. इसकी मदद से, उपयोगकर्ता आपके ऐप्लिकेशन से बाहर निकले बिना, हाल ही में ली गई अपनी फ़ोटो को तुरंत ऐक्सेस कर सकते हैं.वे अपने पसंदीदा क्लाउड मीडिया प्रोवाइडर (जैसे, Google Photos) में अपनी पूरी लाइब्रेरी भी देख सकते हैं. इसमें पसंदीदा फ़ोटो, एल्बम, और खोज की सुविधा शामिल है. इससे उपयोगकर्ताओं को ऐप्लिकेशन के बीच स्विच करने या इस बारे में चिंता करने की ज़रूरत नहीं होती कि उनकी पसंदीदा फ़ोटो स्थानीय तौर पर सेव है या क्लाउड में.
आसान इंटिग्रेशन, बेहतर निजता
एंबेड किए गए फ़ोटो पिकर की मदद से, आपके ऐप्लिकेशन को उपयोगकर्ता की फ़ोटो या वीडियो का ऐक्सेस तब तक नहीं मिलता, जब तक वे कुछ चुन नहीं लेते. इसका मतलब है कि आपके उपयोगकर्ताओं को ज़्यादा निजता और बेहतर अनुभव मिलेगा. इसके अलावा, एंबेड किया गया फ़ोटो पिकर, उपयोगकर्ताओं को क्लाउड पर मौजूद अपनी पूरी मीडिया लाइब्रेरी का ऐक्सेस देता है. वहीं, फ़ोटो ऐक्सेस करने की सामान्य अनुमति सिर्फ़ स्थानीय फ़ाइलों तक सीमित होती है.
Google Messages में एंबेड किया गया फ़ोटो पिकर
Google Messages, एंबेड किए गए फ़ोटो पिकर की सुविधा का बेहतरीन उदाहरण है. यहां बताया गया है कि Google Messages में इसे कैसे इंटिग्रेट किया गया है:
- आसानी से समझ में आने वाली जगह: फ़ोटो पिकर, कैमरे के बटन के ठीक नीचे होता है. इससे उपयोगकर्ताओं को नई फ़ोटो कैप्चर करने या पहले से मौजूद फ़ोटो चुनने का विकल्प साफ़ तौर पर दिखता है.
- डाइनैमिक झलक: उपयोगकर्ता के किसी फ़ोटो पर टैप करने के तुरंत बाद, उन्हें उसकी बड़ी झलक दिखती है. इससे उन्हें अपनी पसंद की पुष्टि करने में आसानी होती है. अगर वे फ़ोटो को चुनते हैं, तो झलक गायब हो जाती है. इससे अनुभव साफ़ और व्यवस्थित बना रहता है.
- ज़्यादा कॉन्टेंट के लिए बड़ा करना: शुरुआती व्यू को आसान बनाया गया है. इससे हाल ही में ली गई फ़ोटो को आसानी से ऐक्सेस किया जा सकता है. हालांकि, उपयोगकर्ता अपनी लाइब्रेरी में मौजूद सभी फ़ोटो और वीडियो को ब्राउज़ करने और चुनने के लिए, फ़ोटो पिकर को आसानी से बड़ा कर सकते हैं. इसमें Google Photos से क्लाउड पर मौजूद कॉन्टेंट भी शामिल है.
- उपयोगकर्ता की पसंद का ध्यान रखना: एंबेड किया गया फ़ोटो पिकर, सिर्फ़ उन फ़ोटो या वीडियो का ऐक्सेस देता है जिन्हें उपयोगकर्ता चुनता है. इसका मतलब है कि उपयोगकर्ता, फ़ोटो और वीडियो ऐक्सेस करने की अनुमतियों का अनुरोध पूरी तरह से बंद कर सकते हैं. इससे Messages को उन स्थितियों को हैंडल करने की ज़रूरत नहीं पड़ती जहां उपयोगकर्ता, फ़ोटो और वीडियो का सीमित ऐक्सेस ही देते हैं.
लागू करना
फ़ोटो पिकर Jetpack लाइब्रेरी की मदद से, एंबेड किए गए फ़ोटो पिकर को इंटिग्रेट करना आसान है.
Jetpack Compose
सबसे पहले, Jetpack फ़ोटो पिकर लाइब्रेरी को डिपेंडेंसी के तौर पर शामिल करें.
implementation("androidx.photopicker:photopicker-compose:1.0.0-alpha01")
EmbeddedPhotoPicker कंपोज़ेबल फ़ंक्शन, एंबेड किए गए फ़ोटो पिकर यूज़र इंटरफ़ेस को सीधे तौर पर Compose स्क्रीन में शामिल करने का तरीका उपलब्ध कराता है. इस कंपोज़ेबल से SurfaceView बनता है. यह एंबेड किए गए फ़ोटो पिकर यूज़र इंटरफ़ेस को होस्ट करता है. यह EmbeddedPhotoPicker सेवा से कनेक्शन मैनेज करता है, उपयोगकर्ता के इंटरैक्शन को हैंडल करता है, और चुने गए मीडिया यूआरआई को कॉलिंग ऐप्लिकेशन के साथ कम्यूनिकेट करता है.
@Composable
fun EmbeddedPhotoPickerDemo() {
// We keep track of the list of selected attachments
var attachments by remember { mutableStateOf(emptyList<Uri>()) }
val coroutineScope = rememberCoroutineScope()
// We hide the bottom sheet by default but we show it when the user clicks on the button
val scaffoldState = rememberBottomSheetScaffoldState(
bottomSheetState = rememberStandardBottomSheetState(
initialValue = SheetValue.Hidden,
skipHiddenState = false
)
)
// Customize the embedded photo picker
val photoPickerInfo = EmbeddedPhotoPickerFeatureInfo
.Builder()
// Set limit the selection to 5 items
.setMaxSelectionLimit(5)
// Order the items selection (each item will have an index visible in the photo picker)
.setOrderedSelection(true)
// Set the accent color (red in this case, otherwise it follows the device's accent color)
.setAccentColor(0xFF0000)
.build()
// The embedded photo picker state will be stored in this variable
val photoPickerState = rememberEmbeddedPhotoPickerState(
onSelectionComplete = {
coroutineScope.launch {
// Hide the bottom sheet once the user has clicked on the done button inside the picker
scaffoldState.bottomSheetState.hide()
}
},
onUriPermissionGranted = {
// We update our list of attachments with the new Uris granted
attachments += it
},
onUriPermissionRevoked = {
// We update our list of attachments with the Uris revoked
attachments -= it
}
)
SideEffect {
val isExpanded = scaffoldState.bottomSheetState.targetValue == SheetValue.Expanded
// We show/hide the embedded photo picker to match the bottom sheet state
photoPickerState.setCurrentExpanded(isExpanded)
}
BottomSheetScaffold(
topBar = {
TopAppBar(title = { Text("Embedded Photo Picker demo") })
},
scaffoldState = scaffoldState,
sheetPeekHeight = if (scaffoldState.bottomSheetState.isVisible) 400.dp else 0.dp,
sheetContent = {
Column(Modifier.fillMaxWidth()) {
// We render the embedded photo picker inside the bottom sheet
EmbeddedPhotoPicker(
state = photoPickerState,
embeddedPhotoPickerFeatureInfo = photoPickerInfo
)
}
}
) { innerPadding ->
Column(Modifier.padding(innerPadding).fillMaxSize().padding(horizontal = 16.dp)) {
Button(onClick = {
coroutineScope.launch {
// We expand the bottom sheet, which will trigger the embedded picker to be shown
scaffoldState.bottomSheetState.partialExpand()
}
}) {
Text("Open photo picker")
}
LazyVerticalGrid(columns = GridCells.Adaptive(minSize = 64.dp)) {
// We render the image using the Coil library
itemsIndexed(attachments) { index, uri ->
AsyncImage(
model = uri,
contentDescription = "Image ${index + 1}",
contentScale = ContentScale.Crop,
modifier = Modifier.clickable {
coroutineScope.launch {
// When the user clicks on the media from the app's UI, we deselect it
// from the embedded photo picker by calling the method deselectUri
photoPickerState.deselectUri(uri)
}
}
)
}
}
}
}
}व्यू
सबसे पहले, Jetpack फ़ोटो पिकर लाइब्रेरी को डिपेंडेंसी के तौर पर शामिल करें.
implementation("androidx.photopicker:photopicker:1.0.0-alpha01")
एंबेड किया गया फ़ोटो पिकर जोड़ने के लिए, आपको अपने लेआउट फ़ाइल में एक एंट्री जोड़नी होगी.
<view class="androidx.photopicker.EmbeddedPhotoPickerView"
android:id="@+id/photopicker"
android:layout_width="match_parent"
android:layout_height="match_parent" />इसके बाद, इसे अपनी गतिविधि/फ़्रैगमेंट में शुरू करें.
// We keep track of the list of selected attachments
private val _attachments = MutableStateFlow(emptyList<Uri>())
val attachments = _attachments.asStateFlow()
private lateinit var picker: EmbeddedPhotoPickerView
private var openSession: EmbeddedPhotoPickerSession? = null
val pickerListener = object EmbeddedPhotoPickerStateChangeListener {
override fun onSessionOpened (newSession: EmbeddedPhotoPickerSession) {
openSession = newSession
}
override fun onSessionError (throwable: Throwable) {}
override fun onUriPermissionGranted(uris: List<Uri>) {
_attachments += uris
}
override fun onUriPermissionRevoked (uris: List<Uri>) {
_attachments -= uris
}
override fun onSelectionComplete() {
// Hide the embedded photo picker as the user is done with the photo/video selection
}
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.main_view)
//
// Add the embedded photo picker to a bottom sheet to allow the dragging to display the full photo library
//
picker = findViewById(R.id.photopicker)
picker.addEmbeddedPhotoPickerStateChangeListener(pickerListener)
picker.setEmbeddedPhotoPickerFeatureInfo(
// Set a custom accent color
EmbeddedPhotoPickerFeatureInfo.Builder().setAccentColor(0xFF0000).build()
)
}एंबेड किए गए पिकर के साथ इंटरैक्ट करने के लिए, EmbeddedPhotoPickerSession के अलग-अलग तरीकों का इस्तेमाल किया जा सकता है.
// Notify the embedded picker of a configuration change openSession.notifyConfigurationChanged(newConfig) // Update the embedded picker to expand following a user interaction openSession.notifyPhotoPickerExpanded(/* expanded: */ true) // Resize the embedded picker openSession.notifyResized(/* width: */ 512, /* height: */ 256) // Show/hide the embedded picker (after a form has been submitted) openSession.notifyVisibilityChanged(/* visible: */ false) // Remove unselected media from the embedded picker after they have been // unselected from the host app's UI openSession.requestRevokeUriPermission(removedUris)
यह ध्यान रखना ज़रूरी है कि एंबेड किए गए फ़ोटो पिकर की सुविधा, Android 14 (एपीआई लेवल 34) या इसके बाद के वर्शन वाले उन डिवाइसों पर उपलब्ध है जिनमें एसडीके एक्सटेंशन 15 या इसके बाद का वर्शन है. फ़ोटो पिकर की सुविधा वाले डिवाइसों के बारे में ज़्यादा जानें.
उपयोगकर्ता की निजता और सुरक्षा को बेहतर बनाने के लिए, सिस्टम एंबेड किए गए फ़ोटो पिकर को इस तरह से रेंडर करता है कि कोई भी चीज़ ड्रॉ या ओवरले न हो. डिजाइन से जुड़ा यह जान-बूझकर लिया गया फ़ैसला है. इसका मतलब है कि आपके यूएक्स में, फ़ोटो पिकर के डिसप्ले एरिया को एक अलग और खास एलिमेंट के तौर पर माना जाना चाहिए. ठीक वैसे ही जैसे विज्ञापन बैनर के लिए प्लान किया जाता है.
अगर आपके पास कोई सुझाव, शिकायत या राय है, तो हमारे इश्यू ट्रैकर पर टिकट सबमिट करें.
पढ़ना जारी रखें
-
प्रॉडक्ट से जुड़ी खबरें
Android के अनुभव में, निजता और उपयोगकर्ता के कंट्रोल को सबसे ज़्यादा अहमियत दी जाती है. जिस तरह फ़ोटो पिकर की मदद से मीडिया शेयर करना सुरक्षित और आसान हो गया है, उसी तरह अब हम संपर्क चुनने के मामले में भी निजता, आसानी, और बेहतर उपयोगकर्ता अनुभव की सुविधा दे रहे हैं.
Roxanna Aliabadi Walker • पढ़ने में 4 मिनट लगेंगे
-
प्रॉडक्ट से जुड़ी खबरें
Google I/O 2026 में, हमने Android को ऑपरेटिंग सिस्टम से इंटेलिजेंस सिस्टम में बदलने की जानकारी दी. हमने यह भी दिखाया कि सिस्टम की मदद से, बेहतर अनुभव कैसे बनाए जा सकते हैं. साथ ही, अपने ऐप्लिकेशन में Google के एआई की सुविधा कैसे जोड़ी जा सकती है.
Jingyu Shi • पढ़ने में 2 मिनट लगेंगे
-
प्रॉडक्ट से जुड़ी खबरें
हमें यह बताते हुए खुशी हो रही है कि Android XR के लिए, Unreal Engine और Godot के आधिकारिक तौर पर काम करने की सुविधा उपलब्ध हो गई है. हम नए टूल भी लॉन्च कर रहे हैं. इन्हें आपकी प्रॉडक्टिविटी बढ़ाने और नए XR की सुविधाएं उपलब्ध कराने के लिए डिज़ाइन किया गया है. ये टूल हैं: Android XR Engine Hub और Android XR Interaction Framework.
Luke Hopkins, Ryan Bartley • पढ़ने में 4 मिनट लगेंगे
अप-टू-डेट रहें
Android डेवलपमेंट से जुड़ी नई जानकारी हर हफ़्ते अपने इनबॉक्स में पाएं.