বড় স্ক্রিনের ডিভাইসে, ব্যবহারকারীরা প্রায়শই কীবোর্ড, মাউস, ট্র্যাকপ্যাড, স্টাইলাস বা গেমপ্যাড ব্যবহার করে অ্যাপগুলির সাথে যোগাযোগ করে। বাহ্যিক ডিভাইসগুলি থেকে ইনপুট গ্রহণ করতে আপনার অ্যাপকে সক্ষম করতে, নিম্নলিখিতগুলি করুন:
- প্রাথমিক কীবোর্ড সমর্থন পরীক্ষা করুন যেমন ট্যাব এবং তীর কী কীবোর্ড নেভিগেশন, কী টেক্সট এন্ট্রি নিশ্চিতকরণ লিখুন এবং মিডিয়া অ্যাপগুলিতে স্পেস বার প্লে/পজ করুন
- প্রযোজ্য ক্ষেত্রে স্ট্যান্ডার্ড কীবোর্ড শর্টকাট যোগ করুন ; উদাহরণস্বরূপ, পূর্বাবস্থার জন্য Ctrl + Z এবং সংরক্ষণের জন্য Ctrl + S
- প্রসঙ্গ মেনু, হোভারে আইকন পরিবর্তন এবং কাস্টম ভিউতে মাউস হুইল বা ট্র্যাকপ্যাড স্ক্রোল ইভেন্টগুলির জন্য ডান-ক্লিকের পদ্ধতিতে প্রাথমিক মাউস ইন্টারঅ্যাকশন পরীক্ষা করুন
- অ্যাপ্লিকেশান-নির্দিষ্ট ইনপুট ডিভাইসগুলি পরীক্ষা করুন যেমন অ্যাপ্লিকেশানগুলি আঁকার জন্য একটি স্টাইলাস, গেমগুলির জন্য গেম কন্ট্রোলার এবং মিউজিক অ্যাপ্লিকেশানগুলির জন্য MIDI কন্ট্রোলারগুলি
- অ্যাপটিকে ডেস্কটপ পরিবেশে আলাদা করে তুলতে পারে এমন উন্নত ইনপুট সমর্থন বিবেচনা করুন ; উদাহরণস্বরূপ, ডিজে অ্যাপের জন্য ক্রস-ফ্যাডার হিসাবে টাচপ্যাড, গেমের জন্য মাউস ক্যাপচার এবং কীবোর্ড-কেন্দ্রিক ব্যবহারকারীদের জন্য ব্যাপক কীবোর্ড শর্টকাট
কীবোর্ড
আপনার অ্যাপ যেভাবে কীবোর্ড ইনপুটে সাড়া দেয় তা একটি ভালো বড় স্ক্রিনের অভিজ্ঞতায় অবদান রাখে। তিন ধরনের কীবোর্ড ইনপুট রয়েছে: নেভিগেশন , কীস্ট্রোক এবং শর্টকাট ।
নেভিগেশন
কীবোর্ড নেভিগেশন খুব কমই স্পর্শ-কেন্দ্রিক অ্যাপগুলিতে প্রয়োগ করা হয়, তবে ব্যবহারকারীরা যখন একটি অ্যাপ ব্যবহার করেন এবং একটি কীবোর্ডে তাদের হাত থাকে তখন এটি আশা করে। এটি ফোন, ট্যাবলেট, ফোল্ডেবল এবং ডেস্কটপ ডিভাইসগুলিতে অ্যাক্সেসযোগ্যতার প্রয়োজন রয়েছে এমন ব্যবহারকারীদের জন্যও অপরিহার্য হতে পারে।
অনেক অ্যাপ্লিকেশানের জন্য, সাধারণ তীর কী এবং ট্যাব নেভিগেশন সবই প্রয়োজন এবং বেশিরভাগই Android ফ্রেমওয়ার্ক দ্বারা স্বয়ংক্রিয়ভাবে পরিচালনা করা হয়। উদাহরণস্বরূপ, একটি Button
একটি দৃশ্য ডিফল্টরূপে ফোকাসযোগ্য, এবং কীবোর্ড নেভিগেশন সাধারণত কোনো অতিরিক্ত কোড ছাড়াই কাজ করা উচিত। ডিফল্টরূপে ফোকাসযোগ্য নয় এমন ভিউগুলির জন্য কীবোর্ড নেভিগেশন সক্ষম করতে, বিকাশকারীদের সেগুলিকে ফোকাসযোগ্য হিসাবে চিহ্নিত করা উচিত, যা নীচে দেখানো হিসাবে প্রোগ্রাম্যাটিকভাবে বা XML-এ করা যেতে পারে। আরও তথ্যের জন্য ফোকাস হ্যান্ডলিং দেখুন।
কোটলিন
yourView.isFocusable = true
জাভা
yourView.setFocusable(true);
বিকল্পভাবে আপনি আপনার লেআউট ফাইলে focusable
বৈশিষ্ট্য সেট করতে পারেন:
android:focusable="true"
একবার ফোকাস সক্ষম হলে, Android ফ্রেমওয়ার্ক তাদের অবস্থানের উপর ভিত্তি করে সমস্ত ফোকাসযোগ্য দৃশ্যের জন্য একটি নেভিগেশনাল ম্যাপিং তৈরি করে। এটি সাধারণত প্রত্যাশিত হিসাবে কাজ করে এবং আর কোন কাজের প্রয়োজন নেই। যখন ডিফল্ট ম্যাপিং একটি অ্যাপের প্রয়োজনের জন্য সঠিক না হয়, তখন এটি নিম্নরূপ ওভাররাইড করা যেতে পারে:
কোটলিন
// Arrow keys yourView.nextFocusLeftId = R.id.view_to_left yourView.nextFocusRightId = R.id.view_to_right yourView.nextFocusTopId = R.id.view_above yourView.nextFocusBottomId = R.id.view_below // Tab key yourView.nextFocusForwardId = R.id.next_view
জাভা
// Arrow keys yourView.setNextFocusLeftId(R.id.view_to_left); yourView.setNextFocusRightId(R.id.view_to_left); yourView.setNextFocusTopId(R.id.view_to_left); yourView.setNextFocusBottomId(R.id.view_to_left); // Tab key yourView.setNextFocusForwardId(R.id.next_view);
শুধুমাত্র কীবোর্ড ব্যবহার করে প্রতিটি প্রকাশের আগে আপনার অ্যাপের কার্যকারিতার প্রতিটি অংশ অ্যাক্সেস করার চেষ্টা করা ভাল অনুশীলন। মাউস বা স্পর্শ ইনপুট ছাড়াই সর্বাধিক সাধারণ ক্রিয়াগুলি অ্যাক্সেস করা সহজ হওয়া উচিত।
মনে রাখবেন, অ্যাক্সেসিবিলিটি প্রয়োজন ব্যবহারকারীদের জন্য কীবোর্ড সমর্থন অপরিহার্য হতে পারে।
কীস্ট্রোক
একটি অন-স্ক্রিন ভার্চুয়াল কীবোর্ড ( IME ) যেমন একটি EditText
দ্বারা পরিচালিত পাঠ্য ইনপুটের জন্য, ডেভেলপারের কাছ থেকে কোনও অতিরিক্ত কাজ ছাড়াই বড় স্ক্রীন ডিভাইসগুলিতে অ্যাপগুলিকে প্রত্যাশা অনুযায়ী আচরণ করা উচিত৷ কীস্ট্রোকগুলির জন্য যা ফ্রেমওয়ার্ক দ্বারা অনুমান করা যায় না, অ্যাপগুলিকে নিজের আচরণটি পরিচালনা করতে হবে। এটি কাস্টম ভিউ সহ অ্যাপগুলির জন্য বিশেষভাবে সত্য৷
কিছু উদাহরণ হল চ্যাট অ্যাপ যা একটি বার্তা পাঠাতে এন্টার কী ব্যবহার করে, মিডিয়া অ্যাপ যা স্পেস কী দিয়ে প্লেব্যাক শুরু এবং বন্ধ করে এবং গেমগুলি যেগুলি w, a, s, এবং d কীগুলির সাহায্যে গতিবিধি নিয়ন্ত্রণ করে।
বেশিরভাগ অ্যাপ 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) } }
জাভা
@Override public boolean onKeyUp(int keyCode, KeyEvent event) { if (keyCode == KeyEvent.KEYCODE_ENTER) { sendMessage(); return true; } else if (KeyEvent.KEYCODE_SPACE){ playOrPauseMedia(); return true; } else { return super.onKeyUp(keyCode, event); } }
একটি কী রিলিজ হলে একটি onKeyUp
ইভেন্ট ঘটে। এই কলব্যাক ব্যবহার করা অ্যাপগুলিকে একাধিক onKeyDown
ইভেন্ট প্রক্রিয়া করতে বাধা দেয় যদি একটি কী ধরে রাখা হয় বা ধীরে ধীরে ছেড়ে দেওয়া হয়। গেম এবং অ্যাপগুলি যেগুলি একটি কী চাপার মুহুর্তে জানতে চায় বা ব্যবহারকারীরা কীবোর্ড কীগুলি ধরে রাখার আশা করে তারা onKeyDown()
ইভেন্টটি সন্ধান করতে পারে এবং বারবার onKeyDown
ইভেন্টগুলি নিজেই পরিচালনা করতে পারে।
কীবোর্ড সমর্থন প্রদানের বিষয়ে আরও তথ্যের জন্য, কীবোর্ড ক্রিয়াগুলি পরিচালনা করুন দেখুন।
শর্টকাট
একটি হার্ডওয়্যার কীবোর্ড ব্যবহার করার সময় সাধারণ Ctrl, Alt এবং Shift-ভিত্তিক শর্টকাটগুলি প্রত্যাশিত। যদি একটি অ্যাপ তাদের বাস্তবায়ন না করে, অভিজ্ঞতাটি ব্যবহারকারীদের কাছে হতাশাজনক বোধ করতে পারে। উন্নত ব্যবহারকারীরা প্রায়শই ব্যবহৃত অ্যাপ-নির্দিষ্ট কাজের জন্য শর্টকাটগুলির প্রশংসা করে। শর্টকাট একটি অ্যাপ ব্যবহার করা সহজ করে এবং শর্টকাট নেই এমন অ্যাপ থেকে এটিকে আলাদা করে।
কিছু সাধারণ শর্টকাটের মধ্যে রয়েছে Ctrl + S (সংরক্ষণ), Ctrl + Z (আনডু), এবং Ctrl + Shift + Z (পুনরায় করুন)। আরও কিছু উন্নত শর্টকাটের উদাহরণের জন্য, ভিএলসি মিডিয়া প্লেয়ার শর্টকাট কীগুলির তালিকা দেখুন।
dispatchKeyShortcutEvent()
ব্যবহার করে শর্টকাট প্রয়োগ করা যেতে পারে। এটি একটি প্রদত্ত কীকোডের জন্য সমস্ত মেটা-কী সমন্বয় (Alt, Ctrl এবং Shift) আটকায়। একটি নির্দিষ্ট মেটা-কী পরীক্ষা করতে, KeyEvent.isCtrlPressed()
, KeyEvent.isShiftPressed()
, KeyEvent.isAltPressed()
বা KeyEvent.hasModifiers()
ব্যবহার করুন।
অন্যান্য কীস্ট্রোক হ্যান্ডলিং (যেমন onKeyUp()
এবং onKeyDown()
) থেকে শর্টকাট কোড আলাদা করা কোড রক্ষণাবেক্ষণকে সহজ করে তুলতে পারে এবং প্রতিটি ক্ষেত্রে ম্যানুয়ালি মেটা-কী চেকগুলি প্রয়োগ না করেই মেটা-কিগুলির ডিফল্ট গ্রহণযোগ্যতা সক্ষম করে৷ বিভিন্ন কীবোর্ড লেআউট এবং অপারেটিং সিস্টেমে অভ্যস্ত ব্যবহারকারীদের জন্য সমস্ত মেটা-কী সমন্বয়ের অনুমতি দেওয়া আরও সুবিধাজনক হতে পারে।
কোটলিন
override fun dispatchKeyShortcutEvent(event: KeyEvent): Boolean { return when (event.keyCode) { KeyEvent.KEYCODE_O -> { openFile() // Ctrl+O, Shift+O, Alt+O true } KeyEvent.KEYCODE_Z-> { if (event.isCtrlPressed) { if (event.isShiftPressed) { redoLastAction() // Ctrl+Shift+Z pressed true } else { undoLastAction() // Ctrl+Z pressed true } } } else -> { return super.dispatchKeyShortcutEvent(event) } } }
জাভা
@Override public boolean dispatchKeyShortcutEvent(KeyEvent event) { if (event.getKeyCode() == KeyEvent.KEYCODE_O) { openFile(); // Ctrl+O, Shift+O, Alt+O return true; } else if(event.getKeyCode() == KeyEvent.KEYCODE_Z) { if (event.isCtrlPressed()) { if (event.isShiftPressed()) { redoLastAction(); return true; } else { undoLastAction(); return true; } } } return super.dispatchKeyShortcutEvent(event); }
আপনি উপরের মত একই পদ্ধতিতে KeyEvent.isCtrlPressed()
, KeyEvent.isShiftPressed()
বা KeyEvent.isAltPressed()
চেক করে onKeyUp()
এ শর্টকাট প্রয়োগ করতে পারেন। এটি বজায় রাখা সহজ হতে পারে যদি মেটা-আচরণ শর্টকাটের চেয়ে অ্যাপের আচরণে পরিবর্তনের বেশি হয়। উদাহরণস্বরূপ, যখন W মানে "অগ্রগতি হাঁটা" এবং Shift + W মানে "এগিয়ে দৌড়"।
কোটলিন
override fun onKeyUp(keyCode: Int, event: KeyEvent): Boolean { return when(keyCode) { KeyEvent.KEYCODE_W-> { if (event.isShiftPressed) { if (event.isCtrlPressed) { flyForward() // Ctrl+Shift+W pressed true } else { runForward() // Shift+W pressed true } } else { walkForward() // W pressed true } } else -> super.onKeyUp(keyCode, event) } }
জাভা
@Override public boolean onKeyUp(int keyCode, KeyEvent event) { if (keyCode == KeyEvent.KEYCODE_W) { if (event.isShiftPressed()) { if (event.isCtrlPressed()) { flyForward(); // Ctrl+Shift+W pressed return true; } else { runForward(); // Shift+W pressed return true; } } else { walkForward(); return true; } } return super.onKeyUp(keyCode, event); }
লেখনী
অনেক বড় স্ক্রীন ডিভাইস একটি স্টাইলাস সহ আসে এবং অ্যান্ড্রয়েড অ্যাপস এটিকে টাচস্ক্রিন ইনপুট হিসাবে পরিচালনা করে। কিছু ডিভাইসে একটি USB বা ব্লুটুথ ড্রয়িং টেবিলও থাকতে পারে, যেমন Wacom Intuos । Android অ্যাপ্লিকেশানগুলি ব্লুটুথ ইনপুট গ্রহণ করতে পারে, কিন্তু USB ইনপুটের সাথে কাজ করবে না৷
একটি স্টাইলাস ইভেন্ট View.onTouchEvent()
বা View.onGenericMotionEvent()
এর মাধ্যমে একটি টাচস্ক্রিন ইভেন্ট হিসাবে রিপোর্ট করা হয় এবং এতে SOURCE_STYLUS
ধরনের একটি MotionEvent.getSource()
রয়েছে।
MotionEvent
এ অতিরিক্ত ডেটাও থাকবে:
-
MotionEvent.getToolType()
TOOL_TYPE_FINGER
, TOOL_TYPE_STYLUS , বাTOOL_TYPE_ERASER
প্রদান করে যা পৃষ্ঠের সাথে যোগাযোগ করেছে তার উপর নির্ভর করে -
MotionEvent.getPressure()
স্টাইলাস কলমে প্রয়োগ করা শারীরিক চাপের রিপোর্ট করে (যদি সমর্থিত হয়) -
MotionEvent.AXIS_TILT
এবংMotionEvent.AXIS_ORIENTATION
সহMotionEvent.getAxisValue()
যা লেখনীর শারীরিক কাত এবং ওরিয়েন্টেশন পড়তে ব্যবহার করা যেতে পারে (যদি সমর্থিত হয়)
ঐতিহাসিক পয়েন্ট
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 অনুযায়ী, সুবিধার জন্য, সিস্টেমটি ACTION_CANCEL
ইভেন্টগুলির জন্য FLAG_CANCELED
সেট করে, কিন্তু পূর্ববর্তী সংস্করণগুলি তা করে না৷
অ্যান্ড্রয়েড 12
অ্যান্ড্রয়েড 12 (এপিআই লেভেল 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-এর একটি বিশেষ অভিপ্রায় রয়েছে যা ব্যবহারকারীদের কাছে নিবন্ধিত নোট গ্রহণকারী অ্যাপগুলিকে সারফেস করে৷ একটি নোট গ্রহণকারী অ্যাপ হিসাবে একটি অ্যাপ নিবন্ধন করতে, Android ম্যানিফেস্টে নিম্নলিখিত যোগ করুন:
<intent-filter>
<action android:name="org.chromium.arc.intent.action.CREATE_NOTE" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
যখন একটি অ্যাপ নিবন্ধিত হয়, ব্যবহারকারী এটিকে ডিফল্ট নোট নেওয়ার অ্যাপ হিসেবে নির্বাচন করতে পারেন। যখন একটি নতুন নোটের জন্য অনুরোধ করা হয়, অ্যাপটিকে স্টাইলাস ইনপুটের জন্য প্রস্তুত একটি খালি নোট তৈরি করা উচিত। যখন ব্যবহারকারী একটি চিত্রকে (যেমন একটি স্ক্রিনশট বা ডাউনলোড করা ছবি) টীকা করতে চান, তখন অ্যাপটি ClipData
সহ একটি বা একাধিক আইটেম সহ content://
ইউআরআই সহ চালু হয়। অ্যাপটির এমন একটি নোট তৈরি করা উচিত যা প্রথম সংযুক্ত ছবিকে ব্যাকগ্রাউন্ড ইমেজ হিসেবে ব্যবহার করে এবং এমন একটি মোডে প্রবেশ করাতে হবে যেখানে ব্যবহারকারী স্ক্রিনে লেখনী দিয়ে আঁকতে পারে।
লেখনী ছাড়াই নোট নেওয়ার অভিপ্রায় পরীক্ষা করুন
কোনো অ্যাপ্লিকেশান সক্রিয় স্টাইলাস ছাড়াই নোট নেওয়ার অভিপ্রায়ে সঠিকভাবে সাড়া দেয় কিনা তা পরীক্ষা করতে, ChromeOS-এ নোট নেওয়ার বিকল্পগুলি প্রদর্শন করতে নিম্নলিখিত পদ্ধতিটি ব্যবহার করুন:
- ডেভ মোডে স্যুইচ করুন এবং ডিভাইসটিকে লেখার যোগ্য করুন
- একটি টার্মিনাল খুলতে Ctrl + Alt + F2 টিপুন
-
sudo vi /etc/chrome_dev.conf
কমান্ডটি চালান - ফাইলের শেষে একটি নতুন লাইনে
--ash-enable-palette
এডিট করতে এবং যোগ করতেi
টিপুন - Esc টিপে সংরক্ষণ করুন এবং তারপরে :, w, q লিখে এন্টার টিপুন
- নিয়মিত ChromeOS UI এ ফিরে যেতে Ctrl + Alt + F1 টিপুন
- লগ আউট এবং ফিরে
শেলফে এখন একটি স্টাইলাস মেনু থাকা উচিত:
- শেলফের স্টাইলাস বোতামটি আলতো চাপুন এবং নতুন নোট নির্বাচন করুন। এটি একটি ফাঁকা অঙ্কন নোট খুলতে হবে।
- একটি স্ক্রিনশট নিন। শেল্ফ থেকে, স্টাইলাস বোতাম > ক্যাপচার স্ক্রীন নির্বাচন করুন বা একটি ছবি ডাউনলোড করুন। বিজ্ঞপ্তিতে "ইমেজ টীকা" করার বিকল্প থাকতে হবে। এটি টীকা করার জন্য প্রস্তুত চিত্র সহ অ্যাপটি চালু করা উচিত।
মাউস এবং টাচপ্যাড সমর্থন
বেশিরভাগ অ্যাপের সাধারণত শুধুমাত্র তিনটি বড় স্ক্রীন-কেন্দ্রিক ইভেন্ট পরিচালনা করতে হয়: ডান-ক্লিক করুন , হোভার করুন এবং টেনে আনুন এবং ড্রপ করুন ।
রাইট-ক্লিক করুন
যে কোনও অ্যাকশন যা একটি অ্যাপকে একটি প্রসঙ্গ মেনু দেখায়, যেমন একটি তালিকা আইটেম স্পর্শ করে ধরে রাখুন, রাইট-ক্লিক ইভেন্টগুলিতেও প্রতিক্রিয়া দেখা উচিত। রাইট-ক্লিক ইভেন্টগুলি পরিচালনা করতে, অ্যাপগুলির একটি View.OnContextClickListener
নিবন্ধন করা উচিত। একটি প্রসঙ্গ মেনু নির্মাণের বিস্তারিত জানার জন্য, প্রসঙ্গ মেনু তৈরি করা দেখুন।
কোটলিন
yourView.setOnContextClickListener { showContextMenu() true }
জাভা
yourView.setOnContextClickListener(v -> { showContextMenu(); return true; });
হোভার
ডেভেলপাররা হোভার ইভেন্টগুলি পরিচালনা করে তাদের অ্যাপ লেআউটগুলিকে পালিশ এবং সহজে ব্যবহার করতে পারে৷ এটি কাস্টম দৃশ্যের জন্য বিশেষভাবে সত্য। এর দুটি সবচেয়ে সাধারণ উদাহরণ হল:
- মাউস পয়েন্টার আইকন পরিবর্তন করে কোনো উপাদানে ক্লিকযোগ্য বা সম্পাদনাযোগ্য হওয়ার মতো ইন্টারেক্টিভ আচরণ আছে কিনা তা ব্যবহারকারীদের নির্দেশ করে
- একটি বড় তালিকা বা গ্রিডে থাকা আইটেমগুলিতে ভিজ্যুয়াল ফিডব্যাক যোগ করা যখন পয়েন্টারটি তাদের উপর ঘোরাফেরা করছে
কোটলিন
// Change the icon to a "hand" pointer on hover, // Highlight the view by changing the background. yourView.setOnHoverListener { view, _ -> addVisualHighlighting(true) view.pointerIcon = PointerIcon.getSystemIcon(view.context, PointerIcon.TYPE_HAND) false // listener did not consume the event. }
জাভা
yourView.setOnHoverListener((view, event) -> { addVisualHighlighting(true); view.setPointerIcon(PointerIcon .getSystemIcon(view.getContext(), PointerIcon.TYPE_HAND)); return true; });
টেনে আনুন
একটি মাল্টি-উইন্ডো পরিবেশে, ব্যবহারকারীরা অ্যাপগুলির মধ্যে আইটেমগুলিকে টেনে আনতে এবং ফেলে দিতে সক্ষম হবে বলে আশা করে৷ এটি ডেস্কটপ ডিভাইসের পাশাপাশি ট্যাবলেট, ফোন এবং স্প্লিট-স্ক্রিন মোডে ফোল্ডেবলের ক্ষেত্রেও সত্য।
ব্যবহারকারীরা তাদের অ্যাপে আইটেম টেনে আনতে পারে কিনা তা বিকাশকারীদের বিবেচনা করা উচিত। কিছু সাধারণ উদাহরণের মধ্যে রয়েছে: ফটো এডিটরদের ফটোগুলি পাওয়ার আশা করা উচিত, অডিও প্লেয়ারদের অডিও ফাইলগুলি পাওয়ার আশা করা উচিত এবং অঙ্কন প্রোগ্রামগুলি ফটোগুলি পাওয়ার আশা করা উচিত।
ড্র্যাগ অ্যান্ড ড্রপ সমর্থন যোগ করতে, অ্যান্ড্রয়েড ড্র্যাগ অ্যান্ড ড্রপ ডকুমেন্টেশন অনুসরণ করুন এবং এই ChromeOS ব্লগ পোস্টটি একবার দেখুন।
ChromeOS এর জন্য বিশেষ বিবেচনা
- অ্যাপের বাইরে থেকে টেনে আনা আইটেম অ্যাক্সেস করার জন্য
requestDragAndDropPermissions
মাধ্যমে অনুমতির অনুরোধ করতে ভুলবেন না - অন্য অ্যাপ্লিকেশানগুলিতে টেনে আনার জন্য একটি আইটেমের
View.DRAG_FLAG_GLOBAL
পতাকা থাকতে হবে
উন্নত পয়েন্টার সমর্থন
যে অ্যাপগুলি মাউস এবং টাচপ্যাড ইনপুটের উন্নত হ্যান্ডলিং করে View.onGenericMotionEvent()
এর জন্য Android ডকুমেন্টেশন অনুসরণ করা উচিত এবং SOURCE_MOUSE
এবং SOURCE_TOUCHSCREEN
এর মধ্যে পার্থক্য করতে MotionEvent.getSource()
ব্যবহার করা উচিত।
প্রয়োজনীয় আচরণ বাস্তবায়ন করতে MotionEvent
পরীক্ষা করুন:
- আন্দোলন
ACTION_HOVER_MOVE
ইভেন্ট তৈরি করে। - বোতামগুলি
ACTION_BUTTON_PRESS
এবংACTION_BUTTON_RELEASE
ইভেন্টগুলি তৈরি করে৷ আপনিgetButtonState()
ব্যবহার করে সমস্ত মাউস/ট্র্যাকপ্যাড বোতামের বর্তমান অবস্থাও পরীক্ষা করতে পারেন। - মাউস হুইল স্ক্রোলিং
ACTION_SCROLL
ইভেন্ট তৈরি করে।
গেম কন্ট্রোলার
কিছু বড় পর্দার অ্যান্ড্রয়েড ডিভাইস চারটি পর্যন্ত গেম কন্ট্রোলার সমর্থন করে। ডেভেলপারদের স্ট্যান্ডার্ড অ্যান্ড্রয়েড গেম কন্ট্রোলার এপিআই ব্যবহার করা উচিত তাদের পরিচালনা করার জন্য ( সাপোর্ট গেম কন্ট্রোলার দেখুন)।
একটি সাধারণ ম্যাপিং অনুসরণ করে সাধারণ মানগুলিতে বোতামগুলি ম্যাপ করা হয়। দুর্ভাগ্যবশত, সমস্ত গেম কন্ট্রোলার নির্মাতারা একই ম্যাপিং নিয়ম অনুসরণ করে না। আপনি যদি ব্যবহারকারীদের বিভিন্ন জনপ্রিয় নিয়ামক ম্যাপিং নির্বাচন করার অনুমতি দেন তবে আপনি আরও ভাল অভিজ্ঞতা প্রদান করতে পারেন। আরও তথ্যের জন্য প্রসেস গেমপ্যাড বোতাম টিপে দেখুন।
ইনপুট অনুবাদ মোড
ChromeOS ডিফল্টরূপে একটি ইনপুট অনুবাদ মোড সক্ষম করে৷ বেশিরভাগ অ্যান্ড্রয়েড অ্যাপের জন্য এই মোড অ্যাপগুলিকে ডেস্কটপ পরিবেশে প্রত্যাশিতভাবে কাজ করতে সাহায্য করে। কিছু উদাহরণের মধ্যে রয়েছে স্বয়ংক্রিয়ভাবে টাচপ্যাডে দুই-আঙুলের স্ক্রলিং সক্ষম করা, মাউস হুইল স্ক্রলিং, এবং উইন্ডো স্থানাঙ্কে কাঁচা প্রদর্শন স্থানাঙ্ক ম্যাপ করা। সাধারনত, অ্যাপ ডেভেলপারদের এই আচরণগুলির কোনটি নিজেরাই প্রয়োগ করতে হবে না।
যদি কোনও অ্যাপ কাস্টম ইনপুট আচরণ প্রয়োগ করে, উদাহরণস্বরূপ একটি কাস্টম দুই-আঙ্গুলের টাচপ্যাড পিঞ্চ অ্যাকশন সংজ্ঞায়িত করা, বা এই ইনপুট অনুবাদগুলি অ্যাপের দ্বারা প্রত্যাশিত ইনপুট ইভেন্টগুলি প্রদান না করে, আপনি Android এ নিম্নলিখিত ট্যাগ যোগ করে ইনপুট অনুবাদ মোড অক্ষম করতে পারেন প্রকাশ:
<uses-feature
android:name="android.hardware.type.pc"
android:required="false" />
অতিরিক্ত সম্পদ
{% শব্দার্থে %}আপনার জন্য প্রস্তাবিত
- দ্রষ্টব্য: জাভাস্ক্রিপ্ট বন্ধ থাকলে লিঙ্ক টেক্সট প্রদর্শিত হয়
- একটি Android অ্যাপে স্টাইলাস সমর্থন উন্নত করুন
- কাস্টম পাঠ্য সম্পাদক
- ট্যাবলেট এবং বড় পর্দা সমর্থন