বড় স্ক্রিনের ডিভাইসে, ব্যবহারকারীরা প্রায়ই কীবোর্ড, মাউস, ট্র্যাকপ্যাড, স্টাইলাস বা গেমপ্যাড ব্যবহার করে অ্যাপের সাথে ইন্টারঅ্যাক্ট করে। বাহ্যিক ডিভাইসগুলি থেকে ইনপুট গ্রহণ করতে আপনার অ্যাপকে সক্ষম করতে, নিম্নলিখিতগুলি করুন:
- প্রাথমিক কীবোর্ড সমর্থন পরীক্ষা করুন , যেমন পূর্বাবস্থার জন্য Ctrl+Z , অনুলিপির জন্য Ctrl+C এবং সংরক্ষণের জন্য Ctrl+S । ডিফল্ট কীবোর্ড শর্টকাটগুলির একটি তালিকার জন্য কীবোর্ড ক্রিয়াগুলি পরিচালনা করুন দেখুন৷
- উন্নত কীবোর্ড সমর্থন পরীক্ষা করুন , উদাহরণস্বরূপ, ট্যাব কী এবং তীর কী কীবোর্ড নেভিগেশন, কী টেক্সট এন্ট্রি নিশ্চিতকরণ লিখুন এবং স্পেসবার মিডিয়া অ্যাপে প্লে এবং পজ করুন।
- প্রসঙ্গ মেনুর জন্য ডান-ক্লিক, হোভারে আইকন পরিবর্তন এবং কাস্টম উপাদানগুলিতে মাউস হুইল বা ট্র্যাকপ্যাড স্ক্রোল ইভেন্ট সহ মৌলিক মাউস ইন্টারঅ্যাকশন পরীক্ষা করুন ।
- স্টাইলাস, গেম কন্ট্রোলার এবং মিউজিক অ্যাপ MIDI কন্ট্রোলারের মতো অ্যাপ-নির্দিষ্ট ইনপুট ডিভাইস পরীক্ষা করুন ।
- উন্নত ইনপুট সমর্থন বিবেচনা করুন যা অ্যাপটিকে ডেস্কটপ পরিবেশে আলাদা করে তুলতে পারে, উদাহরণস্বরূপ, DJ অ্যাপগুলির জন্য একটি ক্রস-ফ্যাডার হিসাবে টাচপ্যাড, গেমগুলির জন্য মাউস ক্যাপচার এবং কীবোর্ড-কেন্দ্রিক ব্যবহারকারীদের জন্য কীবোর্ড শর্টকাট৷
কীবোর্ড
আপনার অ্যাপ যেভাবে কীবোর্ড ইনপুটে সাড়া দেয় তা বড় স্ক্রিনের ব্যবহারকারীর অভিজ্ঞতায় অবদান রাখে। তিন ধরনের কীবোর্ড ইনপুট রয়েছে: নেভিগেশন , কীস্ট্রোক এবং শর্টকাট ।
নেভিগেশন
স্পর্শ-কেন্দ্রিক অ্যাপগুলিতে কীবোর্ড নেভিগেশন খুব কমই প্রয়োগ করা হয়, তবে ব্যবহারকারীরা যখন একটি অ্যাপ ব্যবহার করছেন এবং একটি কীবোর্ডে তাদের হাত থাকবে তখন এটি আশা করে। কীবোর্ড নেভিগেশন ফোন, ট্যাবলেট, ফোল্ডেবল এবং ডেস্কটপ ডিভাইসে অ্যাক্সেসযোগ্যতার প্রয়োজনে ব্যবহারকারীদের জন্য অপরিহার্য হতে পারে।
অনেক অ্যাপের জন্য, অ্যারো কী এবং ট্যাব কী নেভিগেশন স্বয়ংক্রিয়ভাবে অ্যান্ড্রয়েড ফ্রেমওয়ার্ক দ্বারা পরিচালিত হয়। উদাহরণস্বরূপ, কিছু কম্পোজেবল ডিফল্টরূপে ফোকাসযোগ্য, যেমন একটি Button
বা clickable
পরিবর্তনকারী সহ একটি কম্পোজেবল; কীবোর্ড নেভিগেশন সাধারণত কোনো অতিরিক্ত কোড ছাড়াই কাজ করা উচিত। ডিফল্টরূপে ফোকাসযোগ্য নয় এমন কাস্টম কম্পোজেবলগুলির জন্য কীবোর্ড নেভিগেশন সক্ষম করতে, focusable
সংশোধক যোগ করুন:
var color by remember { mutableStateOf(Green) } Box( Modifier .background(color) .onFocusChanged { color = if (it.isFocused) Blue else Green } .focusable() ) { Text("Focusable 1") }
আরও তথ্যের জন্য, একটি রচনাযোগ্য ফোকাসযোগ্য করা দেখুন।
ফোকাস সক্ষম হলে, Android ফ্রেমওয়ার্ক তাদের অবস্থানের উপর ভিত্তি করে সমস্ত ফোকাসযোগ্য উপাদানগুলির জন্য একটি নেভিগেশনাল ম্যাপিং তৈরি করে৷ এটি সাধারণত প্রত্যাশিত হিসাবে কাজ করে এবং আর কোন উন্নয়নের প্রয়োজন নেই।
যাইহোক, কম্পোজ সবসময় ট্যাব এবং তালিকার মতো জটিল কম্পোজেবলের জন্য ট্যাবড নেভিগেশনের জন্য সঠিক পরবর্তী আইটেম নির্ধারণ করে না, উদাহরণস্বরূপ, যখন কম্পোজেবলগুলির মধ্যে একটি অনুভূমিক স্ক্রোলযোগ্য যা সম্পূর্ণরূপে দৃশ্যমান নয়।
ফোকাস আচরণ নিয়ন্ত্রণ করতে, কম্পোজেবলের সংগ্রহের প্যারেন্ট কম্পোজেবলে focusGroup
মডিফায়ার যোগ করুন। ফোকাস গ্রুপে চলে যায়, তারপর পরবর্তী ফোকাসযোগ্য উপাদানে যাওয়ার আগে গ্রুপের মাধ্যমে, উদাহরণস্বরূপ:
Row {
Column(Modifier.focusGroup()) {
Button({}) { Text("Row1 Col1") }
Button({}) { Text("Row2 Col1") }
Button({}) { Text("Row3 Col1") }
}
Column(Modifier.focusGroup()) {
Button({}) { Text("Row1 Col2") }
Button({}) { Text("Row2 Col2") }
Button({}) { Text("Row3 Col2") }
}
}
আরও তথ্যের জন্য, ফোকাস গ্রুপের সাথে সুসংগত নেভিগেশন প্রদান দেখুন।
শুধুমাত্র কীবোর্ড ব্যবহার করে আপনার অ্যাপের প্রতিটি UI উপাদানে অ্যাক্সেস পরীক্ষা করুন। প্রায়শই ব্যবহৃত উপাদানগুলি মাউস বা স্পর্শ ইনপুট ছাড়াই অ্যাক্সেসযোগ্য হওয়া উচিত।
মনে রাখবেন, অ্যাক্সেসিবিলিটি প্রয়োজন ব্যবহারকারীদের জন্য কীবোর্ড সমর্থন অপরিহার্য হতে পারে।
কীস্ট্রোক
টেক্সট ইনপুটের জন্য যা একটি অন-স্ক্রিন ভার্চুয়াল কীবোর্ড ( IME ) দ্বারা পরিচালিত হবে, যেমন এর জন্যএকটি TextField
, কোনো অতিরিক্ত ডেভেলপমেন্ট কাজ ছাড়াই বড় স্ক্রিনের ডিভাইসে অ্যাপগুলি প্রত্যাশা অনুযায়ী আচরণ করা উচিত। কীস্ট্রোকগুলির জন্য যা ফ্রেমওয়ার্ক দ্বারা অনুমান করা যায় না, অ্যাপগুলিকে নিজের আচরণটি পরিচালনা করতে হবে। এটি কাস্টম ভিউ সহ অ্যাপগুলির জন্য বিশেষভাবে সত্য৷
কিছু উদাহরণ হল চ্যাট অ্যাপ যা একটি বার্তা পাঠাতে এন্টার কী ব্যবহার করে, মিডিয়া অ্যাপ যা স্পেসবার দিয়ে প্লেব্যাক শুরু এবং বন্ধ করে এবং গেমগুলি যেগুলি w , a , s , এবং d কীগুলির সাহায্যে গতিবিধি নিয়ন্ত্রণ করে৷
আপনি onKeyEvent
সংশোধকের সাথে পৃথক কীস্ট্রোকগুলি পরিচালনা করতে পারেন, যা একটি ল্যাম্বডা গ্রহণ করে যাকে বলা হয় যখন পরিবর্তিত উপাদান একটি মূল ইভেন্ট গ্রহণ করে। KeyEvent#type
প্রপার্টি আপনাকে ইভেন্টটি কী প্রেস ( KeyDown
) নাকি কী রিলিজ ( KeyUp
) তা নির্ধারণ করতে সক্ষম করে:
Box(
modifier = Modifier.focusable().onKeyEvent {
if(
it.type == KeyEventType.KeyUp &&
it.key == Key.S
) {
doSomething()
true
} else {
false
}
}
) {
Text("Press S key")
}
বিকল্পভাবে, আপনি onKeyUp()
কলব্যাককে ওভাররাইড করতে পারেন এবং প্রতিটি প্রাপ্ত কীকোডের জন্য প্রত্যাশিত আচরণ যোগ করতে পারেন:
override fun onKeyUp(keyCode: Int, event: KeyEvent): Boolean { return when (keyCode) { KeyEvent.KEYCODE_ENTER -> { sendChatMessage() true } KeyEvent.KEYCODE_SPACE -> { playOrPauseMedia() true } else -> super.onKeyUp(keyCode, event) } }
একটি কী রিলিজ হলে একটি onKeyUp
ইভেন্ট ঘটে। কলব্যাক ব্যবহার করা অ্যাপগুলিকে একাধিক onKeyDown
ইভেন্ট প্রক্রিয়া করতে বাধা দেয় যদি একটি কী চেপে রাখা হয় বা ধীরে ধীরে ছেড়ে দেওয়া হয়। যে গেমস এবং অ্যাপগুলিকে একটি কী চাপার মুহুর্তে শনাক্ত করতে হবে বা ব্যবহারকারী একটি কী চেপে ধরে আছে কিনা সেগুলি onKeyDown
ইভেন্ট শুনতে পারে এবং বারবার onKeyDown
ইভেন্টগুলি নিজেই পরিচালনা করতে পারে।
আরও তথ্যের জন্য, কীবোর্ড ক্রিয়াগুলি হ্যান্ডেল দেখুন।
শর্টকাট
একটি হার্ডওয়্যার কীবোর্ড ব্যবহার করার সময় Ctrl , Alt , Shift , এবং Meta কীগুলি অন্তর্ভুক্ত সাধারণ কীবোর্ড শর্টকাটগুলি প্রত্যাশিত৷ যদি একটি অ্যাপ শর্টকাট প্রয়োগ না করে, অভিজ্ঞতাটি ব্যবহারকারীদের কাছে হতাশাজনক বোধ করতে পারে। উন্নত ব্যবহারকারীরা প্রায়শই ব্যবহৃত অ্যাপ-নির্দিষ্ট কাজের জন্য শর্টকাটের প্রশংসা করে। শর্টকাট একটি অ্যাপ ব্যবহার করা সহজ করে এবং শর্টকাট নেই এমন অ্যাপ থেকে এটিকে আলাদা করে।
কিছু সাধারণ শর্টকাটের মধ্যে রয়েছে Ctrl+S (সংরক্ষণ), Ctrl+Z (আনডু), এবং Ctrl+Shift+Z (পুনরায় করুন)। ডিফল্ট শর্টকাটগুলির একটি তালিকার জন্য, কীবোর্ড ক্রিয়াগুলি পরিচালনা করুন দেখুন।
একটি KeyEvent
অবজেক্টের নিম্নলিখিত বৈশিষ্ট্যগুলি রয়েছে যা নির্দেশ করে যে পরিবর্তনকারী কীগুলি চাপানো হয়েছে কিনা:
যেমন:
Box(
Modifier.onKeyEvent {
if (it.isAltPressed && it.key == Key.A) {
println("Alt + A is pressed")
true
} else {
false
}
}
.focusable()
)
আরও তথ্যের জন্য, নিম্নলিখিত দেখুন:
লেখনী
অনেক বড় পর্দার ডিভাইস একটি স্টাইলাস সহ আসে। অ্যান্ড্রয়েড অ্যাপ্লিকেশানগুলি টাচস্ক্রিন ইনপুট হিসাবে স্টাইলগুলি পরিচালনা করে৷ কিছু ডিভাইসে একটি USB বা ব্লুটুথ ড্রয়িং টেবিলও থাকতে পারে, যেমন Wacom Intuos । অ্যান্ড্রয়েড অ্যাপ ব্লুটুথ ইনপুট গ্রহণ করতে পারে কিন্তু USB ইনপুট নয়।
স্টাইলাস MotionEvent
অবজেক্ট অ্যাক্সেস করতে, অঙ্কন পৃষ্ঠে pointerInteropFilter
সংশোধক যোগ করুন। মোশন ইভেন্টগুলিকে প্রক্রিয়া করে এমন একটি পদ্ধতি সহ একটি ViewModel
ক্লাস প্রয়োগ করুন; pointerInteropFilter
মডিফায়ারের onTouchEvent
ল্যাম্বডা হিসাবে পদ্ধতিটি পাস করুন:
@Composable
@OptIn(ExperimentalComposeUiApi::class)
fun DrawArea(modifier: Modifier = Modifier) {
Canvas(modifier = modifier
.clipToBounds()
.pointerInteropFilter {
viewModel.processMotionEvent(it)
}
) {
// Drawing code here.
}
}
MotionEvent
অবজেক্টটিতে ইভেন্ট সম্পর্কে তথ্য রয়েছে:
-
MotionEvent#getToolType()
TOOL_TYPE_FINGER
,TOOL_TYPE_STYLUS
, বাTOOL_TYPE_ERASER
প্রদান করে যা ডিসপ্লের সাথে যোগাযোগ করে এমন টুলের উপর নির্ভর করে -
MotionEvent#getPressure()
স্টাইলাস কলমে প্রয়োগ করা শারীরিক চাপের রিপোর্ট করে (যদি সমর্থিত হয়) -
MotionEvent#getAxisValue()
এর সাথেMotionEvent.AXIS_TILT
এবংMotionEvent.AXIS_ORIENTATION
লেখনীর শারীরিক কাত এবং অভিযোজন প্রদান করে (যদি সমর্থিত হয়)
ঐতিহাসিক পয়েন্ট
Android ব্যাচ ইনপুট ইভেন্ট এবং প্রতি ফ্রেমে একবার সেগুলি বিতরণ করে। একটি স্টাইলাস ডিসপ্লের চেয়ে অনেক বেশি ফ্রিকোয়েন্সিতে ইভেন্ট রিপোর্ট করতে পারে। অঙ্কন অ্যাপ্লিকেশন তৈরি করার সময়, getHistorical
API ব্যবহার করে সাম্প্রতিক অতীতে হতে পারে এমন ইভেন্টগুলি পরীক্ষা করুন:
-
MotionEvent#getHistoricalX()
-
MotionEvent#getHistoricalY()
-
MotionEvent#getHistoricalPressure()
-
MotionEvent#getHistoricalAxisValue()
পাম প্রত্যাখ্যান
যখন ব্যবহারকারীরা স্টাইলাস ব্যবহার করে আপনার অ্যাপের সাথে আঁকেন, লেখেন বা ইন্টারঅ্যাক্ট করেন, তারা মাঝে মাঝে তাদের হাতের তালু দিয়ে স্ক্রীন স্পর্শ করে। টাচ ইভেন্টটি ( ACTION_DOWN
বা ACTION_POINTER_DOWN
এ সেট করা হয়েছে) আপনার অ্যাপ্লিকেশানে রিপোর্ট করা যেতে পারে তার আগে সিস্টেম অসাবধানতাবশত পামের স্পর্শকে স্বীকৃতি দেয় এবং উপেক্ষা করে৷
Android একটি MotionEvent
পাঠানোর মাধ্যমে পাম টাচ ইভেন্ট বাতিল করে। যদি আপনার অ্যাপ ACTION_CANCEL
পায়, তাহলে অঙ্গভঙ্গি বাতিল করুন। যদি আপনার অ্যাপ ACTION_POINTER_UP
পায়, তাহলে FLAG_CANCELED
সেট করা আছে কিনা তা পরীক্ষা করুন। যদি তাই হয়, অঙ্গভঙ্গি বাতিল.
শুধু FLAG_CANCELED
এর জন্য চেক করবেন না। Android 13 (API স্তর 33) এবং উচ্চতর, সিস্টেম ACTION_CANCEL
ইভেন্টগুলির জন্য FLAG_CANCELED
সেট করে, কিন্তু সিস্টেমটি নিম্ন Android সংস্করণগুলিতে পতাকা সেট করে না।
অ্যান্ড্রয়েড 12
Android 12 (API লেভেল 32) এবং তার নিচের ক্ষেত্রে, পাম প্রত্যাখ্যান সনাক্তকরণ শুধুমাত্র একক-পয়েন্টার টাচ ইভেন্টের জন্য সম্ভব। যদি একটি পাম স্পর্শই একমাত্র পয়েন্টার হয়, তবে সিস্টেমটি মোশন ইভেন্ট অবজেক্টে ACTION_CANCEL
সেট করে ইভেন্টটি বাতিল করে। অন্য পয়েন্টার ডাউন হলে, সিস্টেম ACTION_POINTER_UP
সেট করে, যা পাম প্রত্যাখ্যান সনাক্তকরণের জন্য অপর্যাপ্ত।
অ্যান্ড্রয়েড 13
অ্যান্ড্রয়েড 13 (API লেভেল 33) এবং উচ্চতর ক্ষেত্রে, যদি একটি পাম টাচই একমাত্র পয়েন্টার হয়, তাহলে সিস্টেমটি মোশন ইভেন্ট অবজেক্টে ACTION_CANCEL
এবং FLAG_CANCELED
সেট করে ইভেন্টটি বাতিল করে। যদি অন্য পয়েন্টার ডাউন থাকে, সিস্টেম ACTION_POINTER_UP
এবং FLAG_CANCELED
সেট করে।
যখনই আপনার অ্যাপ ACTION_POINTER_UP
এর সাথে একটি মোশন ইভেন্ট পায়, ইভেন্টটি পাম প্রত্যাখ্যান (বা অন্য ইভেন্ট বাতিলকরণ) নির্দেশ করে কিনা তা নির্ধারণ করতে FLAG_CANCELED
পরীক্ষা করুন।
নোট নেওয়ার অ্যাপ
ChromeOS-এর একটি বিশেষ অভিপ্রায় রয়েছে যা ব্যবহারকারীদের কাছে নিবন্ধিত নোট গ্রহণের অ্যাপগুলিকে সারফেস করে৷ একটি নোট টেকিং অ্যাপ হিসাবে একটি অ্যাপ নিবন্ধন করতে, আপনার অ্যাপ ম্যানিফেস্টে নিম্নলিখিত যোগ করুন:
<intent-filter>
<action android:name="org.chromium.arc.intent.action.CREATE_NOTE" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
যখন একটি অ্যাপ সিস্টেমের সাথে নিবন্ধিত হয়, ব্যবহারকারী এটিকে ডিফল্ট নোট-টেকিং অ্যাপ হিসেবে নির্বাচন করতে পারেন। যখন একটি নতুন নোটের জন্য অনুরোধ করা হয়, অ্যাপটিকে স্টাইলাস ইনপুটের জন্য প্রস্তুত একটি খালি নোট তৈরি করা উচিত। যখন ব্যবহারকারী একটি চিত্রকে (যেমন একটি স্ক্রিনশট বা ডাউনলোড করা ছবি) টীকা করতে চান, তখন অ্যাপটি ClipData
সহ একটি বা একাধিক আইটেম সহ content://
ইউআরআই সহ চালু হয়। অ্যাপটির এমন একটি নোট তৈরি করা উচিত যা প্রথম সংযুক্ত ছবিকে ব্যাকগ্রাউন্ড ইমেজ হিসেবে ব্যবহার করে এবং এমন একটি মোডে প্রবেশ করাতে হবে যেখানে ব্যবহারকারী স্ক্রিনে লেখনী দিয়ে আঁকতে পারে।
লেখনী ছাড়াই নোট নেওয়ার অভিপ্রায় পরীক্ষা করুন
[TBD বিভাগ সরান।]
কোনো অ্যাপ্লিকেশান সক্রিয় স্টাইলাস ছাড়াই নোট নেওয়ার অভিপ্রায়ে সঠিকভাবে সাড়া দেয় কিনা তা পরীক্ষা করতে, ChromeOS-এ নোট নেওয়ার বিকল্পগুলি প্রদর্শন করতে নিম্নলিখিত পদ্ধতিটি ব্যবহার করুন:
- ডেভ মোডে স্যুইচ করুন এবং ডিভাইসটিকে লেখার যোগ্য করুন
- একটি টার্মিনাল খুলতে Ctrl+Alt+F2 টিপুন
-
sudo vi /etc/chrome_dev.conf
কমান্ডটি চালান - ফাইলের শেষে একটি নতুন লাইনে
--ash-enable-palette
এডিট করতে এবং যোগ করতেi
টিপুন - Esc টিপে সংরক্ষণ করুন এবং তারপরে টাইপ করুন : , w , q এবং এন্টার টিপুন
- নিয়মিত ChromeOS UI-এ ফিরে যেতে Ctrl+Alt+F1 টিপুন
- লগ আউট করুন, তারপর আবার লগ ইন করুন
একটি স্টাইলাস মেনু এখন শেলফে থাকা উচিত:
- শেলফের স্টাইলাস বোতামটি আলতো চাপুন এবং নতুন নোট নির্বাচন করুন। এটি একটি ফাঁকা অঙ্কন নোট খুলতে হবে।
- একটি স্ক্রিনশট নিন। শেল্ফ থেকে, স্টাইলাস বোতাম > ক্যাপচার স্ক্রীন নির্বাচন করুন বা একটি ছবি ডাউনলোড করুন। বিজ্ঞপ্তিতে ইমেজ টীকা করার বিকল্প থাকতে হবে। এটি টীকা করার জন্য প্রস্তুত চিত্র সহ অ্যাপটি চালু করা উচিত।
মাউস এবং টাচপ্যাড সমর্থন
বেশিরভাগ অ্যাপকে সাধারণত শুধুমাত্র তিনটি বড় স্ক্রীন-কেন্দ্রিক ইভেন্ট পরিচালনা করতে হয়: ডান-ক্লিক করুন , হোভার করুন এবং টেনে আনুন এবং ড্রপ করুন ।
রাইট-ক্লিক করুন
যে কোনও অ্যাকশন যা একটি অ্যাপকে একটি প্রসঙ্গ মেনু দেখায়, যেমন একটি তালিকা আইটেম স্পর্শ করে ধরে রাখুন, ডান-ক্লিক ইভেন্টগুলিতেও প্রতিক্রিয়া দেখাতে হবে।
ডান-ক্লিক ইভেন্টগুলি পরিচালনা করতে, অ্যাপগুলির একটি View.OnContextClickListener
নিবন্ধন করা উচিত।OnContextClickListener :
Box(modifier = Modifier.fillMaxSize()) {
AndroidView(
modifier = Modifier.fillMaxSize(),
factory = { context ->
val rootView = FrameLayout(context)
val onContextClickListener =
View.OnContextClickListener { view ->
showContextMenu()
true
}
rootView.setOnContextClickListener(onContextClickListener)
rootView
},
)
}
প্রসঙ্গ মেনু নির্মাণের বিস্তারিত জানার জন্য, একটি প্রাসঙ্গিক মেনু তৈরি করুন দেখুন।
হোভার
হোভার ইভেন্টগুলি পরিচালনা করে আপনি আপনার অ্যাপ লেআউটগুলিকে মসৃণ এবং সহজে ব্যবহার করতে পারেন৷ এটি কাস্টম জন্য বিশেষভাবে সত্যউপাদান:
এর দুটি সবচেয়ে সাধারণ উদাহরণ হল:
- মাউস পয়েন্টার আইকন পরিবর্তন করে ব্যবহারকারীদের নির্দেশ করে যে একটি উপাদানের ইন্টারেক্টিভ আচরণ আছে কিনা, যেমন ক্লিকযোগ্য বা সম্পাদনাযোগ্য
- একটি বড় তালিকা বা গ্রিডে থাকা আইটেমগুলিতে ভিজ্যুয়াল ফিডব্যাক যোগ করা যখন পয়েন্টারটি তাদের উপর ঘোরাফেরা করছে
টেনে আনুন
একটি মাল্টি-উইন্ডো পরিবেশে, ব্যবহারকারীরা অ্যাপগুলির মধ্যে আইটেমগুলিকে টেনে আনতে এবং ফেলে দিতে সক্ষম হবে বলে আশা করে৷ এটি ডেস্কটপ ডিভাইসের পাশাপাশি ট্যাবলেট, ফোন এবং স্প্লিট-স্ক্রিন মোডে ফোল্ডেবলের ক্ষেত্রেও সত্য।
ব্যবহারকারীরা আপনার অ্যাপে আইটেম টেনে আনতে পারে কিনা তা বিবেচনা করুন। উদাহরণস্বরূপ, ফটো এডিটরদের ফটোগুলি পাওয়ার আশা করা উচিত, অডিও প্লেয়ারদের অডিও ফাইলগুলি পাওয়ার আশা করা উচিত এবং অঙ্কন প্রোগ্রামগুলি ফটোগুলি পাওয়ার আশা করা উচিত।
ড্র্যাগ এবং ড্রপ সমর্থন যোগ করতে, দেখুনটেনে আনুন, এবং ChromeOS-এ অ্যান্ড্রয়েডের দিকে নজর দিন — ড্র্যাগ অ্যান্ড ড্রপ ব্লগ পোস্ট বাস্তবায়ন করা ।
ChromeOS এর জন্য বিশেষ বিবেচনা
- অ্যাপের বাইরে থেকে টেনে আনা আইটেমগুলি অ্যাক্সেস করতে
requestDragAndDropPermissions()
দিয়ে অনুমতির অনুরোধ করতে ভুলবেন না অন্য অ্যাপ্লিকেশানগুলিতে টেনে আনার জন্য একটি আইটেমের
View.DRAG_FLAG_GLOBAL
পতাকা থাকতে হবে
উন্নত পয়েন্টার সমর্থন
মাউস এবং টাচপ্যাড ইনপুট উন্নত হ্যান্ডলিং যে অ্যাপ্লিকেশন একটি বাস্তবায়ন করা উচিতPointerEvent
পেতে pointerInput
সংশোধক:
@Composable private fun LogPointerEvents(filter: PointerEventType? = null) { var log by remember { mutableStateOf("") } Column { Text(log) Box( Modifier .size(100.dp) .background(Color.Red) .pointerInput(filter) { awaitPointerEventScope { while (true) { val event = awaitPointerEvent() // handle pointer event if (filter == null || event.type == filter) { log = "${event.type}, ${event.changes.first().position}" } } } } ) } }
নিম্নলিখিত নির্ধারণ করতে PointerEvent
অবজেক্ট পরীক্ষা করুন:
-
PointerType
:PointerEvent#changes
থেকে মাউস, লেখনী, স্পর্শ এবং আরও অনেক কিছু -
PointerEventType
: পয়েন্টার অ্যাকশন, যেমন প্রেস, সরানো, স্ক্রোল এবং রিলিজ
গেম কন্ট্রোলার
কিছু বড় পর্দার অ্যান্ড্রয়েড ডিভাইস চারটি পর্যন্ত গেম কন্ট্রোলার সমর্থন করে। গেম কন্ট্রোলারগুলি পরিচালনা করতে স্ট্যান্ডার্ড অ্যান্ড্রয়েড গেম কন্ট্রোলার API ব্যবহার করুন ( সাপোর্ট গেম কন্ট্রোলার দেখুন)।
গেম কন্ট্রোলার বোতামগুলি একটি সাধারণ ম্যাপিং অনুসরণ করে সাধারণ মানগুলিতে ম্যাপ করা হয়। কিন্তু সব গেম কন্ট্রোলার নির্মাতারা একই ম্যাপিং কনভেনশন অনুসরণ করে না। আপনি যদি ব্যবহারকারীদের বিভিন্ন জনপ্রিয় নিয়ামক ম্যাপিং নির্বাচন করার অনুমতি দেন তবে আপনি আরও ভাল অভিজ্ঞতা প্রদান করতে পারেন। আরও তথ্যের জন্য প্রসেস গেমপ্যাড বোতাম টিপে দেখুন।
ইনপুট অনুবাদ মোড
ChromeOS ডিফল্টরূপে একটি ইনপুট অনুবাদ মোড সক্ষম করে৷ বেশিরভাগ অ্যান্ড্রয়েড অ্যাপের জন্য, এই মোড অ্যাপগুলিকে ডেস্কটপ পরিবেশে প্রত্যাশিতভাবে কাজ করতে সাহায্য করে। কিছু উদাহরণের মধ্যে রয়েছে স্বয়ংক্রিয়ভাবে টাচপ্যাডে দুই-আঙ্গুলের স্ক্রলিং সক্ষম করা, মাউস হুইল স্ক্রলিং, এবং উইন্ডো স্থানাঙ্কে কাঁচা প্রদর্শন স্থানাঙ্ক ম্যাপ করা। সাধারনত, অ্যাপ ডেভেলপারদের এই আচরণগুলির কোনটি নিজেরাই প্রয়োগ করতে হবে না।
যদি একটি অ্যাপ কাস্টম ইনপুট আচরণ প্রয়োগ করে, উদাহরণস্বরূপ একটি কাস্টম দুই-আঙ্গুলের টাচপ্যাড পিঞ্চ অ্যাকশন সংজ্ঞায়িত করা, বা এই ইনপুট অনুবাদগুলি অ্যাপের দ্বারা প্রত্যাশিত ইনপুট ইভেন্টগুলি প্রদান না করে, আপনি নিম্নলিখিত ট্যাগ যোগ করে ইনপুট অনুবাদ মোডটি অক্ষম করতে পারেন অ্যান্ড্রয়েড ম্যানিফেস্ট:
<uses-feature
android:name="android.hardware.type.pc"
android:required="false" />