आसानी से फ़ोकस करने के लिए विज़ुअल संकेत दें
मटीरियल थीम के सभी फ़ोकस करने लायक एलिमेंट पर पहले से ही फ़ोकस स्टाइल मौजूद है जो थीम से मेल खाते हैं, आपको कस्टम बनाने के लिए कुछ विज़ुअल एलिमेंट जोड़ने पड़ सकते हैं फ़ोकस किए गए एलिमेंट को पहचानना आसान होता है. एक अच्छा समाधान यह है कि आप अपने समाचार खाते का बॉर्डर आपका एलिमेंट जिसका रंग बैकग्राउंड के साथ अच्छा कंट्रास्ट हो:
var color by remember { mutableStateOf(Color.White) } Card( modifier = Modifier .onFocusChanged { color = if (it.isFocused) Red else White } .border(5.dp, color) ) {}
इस उदाहरण में, remember
का इस्तेमाल बॉर्डर के रंग को सेव करने के लिए किया जाता है
रीकंपोज़िशन और हर बार एलिमेंट के आउटलाइन को अपडेट कर दिया जाता है.
फ़ोकस बदल जाता है या खो जाता है.
बेहतर विज़ुअल क्यू लागू करना
Jetpack Compose की मदद से, बेहतर और ऐडवांस विज़ुअल भी बनाया जा सकता है ऐसे क्यू जो आपके यूज़र इंटरफ़ेस (यूआई) के साथ बेहतर तरीके से मेल खाते हैं.
- सबसे पहले, एक ऐसा
IndicationInstance
बनाएं जो आपके यूज़र इंटरफ़ेस में आपकी पसंद के मुताबिक ड्रॉ करता हो:private class MyHighlightIndicationInstance(isEnabledState: State<Boolean>) : IndicationInstance { private val isEnabled by isEnabledState override fun ContentDrawScope.drawIndication() { drawContent() if (isEnabled) { drawRect(size = size, color = Color.White, alpha = 0.2f) } } }
- इसके बाद, एक
Indication
बनाएं और फ़ोकस की गई स्थिति याद रखें:class MyHighlightIndication : Indication { @Composable override fun rememberUpdatedInstance(interactionSource: InteractionSource): IndicationInstance { val isFocusedState = interactionSource.collectIsFocusedAsState() return remember(interactionSource) { MyHighlightIndicationInstance(isEnabledState = isFocusedState) } } }
indication()
मॉडिफ़ायर की मदद से, यूज़र इंटरफ़ेस (यूआई) मेंIndication
औरInteractionSource
, दोनों जोड़ें:val highlightIndication = remember { MyHighlightIndication() } var interactionSource = remember { MutableInteractionSource() } Card( modifier = Modifier .clickable( interactionSource = interactionSource, indication = highlightIndication, enabled = true, onClick = { } ) ) {}
फ़ोकस की स्थिति को समझना
आम तौर पर, जब भी फ़ोकस की स्थिति बदलती है, तब FocusEvent
ट्रिगर होता है
पेड़ और एक focusable()
संशोधक के अभिभावक इसे सुन सकते हैं
onFocusChanged()
मॉडिफ़ायर.
अगर आपको फ़ोकस की स्थिति के बारे में जानना है,तो इन एपीआई को एक साथ इस्तेमाल किया जा सकता है
onFocusChanged
मॉडिफ़ायर का इस्तेमाल करके:
- अगर वह कंपोज़ेबल, जिससे मॉडिफ़ायर जुड़ा है, तो
isFocused
true
वैल्यू दिखाता है फ़ोकस्ड है hasFocus
,isFocused
की तरह ही काम करता है. हालांकि, यह काफ़ी अलग होता है: केवल वर्तमान की जांच करने के बजाय, यह जांच करता है कि बच्चों पर फ़ोकस होता है- फ़ोकस को होल्ड पर रखने पर
isCaptured
,true
दिखाता है. ऐसा होता है, उदाहरण के लिए, जब किसीTextField
में गलत डेटा हो, जिससे फ़ोकस करने की कोशिश की जा रही हो अन्य एलिमेंट फ़ोकस को साफ़ नहीं कर पाएंगे.
ये फ़ील्ड नीचे दिखाए गए हैं:
Modifier.onFocusChanged {
val isFocused = it.isFocused
val hasFocus = it.hasFocus
val isCaptured= it.isCaptured
}
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
आपके लिए सुझाव
- ध्यान दें: JavaScript बंद होने पर लिंक टेक्स्ट दिखता है
- फ़ोकस के व्यवहार में बदलाव करना
- Compose में मटीरियल डिज़ाइन 2
- उपयोगकर्ता के इनपुट मैनेज करें