নিম্নলিখিত উপাদান অ্যাপ্লিকেশন বিকাশকারীদের জন্য.
আপনার অ্যাপ সমর্থন রোটারি করতে, আপনাকে অবশ্যই:
- সংশ্লিষ্ট কার্যকলাপ বিন্যাসে একটি
FocusParkingView
রাখুন। - দৃষ্টিভঙ্গিগুলি নিশ্চিত করুন যা ফোকাসযোগ্য (বা নয়)৷
-
FocusParkingView
ব্যতীত আপনার সমস্ত ফোকাসযোগ্য ভিউ মোড়ানোর জন্যFocusArea
ব্যবহার করুন।
আপনি রোটারি-সক্ষম অ্যাপগুলি বিকাশের জন্য আপনার পরিবেশ সেট আপ করার পরে এই প্রতিটি কাজ নীচে বিশদভাবে দেওয়া আছে।
একটি ঘূর্ণমান নিয়ামক সেট আপ করুন
আপনি রোটারি-সক্ষম অ্যাপ্লিকেশানগুলি বিকাশ শুরু করার আগে, আপনার হয় একটি রোটারি কন্ট্রোলার বা একটি স্ট্যান্ড-ইন প্রয়োজন৷ আপনি নীচে বর্ণিত বিকল্প আছে.
এমুলেটর
source build/envsetup.sh && lunch car_x86_64-userdebug m -j emulator -wipe-data -no-snapshot -writable-system
এছাড়াও আপনি aosp_car_x86_64-userdebug
ব্যবহার করতে পারেন।
এমুলেটেড রোটারি কন্ট্রোলার অ্যাক্সেস করতে:
- টুলবারের নীচে তিনটি বিন্দুতে আলতো চাপুন:
- বর্ধিত নিয়ন্ত্রণ উইন্ডোতে কার রোটারি নির্বাচন করুন:
ইউএসবি কীবোর্ড
- আপনার ডিভাইসে একটি USB কীবোর্ড প্লাগ করুন যা Android Automotive OS (AAOS) চালায়, কিছু ক্ষেত্রে, এটি অন-স্ক্রীন কীবোর্ডকে দেখাতে বাধা দেয়।
- একটি
userdebug
বাeng
বিল্ড ব্যবহার করুন. - কী ইভেন্ট ফিল্টারিং সক্ষম করুন:
adb shell settings put secure android.car.ROTARY_KEY_EVENT_FILTER 1
- প্রতিটি কর্মের জন্য সংশ্লিষ্ট কী খুঁজে পেতে নীচের টেবিলটি দেখুন:
চাবি ঘূর্ণমান কর্ম প্র ঘড়ির কাঁটার বিপরীত দিকে ঘোরান ই ঘড়ির কাঁটার দিকে ঘোরান ক নাজ বাম ডি ডান দিকে নাজ ডব্লিউ নাজ আপ এস নিচে নাজ F বা কমা কেন্দ্র বোতাম R বা Esc পিছনের বোতাম
ADB কমান্ড
আপনি রোটারি ইনপুট ইভেন্ট ইনজেকশন করতে car_service
কমান্ড ব্যবহার করতে পারেন। এই কমান্ডগুলি Android Automotive OS (AAOS) বা এমুলেটরে চালিত ডিভাইসগুলিতে চালানো যেতে পারে।
car_service কমান্ড | রোটারি ইনপুট |
---|---|
adb shell cmd car_service inject-rotary | ঘড়ির কাঁটার বিপরীত দিকে ঘোরান |
adb shell cmd car_service inject-rotary -c true | ঘড়ির কাঁটার দিকে ঘোরান |
adb shell cmd car_service inject-rotary -dt 100 50 | ঘড়ির কাঁটার বিপরীত দিকে একাধিকবার ঘোরান (100 ms আগে এবং 50 ms আগে) |
adb shell cmd car_service inject-key 282 | নাজ বাম |
adb shell cmd car_service inject-key 283 | ডান দিকে নাজ |
adb shell cmd car_service inject-key 280 | নাজ আপ |
adb shell cmd car_service inject-key 281 | নিচে নাজ |
adb shell cmd car_service inject-key 23 | কেন্দ্র বোতামে ক্লিক করুন |
adb shell input keyevent inject-key 4 | ব্যাক বাটনে ক্লিক করুন |
OEM ঘূর্ণমান নিয়ামক
যখন আপনার ঘূর্ণমান নিয়ামক হার্ডওয়্যার আপ এবং চলমান হয়, এটি সবচেয়ে বাস্তবসম্মত বিকল্প। এটি দ্রুত ঘূর্ণন পরীক্ষা করার জন্য বিশেষভাবে দরকারী।
ফোকাসপার্কিংভিউ
FocusParkingView
হল Car UI লাইব্রেরিতে (car-ui-library) একটি স্বচ্ছ দৃশ্য। RotaryService
রোটারি কন্ট্রোলার নেভিগেশন সমর্থন করার জন্য এটি ব্যবহার করে। FocusParkingView
লেআউটের প্রথম ফোকাসযোগ্য দৃশ্য হতে হবে। এটি অবশ্যই সমস্ত FocusArea
বাইরে স্থাপন করা উচিত। প্রতিটি উইন্ডোতে একটি FocusParkingView
থাকতে হবে। আপনি যদি ইতিমধ্যেই car-ui-লাইব্রেরি বেস লেআউট ব্যবহার করে থাকেন, যাতে একটি FocusParkingView
রয়েছে, তাহলে আপনাকে আর একটি FocusParkingView
যোগ করতে হবে না। RotaryPlayground
FocusParkingView
-এর একটি উদাহরণ নীচে দেখানো হয়েছে।
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <com.android.car.ui.FocusParkingView android:layout_width="wrap_content" android:layout_height="wrap_content"/> <FrameLayout android:layout_width="match_parent" android:layout_height="match_parent"/> </FrameLayout>
এখানে আপনার একটি FocusParkingView
প্রয়োজনের কারণ রয়েছে:
- অন্য উইন্ডোতে ফোকাস সেট করা হলে Android স্বয়ংক্রিয়ভাবে ফোকাস সাফ করে না। আপনি যদি আগের উইন্ডোতে ফোকাস সাফ করার চেষ্টা করেন, তাহলে অ্যান্ড্রয়েড সেই উইন্ডোতে একটি ভিউ রিফোকাস করে, যার ফলে দুটি উইন্ডো একই সাথে ফোকাস করা হয়। প্রতিটি উইন্ডোতে একটি
FocusParkingView
যোগ করলে এই সমস্যার সমাধান হতে পারে। এই দৃশ্যটি স্বচ্ছ এবং এর ডিফল্ট ফোকাস হাইলাইট অক্ষম করা হয়েছে, যাতে এটি ফোকাস করা হোক বা না হোক ব্যবহারকারীর কাছে অদৃশ্য। এটি ফোকাস নিতে পারে যাতেRotaryService
ফোকাস হাইলাইটটি সরাতে এটিতে ফোকাস পার্ক করতে পারে। - বর্তমান উইন্ডোতে শুধুমাত্র একটি
FocusArea
থাকলে,FocusArea
এ কন্ট্রোলার ঘোরানোর ফলেRotaryService
ফোকাসটিকে ডানদিকের ভিউ থেকে বাম দিকের ভিউতে নিয়ে যায় (এবং এর বিপরীতে)। প্রতিটি উইন্ডোতে এই ভিউ যোগ করলে সমস্যার সমাধান করা যায়। যখনRotaryService
নির্ধারণ করে যে ফোকাস টার্গেট হল একটিFocusParkingView
, তখন এটি নির্ধারণ করতে পারে যে একটি মোড়ক ঘটতে চলেছে কোন সময়ে এটি ফোকাস না সরানোর মাধ্যমে মোড়ানো এড়িয়ে যায়৷ - যখন রোটারি কন্ট্রোল একটি অ্যাপ চালু করে, তখন অ্যান্ড্রয়েড প্রথম ফোকাসযোগ্য দৃশ্যে ফোকাস করে, যা সর্বদা
FocusParkingView
।FocusParkingView
ফোকাস করার জন্য সর্বোত্তম দৃশ্য নির্ধারণ করে এবং তারপর ফোকাস প্রয়োগ করে।
ফোকাসযোগ্য দৃশ্য
RotaryService
অ্যান্ড্রয়েড ফ্রেমওয়ার্কের ভিউ ফোকাসের বিদ্যমান ধারণার উপর ভিত্তি করে তৈরি করে, যখন ফোনে ফিজিক্যাল কীবোর্ড এবং ডি-প্যাড ছিল। বিদ্যমান android:nextFocusForward
অ্যাট্রিবিউটটি রোটারির জন্য পুনরায় ব্যবহার করা হয়েছে ( FocusArea কাস্টমাইজেশন দেখুন), কিন্তু android:nextFocusLeft
, android:nextFocusRight
, android:nextFocusUp
, এবং android:nextFocusDown
নয়।
RotaryService
শুধুমাত্র ফোকাসযোগ্য দৃশ্যের উপর ফোকাস করে। কিছু ভিউ, যেমন Button
s, সাধারণত ফোকাসযোগ্য। অন্যান্য, যেমন TextView
s এবং ViewGroup
, সাধারণত হয় না। ক্লিকযোগ্য ভিউ স্বয়ংক্রিয়ভাবে ফোকাসযোগ্য এবং ভিউ স্বয়ংক্রিয়ভাবে ক্লিকযোগ্য হয় যখন তাদের একটি ক্লিক শ্রোতা থাকে। যদি এই স্বয়ংক্রিয় যুক্তির ফলে পছন্দসই ফোকাসযোগ্যতা পাওয়া যায়, তাহলে আপনাকে দৃশ্যের ফোকাসযোগ্যতা স্পষ্টভাবে সেট করতে হবে না। যদি স্বয়ংক্রিয় যুক্তির ফলে কাঙ্ক্ষিত ফোকাসেবিলিটি না হয়, android:focusable
অ্যাট্রিবিউটটিকে true
বা false
তে সেট করুন, অথবা View.setFocusable(boolean)
দিয়ে ভিউয়ের ফোকাসযোগ্যতা প্রোগ্রামেটিকভাবে সেট করুন। RotaryService
এর উপর ফোকাস করার জন্য, একটি ভিউ অবশ্যই নিম্নলিখিত প্রয়োজনীয়তাগুলি পূরণ করবে:
- ফোকাসযোগ্য
- সক্রিয়
- দৃশ্যমান
- প্রস্থ এবং উচ্চতার জন্য অ-শূন্য মান আছে
যদি একটি দৃশ্য এই সমস্ত প্রয়োজনীয়তা পূরণ না করে, উদাহরণস্বরূপ একটি ফোকাসযোগ্য কিন্তু অক্ষম বোতাম, ব্যবহারকারী এটিতে ফোকাস করতে ঘূর্ণমান নিয়ন্ত্রণ ব্যবহার করতে পারবেন না। আপনি যদি অক্ষম দৃশ্যগুলিতে ফোকাস করতে চান তবে android:state_enabled
এর পরিবর্তে একটি কাস্টম স্থিতি ব্যবহার করার কথা বিবেচনা করুন যাতে Android এটিকে নিষ্ক্রিয় বিবেচনা করা উচিত বলে নির্দেশ না করে ভিউটি কীভাবে প্রদর্শিত হয় তা নিয়ন্ত্রণ করুন৷ আপনার অ্যাপ ব্যবহারকারীকে জানাতে পারে কেন ট্যাপ করার সময় ভিউ অক্ষম করা হয়। পরবর্তী অধ্যায় ব্যাখ্যা করে কিভাবে এটি করতে হয়।
কাস্টম অবস্থা
একটি কাস্টম অবস্থা যোগ করতে:
- আপনার ভিউতে একটি কাস্টম অ্যাট্রিবিউট যোগ করতে। উদাহরণস্বরূপ,
CustomView
ভিউ ক্লাসে একটিstate_rotary_enabled
কাস্টম অবস্থা যোগ করতে, ব্যবহার করুন:<declare-styleable name="CustomView"> <attr name="state_rotary_enabled" format="boolean" /> </declare-styleable>
- এই অবস্থা ট্র্যাক করতে, অ্যাক্সেসর পদ্ধতি সহ আপনার ভিউতে একটি ইনস্ট্যান্স ভেরিয়েবল যোগ করুন:
private boolean mRotaryEnabled; public boolean getRotaryEnabled() { return mRotaryEnabled; } public void setRotaryEnabled(boolean rotaryEnabled) { mRotaryEnabled = rotaryEnabled; }
- আপনার ভিউ তৈরি হলে আপনার অ্যাট্রিবিউটের মান পড়তে:
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.CustomView); mRotaryEnabled = a.getBoolean(R.styleable.CustomView_state_rotary_enabled);
- আপনার ভিউ ক্লাসে,
onCreateDrawableState()
পদ্ধতিটি ওভাররাইড করুন এবং তারপরে উপযুক্ত অবস্থা যোগ করুন। যেমন:@Override protected int[] onCreateDrawableState(int extraSpace) { if (mRotaryEnabled) extraSpace++; int[] drawableState = super.onCreateDrawableState(extraSpace); if (mRotaryEnabled) { mergeDrawableStates(drawableState, { R.attr.state_rotary_enabled }); } return drawableState; }
- আপনার ভিউয়ের ক্লিক হ্যান্ডলারকে তার অবস্থার উপর নির্ভর করে ভিন্নভাবে পারফর্ম করুন। উদাহরণস্বরূপ, ক্লিক হ্যান্ডলার কিছুই করতে পারে না বা
mRotaryEnabled
false
হলে এটি একটি টোস্ট পপ আপ করতে পারে। - বোতামটিকে নিষ্ক্রিয় দেখাতে, আপনার দৃশ্যের পটভূমিতে আঁকার যোগ্য,
android:state_enabled
:state_enabled এর পরিবর্তেapp:state_rotary_enabled
ব্যবহার করুন। আপনার যদি এটি ইতিমধ্যে না থাকে তবে আপনাকে যোগ করতে হবে:xmlns:app="http://schemas.android.com/apk/res-auto"
- যদি আপনার ভিউ কোনো লেআউটে অক্ষম করা থাকে,
android:enabled="false"
app:state_rotary_enabled="false"
দিয়ে প্রতিস্থাপন করুন এবং তারপরে উপরের মতোapp
নামস্থান যোগ করুন। - যদি আপনার ভিউ প্রোগ্রাম্যাটিকভাবে অক্ষম করা থাকে,
setEnabled()
এর কলগুলিকেsetRotaryEnabled()
এ কল দিয়ে প্রতিস্থাপন করুন।
ফোকাস এরিয়া
নেভিগেশন সহজ করতে এবং অন্যান্য অ্যাপের সাথে সামঞ্জস্যপূর্ণ হতে ফোকাসযোগ্য দৃশ্যগুলিকে ব্লকে ভাগ করতে FocusAreas
ব্যবহার করুন। উদাহরণস্বরূপ, যদি আপনার অ্যাপে একটি টুলবার থাকে, তাহলে টুলবারটি আপনার বাকি অ্যাপ থেকে আলাদা FocusArea
থাকা উচিত। ট্যাব বার এবং অন্যান্য নেভিগেশন উপাদানগুলিও অ্যাপের বাকি অংশ থেকে আলাদা করা উচিত। বড় তালিকার সাধারণত তাদের নিজস্ব FocusArea
থাকা উচিত। যদি তা না হয়, ব্যবহারকারীদের কিছু ভিউ অ্যাক্সেস করতে পুরো তালিকার মাধ্যমে ঘুরতে হবে।
FocusArea
হল car-ui-লাইব্রেরিতে LinearLayout
এর একটি সাবক্লাস। যখন এই বৈশিষ্ট্যটি সক্ষম করা হয়, তখন FocusArea
একটি হাইলাইট আঁকে যখন এর বংশধরদের মধ্যে একটি ফোকাস করা হয়। আরও জানতে, ফোকাস হাইলাইট কাস্টমাইজেশন দেখুন।
লেআউট ফাইলে একটি নেভিগেশন ব্লক তৈরি করার সময়, আপনি যদি সেই ব্লকের জন্য একটি ধারক হিসাবে একটি LinearLayout
ব্যবহার করতে চান, তার পরিবর্তে FocusArea
ব্যবহার করুন। অন্যথায়, একটি FocusArea
ব্লকটি মোড়ানো।
একটি FocusArea
অন্য FocusArea
নেস্ট করবেন না । এটি করা অনির্ধারিত নেভিগেশন আচরণের দিকে নিয়ে যায়। নিশ্চিত করুন যে সমস্ত ফোকাসযোগ্য দৃশ্য একটি FocusArea
মধ্যে নেস্ট করা হয়েছে।
RotaryPlayground
FocusArea
একটি উদাহরণ নীচে দেখানো হয়েছে:
<com.android.car.ui.FocusArea android:layout_margin="16dp" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <EditText android:layout_width="match_parent" android:layout_height="wrap_content" android:singleLine="true"> </EditText> </com.android.car.ui.FocusArea>
FocusArea
নিম্নরূপ কাজ করে:
- ঘোরানো এবং নাজ অ্যাকশন পরিচালনা করার সময়,
RotaryService
ভিউ হায়ারার্কিতেFocusArea
উদাহরণ খোঁজে। - একটি ঘূর্ণন ইভেন্ট গ্রহণ করার সময়,
RotaryService
ফোকাসকে অন্য ভিউতে নিয়ে যায় যা একইFocusArea
এ ফোকাস নিতে পারে। - একটি নাজ ইভেন্ট গ্রহণ করার সময়,
RotaryService
ফোকাসকে অন্য ভিউতে নিয়ে যায় যা অন্য (সাধারণত সংলগ্ন)FocusArea
এ ফোকাস নিতে পারে।
আপনি যদি আপনার লেআউটে কোনো FocusAreas
অন্তর্ভুক্ত না করেন, তাহলে রুট ভিউটিকে একটি অন্তর্নিহিত ফোকাস এলাকা হিসেবে গণ্য করা হয়। ব্যবহারকারী অ্যাপে নেভিগেট করতে ধাক্কা দিতে পারে না। পরিবর্তে, তারা সমস্ত ফোকাসযোগ্য দৃশ্যের মাধ্যমে ঘুরবে, যা ডায়ালগের জন্য পর্যাপ্ত হতে পারে।
ফোকাস এরিয়া কাস্টমাইজেশন
রোটারি নেভিগেশন কাস্টমাইজ করতে দুটি স্ট্যান্ডার্ড ভিউ অ্যাট্রিবিউট ব্যবহার করা যেতে পারে:
-
android:nextFocusForward
অ্যাপ ডেভেলপারদের একটি ফোকাস এলাকায় ঘূর্ণন ক্রম নির্দিষ্ট করার অনুমতি দেয়। এটি কীবোর্ড নেভিগেশনের জন্য ট্যাব অর্ডার নিয়ন্ত্রণ করতে ব্যবহৃত একই বৈশিষ্ট্য। একটি লুপ তৈরি করতে এই বৈশিষ্ট্যটি ব্যবহার করবেন না । পরিবর্তে, একটি লুপ তৈরি করতেapp:wrapAround
(নীচে দেখুন) ব্যবহার করুন। -
android:focusedByDefault
অ্যাপ ডেভেলপারদের উইন্ডোতে ডিফল্ট ফোকাস ভিউ নির্দিষ্ট করতে দেয়। একইFocusArea
এ এই অ্যাট্রিবিউট এবংapp:defaultFocus
(নীচে দেখুন) ব্যবহার করবেন না ।
FocusArea
এছাড়াও ঘূর্ণমান নেভিগেশন কাস্টমাইজ করার জন্য কিছু বৈশিষ্ট্য সংজ্ঞায়িত করে। অন্তর্নিহিত ফোকাস এলাকাগুলি এই বৈশিষ্ট্যগুলির সাথে কাস্টমাইজ করা যাবে না৷
- ( Android 11 QPR3, Android 11 Car, Android 12 )
app:defaultFocus
একটি ফোকাসযোগ্য ডিসেন্ডেন্ট ভিউয়ের আইডি নির্দিষ্ট করতে ব্যবহার করা যেতে পারে, যেটি ফোকাস করা উচিত যখন ব্যবহারকারী এইFocusArea
ধাক্কা দেয়। - ( Android 11 QPR3, Android 11 Car, Android 12 )
app:defaultFocusOverridesHistory
true
সেট করা যেতে পারে যাতে উপরে উল্লেখিত ভিউ ফোকাস নেয়, এমনকি যদি ইতিহাসের সাথে এইFocusArea
অন্য একটি ভিউ ফোকাস করা হয়। - ( অ্যান্ড্রয়েড 12 )
একটি ফোকাসযোগ্য ডিসেন্ডেন্ট ভিউয়ের আইডি নির্দিষ্ট করতেapp:nudgeLeftShortcut
,app:nudgeRightShortcut
,app:nudgeUpShortcut
, এবংapp:nudgeDownShortcut
ব্যবহার করুন, যেটি ব্যবহারকারী যখন একটি নির্দিষ্ট দিকে নাজেন তখন তার উপর ফোকাস করা উচিত। আরও জানতে, নিচের শর্টকাটের জন্য কন্টেন্ট দেখুন।( Android 11 QPR3, Android 11 Car, Android 12-এ বাতিল করা হয়েছে )
app:nudgeShortcut
এবংapp:nudgeShortcutDirection
শুধুমাত্র একটি নাজ শর্টকাট সমর্থিত। - ( Android 11 QPR3, Android 11 Car, Android 12 )
এইFocusArea
মোড়ানো ঘূর্ণন সক্ষম করতে,app:wrapAround
true
সেট করা যেতে পারে। এটি সাধারণত ব্যবহৃত হয় যখন দৃশ্যগুলি একটি বৃত্ত বা ডিম্বাকৃতিতে সাজানো হয়। - ( Android 11 QPR3, Android 11 Car, Android 12 )
এইFocusArea
হাইলাইটের প্যাডিং সামঞ্জস্য করতে,app:highlightPaddingStart
,app:highlightPaddingEnd
,app:highlightPaddingTop
,app:highlightPaddingBottom
,app:highlightPaddingHorizontal
, এবংapp:highlightPaddingVertical
ব্যবহার করুন। - ( Android 11 QPR3, Android 11 Car, Android 12 )
একটি নাজ টার্গেট খুঁজে পেতে এইFocusArea
অনুভূত সীমাগুলি সামঞ্জস্য করতে,app:startBoundOffset
,app:endBoundOffset
,app:topBoundOffset
,app:bottomBoundOffset
,app:horizontalBoundOffset
এবংapp:verticalBoundOffset
ব্যবহার করুন। - ( Android 11 QPR3, Android 11 Car, Android 12 )
প্রদত্ত দিকনির্দেশে একটি সংলগ্নFocusArea
(বা এলাকা) আইডি স্পষ্টভাবে নির্দিষ্ট করতে,app:nudgeLeft
,app:nudgeRight
,app:nudgeUp
, এবংapp:nudgeDown
ব্যবহার করুন। ডিফল্টরূপে ব্যবহৃত জ্যামিতিক অনুসন্ধান যখন পছন্দসই লক্ষ্য খুঁজে পায় না তখন এটি ব্যবহার করুন।
নাডিং সাধারণত FocusAreas এর মধ্যে নেভিগেট করে। কিন্তু নাজ শর্টকাট সহ, নজিং কখনও কখনও প্রথমে একটি FocusArea
মধ্যে নেভিগেট করে যাতে ব্যবহারকারীকে পরবর্তী FocusArea
এ নেভিগেট করতে দুবার নাজ করতে হতে পারে। নাজ শর্টকাটগুলি উপযোগী হয় যখন একটি FocusArea
একটি দীর্ঘ তালিকা থাকে যার পরে একটি ফ্লোটিং অ্যাকশন বোতাম থাকে , যেমন নীচের উদাহরণে:
নাজ শর্টকাট ব্যতীত, ব্যবহারকারীকে FAB-এ পৌঁছানোর জন্য সম্পূর্ণ তালিকার মধ্য দিয়ে ঘুরতে হবে।
ফোকাস হাইলাইট কাস্টমাইজেশন
উপরে উল্লিখিত হিসাবে, RotaryService
Android ফ্রেমওয়ার্কের ভিউ ফোকাসের বিদ্যমান ধারণার উপর ভিত্তি করে তৈরি করে। যখন ব্যবহারকারী ঘোরান এবং নাজ করেন, RotaryService
ফোকাসকে চারদিকে নিয়ে যায়, একটি ভিউকে ফোকাস করে এবং অন্যটি আনফোকাস করে। অ্যান্ড্রয়েডে, যখন একটি ভিউ ফোকাস করা হয়, যদি ভিউ:
- নিজস্ব ফোকাস হাইলাইট নির্দিষ্ট করেছে, অ্যান্ড্রয়েড ভিউ এর ফোকাস হাইলাইট আঁকে।
- একটি ফোকাস হাইলাইট নির্দিষ্ট করে না, এবং ডিফল্ট ফোকাস হাইলাইট অক্ষম করা হয় না, Android দৃশ্যের জন্য ডিফল্ট ফোকাস হাইলাইট আঁকে।
স্পর্শের জন্য ডিজাইন করা অ্যাপগুলি সাধারণত উপযুক্ত ফোকাস হাইলাইটগুলি নির্দিষ্ট করে না৷
ডিফল্ট ফোকাস হাইলাইট Android ফ্রেমওয়ার্ক দ্বারা সরবরাহ করা হয় এবং OEM দ্বারা ওভাররাইড করা যেতে পারে। অ্যাপ ডেভেলপাররা এটি পান যখন তারা যে থিমটি ব্যবহার করছেন তা Theme.DeviceDefault
থেকে প্রাপ্ত হয়।
সামঞ্জস্যপূর্ণ ব্যবহারকারীর অভিজ্ঞতার জন্য, যখনই সম্ভব ডিফল্ট ফোকাস হাইলাইটের উপর নির্ভর করুন। আপনার যদি একটি কাস্টম-আকৃতির (উদাহরণস্বরূপ, গোলাকার বা পিল-আকৃতির) ফোকাস হাইলাইটের প্রয়োজন হয়, অথবা আপনি যদি Theme.DeviceDefault
থেকে প্রাপ্ত নয় এমন একটি থিম ব্যবহার করেন, তাহলে আপনার নিজস্ব ফোকাস হাইলাইট নির্দিষ্ট করতে car-ui-লাইব্রেরি সংস্থানগুলি ব্যবহার করুন প্রতিটি দৃশ্য।
একটি দৃশ্যের জন্য একটি কাস্টম ফোকাস হাইলাইট নির্দিষ্ট করতে, দৃশ্যটির পটভূমি বা ফোরগ্রাউন্ড অঙ্কনযোগ্য একটি ড্রয়েবল পরিবর্তন করুন যা দৃশ্যটির উপর ফোকাস করা হলে ভিন্ন হয়। সাধারণত, আপনি পটভূমি পরিবর্তন চাই. নিম্নলিখিত অঙ্কনযোগ্য, যদি একটি বর্গাকার দৃশ্যের জন্য পটভূমি হিসাবে ব্যবহার করা হয়, একটি বৃত্তাকার ফোকাস হাইলাইট তৈরি করে:
<selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_focused="true" android:state_pressed="true"> <shape android:shape="oval"> <solid android:color="@color/car_ui_rotary_focus_pressed_fill_color"/> <stroke android:width="@dimen/car_ui_rotary_focus_pressed_stroke_width" android:color="@color/car_ui_rotary_focus_pressed_stroke_color"/> </shape> </item> <item android:state_focused="true"> <shape android:shape="oval"> <solid android:color="@color/car_ui_rotary_focus_fill_color"/> <stroke android:width="@dimen/car_ui_rotary_focus_stroke_width" android:color="@color/car_ui_rotary_focus_stroke_color"/> </shape> </item> <item> <ripple...> ... </ripple> </item> </selector>
( Android 11 QPR3, Android 11 Car, Android 12 ) উপরের নমুনায় বোল্ড রিসোর্স রেফারেন্সগুলি car-ui-লাইব্রেরি দ্বারা সংজ্ঞায়িত সংস্থানগুলি সনাক্ত করে৷ OEM তাদের নির্দিষ্ট করা ডিফল্ট ফোকাস হাইলাইটের সাথে সামঞ্জস্যপূর্ণ হতে ওভাররাইড করে। এটি নিশ্চিত করে যে ফোকাস হাইলাইট রঙ, স্ট্রোক প্রস্থ, এবং তাই পরিবর্তন হবে না যখন ব্যবহারকারী একটি কাস্টম ফোকাস হাইলাইট সহ একটি ভিউ এবং ডিফল্ট ফোকাস হাইলাইট সহ একটি দৃশ্যের মধ্যে নেভিগেট করে। শেষ আইটেমটি স্পর্শের জন্য ব্যবহৃত একটি লহর। সাহসী সংস্থানগুলির জন্য ব্যবহৃত ডিফল্ট মানগুলি নিম্নরূপ প্রদর্শিত হয়:
এছাড়াও, একটি কাস্টম ফোকাস হাইলাইট বলা হয় যখন একটি বোতামকে একটি কঠিন পটভূমির রঙ দেওয়া হয় যাতে এটি ব্যবহারকারীর নজরে আসে, যেমন নীচের উদাহরণে। এটি ফোকাস হাইলাইটকে দেখতে কঠিন করে তুলতে পারে। এই পরিস্থিতিতে, গৌণ রং ব্যবহার করে একটি কাস্টম ফোকাস হাইলাইট নির্দিষ্ট করুন:
- ( Android 11 QPR3, Android 11 Car, Android 12 )
car_ui_rotary_focus_fill_secondary_color
car_ui_rotary_focus_stroke_secondary_color
- ( অ্যান্ড্রয়েড 12 )
car_ui_rotary_focus_pressed_fill_secondary_color
car_ui_rotary_focus_pressed_stroke_secondary_color
যেমন:
ফোকাসড, চাপা নয় | ফোকাসড, চাপা |
রোটারি স্ক্রোলিং
যদি আপনার অ্যাপ RecyclerView
s ব্যবহার করে, তাহলে আপনার পরিবর্তে CarUiRecyclerView
s ব্যবহার করা উচিত। এটি নিশ্চিত করে যে আপনার UI অন্যদের সাথে সামঞ্জস্যপূর্ণ কারণ একটি OEM-এর কাস্টমাইজেশন সমস্ত CarUiRecyclerView
এর ক্ষেত্রে প্রযোজ্য।
আপনার তালিকার উপাদানগুলি যদি সমস্ত ফোকাসযোগ্য হয় তবে আপনাকে অন্য কিছু করতে হবে না। রোটারি নেভিগেশন নতুন ফোকাস করা উপাদানকে দৃশ্যমান করতে তালিকার উপাদান এবং তালিকা স্ক্রোলগুলির মাধ্যমে ফোকাসকে সরিয়ে দেয়।
( Android 11 QPR3, Android 11 Car, Android 12 )
যদি ফোকাসযোগ্য এবং ফোকাসযোগ্য উপাদানগুলির একটি মিশ্রণ থাকে, অথবা যদি সমস্ত উপাদানগুলি ফোকাসযোগ্য না হয়, আপনি ঘূর্ণমান স্ক্রোলিং সক্ষম করতে পারেন, যা ব্যবহারকারীকে অনফোকাসযোগ্য আইটেমগুলি এড়িয়ে না গিয়ে ধীরে ধীরে তালিকার মধ্য দিয়ে স্ক্রোল করতে রোটারি কন্ট্রোলার ব্যবহার করতে দেয়৷ ঘূর্ণমান স্ক্রোলিং সক্ষম করতে, app:rotaryScrollEnabled
অ্যাট্রিবিউটটিকে true
এ সেট করুন।
( Android 11 QPR3, Android 11 Car, Android 12 )
আপনি CarUiUtils
এ setRotaryScrollEnabled()
পদ্ধতি সহ av CarUiRecyclerView
সহ যে কোনও স্ক্রোলযোগ্য ভিউতে রোটারি স্ক্রলিং সক্ষম করতে পারেন। আপনি যদি তা করেন তবে আপনার প্রয়োজন:
- স্ক্রোলযোগ্য দৃশ্যটিকে ফোকাসযোগ্য করুন যাতে এটি ফোকাস করা যায় যখন এর কোনো ফোকাসযোগ্য বংশধর দৃশ্য দৃশ্যমান হয় না,
-
setDefaultFocusHighlightEnabled(false)
কল করে স্ক্রোলযোগ্য ভিউতে ডিফল্ট ফোকাস হাইলাইট অক্ষম করুন যাতে স্ক্রোলযোগ্য ভিউ ফোকাস করা মনে না হয়, -
setDescendantFocusability(ViewGroup.FOCUS_BEFORE_DESCENDANTS)
কল করে স্ক্রোলযোগ্য দৃশ্যটি তার বংশধরদের আগে ফোকাস করা হয়েছে তা নিশ্চিত করুন। -
SOURCE_ROTARY_ENCODER
সহ মোশন ইভেন্টগুলির জন্য শুনুন এবং হয়AXIS_VSCROLL
বাAXIS_HSCROLL
স্ক্রোল করার দূরত্ব এবং দিক নির্দেশ করতে (চিহ্নের মাধ্যমে)।
যখন একটি CarUiRecyclerView
এ রোটারি স্ক্রোলিং সক্ষম করা হয় এবং ব্যবহারকারী এমন একটি এলাকায় ঘোরান যেখানে কোনও ফোকাসযোগ্য দৃশ্য নেই, স্ক্রলবারটি ধূসর থেকে নীল হয়ে যায়, যেন স্ক্রলবারটি ফোকাস করা নির্দেশ করে। আপনি যদি চান একটি অনুরূপ প্রভাব বাস্তবায়ন করতে পারেন.
মোশন ইভেন্টগুলি উৎস ব্যতীত মাউসের একটি স্ক্রোল হুইল দ্বারা উত্পন্ন হিসাবে একই।
সরাসরি ম্যানিপুলেশন মোড
সাধারণত, নাজ এবং ঘূর্ণন ব্যবহারকারী ইন্টারফেসের মাধ্যমে নেভিগেট করে, যখন কেন্দ্র বোতাম টিপে পদক্ষেপ নেয়, যদিও এটি সর্বদা হয় না। উদাহরণস্বরূপ, যদি একজন ব্যবহারকারী অ্যালার্মের ভলিউম সামঞ্জস্য করতে চান, তাহলে তারা ভলিউম স্লাইডারে নেভিগেট করতে রোটারি কন্ট্রোলার ব্যবহার করতে পারে, কেন্দ্র বোতাম টিপুন, অ্যালার্মের ভলিউম সামঞ্জস্য করতে কন্ট্রোলারটি ঘোরাতে পারেন এবং তারপর নেভিগেশনে ফিরে যেতে ব্যাক বোতাম টিপুন। . এটি সরাসরি ম্যানিপুলেশন (DM) মোড হিসাবে উল্লেখ করা হয়। এই মোডে, রোটারি কন্ট্রোলারটি নেভিগেট করার পরিবর্তে সরাসরি ভিউয়ের সাথে ইন্টারঅ্যাক্ট করতে ব্যবহৃত হয়।
দুটি উপায়ের একটিতে DM প্রয়োগ করুন। আপনি যদি শুধুমাত্র ঘূর্ণন পরিচালনা করতে চান এবং আপনি যে ভিউ ম্যানিপুলেট করতে চান তা ACTION_SCROLL_FORWARD
এবং ACTION_SCROLL_BACKWARD
AccessibilityEvent
যথাযথভাবে সাড়া দেয়, সহজ পদ্ধতি ব্যবহার করুন। অন্যথায়, উন্নত প্রক্রিয়া ব্যবহার করুন।
সিস্টেম উইন্ডোতে সাধারণ প্রক্রিয়াই একমাত্র বিকল্প; অ্যাপ্লিকেশন উভয় প্রক্রিয়া ব্যবহার করতে পারেন.
সরল মেকানিজম
( Android 11 QPR3, Android 11 Car, Android 12 )
আপনার অ্যাপটিকে DirectManipulationHelper.setSupportsRotateDirectly(View view, boolean enable)
কল করা উচিত। ব্যবহারকারী যখন DM মোডে থাকে তখন RotaryService
শনাক্ত করে এবং যখন একটি ভিউ ফোকাস করার সময় ব্যবহারকারী সেন্টার বোতাম টিপে তখন DM মোডে প্রবেশ করে। যখন DM মোডে, ঘূর্ণনগুলি ACTION_SCROLL_FORWARD
বা ACTION_SCROLL_BACKWARD
সঞ্চালন করে এবং ব্যবহারকারী যখন পিছনের বোতাম টিপে তখন DM মোড থেকে প্রস্থান করে৷ ডিএম মোডে প্রবেশ এবং প্রস্থান করার সময় সাধারণ প্রক্রিয়াটি দৃশ্যের নির্বাচিত অবস্থাকে টগল করে।
ব্যবহারকারী DM মোডে আছে এমন একটি ভিজ্যুয়াল কিউ প্রদান করতে, নির্বাচন করার সময় আপনার ভিউকে আলাদা দেখান। উদাহরণস্বরূপ, যখন android:state_selected
true
হয় তখন পটভূমি পরিবর্তন করুন।
উন্নত প্রক্রিয়া
অ্যাপটি নির্ধারণ করে কখন RotaryService
DM মোডে প্রবেশ করে এবং প্রস্থান করে। একটি সামঞ্জস্যপূর্ণ ব্যবহারকারীর অভিজ্ঞতার জন্য, একটি DM ভিউ ফোকাস করে কেন্দ্র বোতাম টিপলে DM মোডে প্রবেশ করা উচিত এবং পিছনের বোতামটি DM মোড থেকে প্রস্থান করা উচিত। যদি কেন্দ্র বোতাম এবং/অথবা নাজ ব্যবহার না করা হয়, তাহলে তারা DM মোড থেকে প্রস্থান করার বিকল্প উপায় হতে পারে। ম্যাপের মতো অ্যাপের জন্য, ডিএম মোডে প্রবেশ করতে DM প্রতিনিধিত্ব করার জন্য একটি বোতাম ব্যবহার করা যেতে পারে।
উন্নত ডিএম মোড সমর্থন করতে, একটি দৃশ্য:
- ( Android 11 QPR3, Android 11 Car, Android 12 ) DM মোডে প্রবেশ করতে একটি
KEYCODE_DPAD_CENTER
ইভেন্ট শুনতে হবে এবং DM মোড থেকে প্রস্থান করার জন্য একটিKEYCODE_BACK
ইভেন্ট শুনতে হবে, প্রতিটি ক্ষেত্রেDirectManipulationHelper.enableDirectManipulationMode()
কল করে। এই ঘটনাগুলি শুনতে, নিম্নলিখিতগুলির মধ্যে একটি করুন:- একটি
OnKeyListener
নিবন্ধন করুন। অথবা, - ভিউটি প্রসারিত করুন এবং তারপরে এটির
dispatchKeyEvent()
পদ্ধতি ওভাররাইড করুন।
- একটি
- নাজ ইভেন্টগুলি শুনতে হবে (
KEYCODE_DPAD_UP
,KEYCODE_DPAD_DOWN
,KEYCODE_DPAD_LEFT
, বাKEYCODE_DPAD_RIGHT
) যদি ভিউটি নাজগুলি পরিচালনা করে। -
MotionEvent
s শুনতে হবে এবংAXIS_SCROLL
এ ঘূর্ণন গণনা পেতে হবে যদি ভিউ ঘূর্ণন পরিচালনা করতে চায়। এটি করার বিভিন্ন উপায় রয়েছে:- একটি
OnGenericMotionListener
নিবন্ধন করুন। - ভিউ প্রসারিত করুন এবং এর
dispatchTouchEvent()
পদ্ধতি ওভাররাইড করুন।
- একটি
- DM মোডে আটকে থাকা এড়াতে, দৃশ্যটি যে খণ্ড বা কার্যকলাপের অন্তর্গত তা ইন্টারেক্টিভ না হলে DM মোড থেকে বেরিয়ে আসতে হবে।
- দৃশ্যটি DM মোডে রয়েছে তা নির্দেশ করার জন্য একটি ভিজ্যুয়াল কিউ প্রদান করা উচিত।
একটি মানচিত্র প্যান এবং জুম করতে DM মোড ব্যবহার করে এমন একটি কাস্টম ভিউয়ের একটি নমুনা নীচে দেওয়া হয়েছে:
/** Whether this view is in DM mode. */ private boolean mInDirectManipulationMode;
/** Initializes the view. Called by the constructors. */ private void init() { setOnKeyListener((view, keyCode, keyEvent) -> { boolean isActionUp = keyEvent.getAction() == KeyEvent.ACTION_UP; switch (keyCode) { // Always consume KEYCODE_DPAD_CENTER and KEYCODE_BACK events. case KeyEvent.KEYCODE_DPAD_CENTER: if (!mInDirectManipulationMode && isActionUp) { mInDirectManipulationMode = true; DirectManipulationHelper.enableDirectManipulationMode(this, true); setSelected(true); // visually indicate DM mode } return true; case KeyEvent.KEYCODE_BACK: if (mInDirectManipulationMode && isActionUp) { mInDirectManipulationMode = false; DirectManipulationHelper.enableDirectManipulationMode(this, false); setSelected(false); } return true; // Consume controller nudge events only when in DM mode. // When in DM mode, nudges pan the map. case KeyEvent.KEYCODE_DPAD_UP: if (!mInDirectManipulationMode) return false; if (isActionUp) pan(0f, -10f); return true; case KeyEvent.KEYCODE_DPAD_DOWN: if (!mInDirectManipulationMode) return false; if (isActionUp) pan(0f, 10f); return true; case KeyEvent.KEYCODE_DPAD_LEFT: if (!mInDirectManipulationMode) return false; if (isActionUp) pan(-10f, 0f); return true; case KeyEvent.KEYCODE_DPAD_RIGHT: if (!mInDirectManipulationMode) return false; if (isActionUp) pan(10f, 0f); return true; // Don't consume other key events. default: return false; } });
// When in DM mode, rotation zooms the map. setOnGenericMotionListener(((view, motionEvent) -> { if (!mInDirectManipulationMode) return false; float scroll = motionEvent.getAxisValue(MotionEvent.AXIS_SCROLL); zoom(10 * scroll); return true; })); }
@Override public void onPause() { if (mInDirectManipulationMode) { // To ensure that the user doesn't get stuck in DM mode, disable DM mode // when the fragment is not interactive (e.g., a dialog shows up). mInDirectManipulationMode = false; DirectManipulationHelper.enableDirectManipulationMode(this, false); } super.onPause(); }
আরো উদাহরণ RotaryPlayground
প্রকল্পে পাওয়া যাবে।
অ্যাক্টিভিটিভিউ
একটি ActivityView ব্যবহার করার সময়:
-
ActivityView
ফোকাসযোগ্য হওয়া উচিত নয়। - ( Android 11 QPR3, Android 11 Car, Android 11-এ বাতিল করা হয়েছে )
ActivityView
এর বিষয়বস্তুতে প্রথম ফোকাসযোগ্য ভিউ হিসেবে একটিFocusParkingView
থাকা আবশ্যক এবং এরapp:shouldRestoreFocus
অ্যাট্রিবিউটটিfalse
হতে হবে। -
ActivityView
এর বিষয়বস্তুতেandroid:focusByDefault
ভিউ থাকা উচিত নয়।
ব্যবহারকারীর জন্য, নেভিগেশনের উপর ActivityViews-এর কোনো প্রভাব থাকা উচিত নয়, ফোকাস এলাকাগুলি ActivityViews স্প্যান করতে পারে না। অন্য কথায়, আপনার কাছে একটি একক ফোকাস এলাকা থাকতে পারে না যেটিতে একটি ActivityView
ভিতরে এবং বাইরে সামগ্রী রয়েছে। আপনি যদি আপনার ActivityView
এ কোনো FocusAreas যোগ না করেন, তাহলে ActivityView
এ ভিউ হায়ারার্কির মূলটিকে একটি অন্তর্নিহিত ফোকাস এলাকা হিসেবে বিবেচনা করা হয়।
বোতাম যেগুলো চেপে ধরে থাকলে কাজ করে
বেশিরভাগ বোতাম ক্লিক করার সময় কিছু ক্রিয়া করে। কিছু বোতাম পরিবর্তে চেপে রাখা হলে কাজ করে। উদাহরণস্বরূপ, ফাস্ট ফরোয়ার্ড এবং রিওয়াইন্ড বোতামগুলি সাধারণত চেপে ধরে থাকলে কাজ করে। এই ধরনের বোতামগুলিকে রোটারি সমর্থন করতে, KEYCODE_DPAD_CENTER
KeyEvents
নিম্নরূপ শুনুন:
mButton.setOnKeyListener((v, keyCode, event) -> { if (keyCode != KEYCODE_DPAD_CENTER) { return false; } if (event.getAction() == ACTION_DOWN) { mButton.setPressed(true); mHandler.post(mRunnable); } else { mButton.setPressed(false); mHandler.removeCallbacks(mRunnable); } return true; });
যেখানে mRunnable
একটি পদক্ষেপ নেয় (যেমন রিওয়াইন্ডিং) এবং বিলম্বের পরে চালানোর জন্য নিজেই সময়সূচী করে।
টাচ মোড
ব্যবহারকারীরা একটি ঘূর্ণমান নিয়ামক ব্যবহার করে একটি গাড়িতে হেড ইউনিটের সাথে দুটি উপায়ে যোগাযোগ করতে পারে, হয় রোটারি কন্ট্রোলার ব্যবহার করে বা স্ক্রীন স্পর্শ করে। ঘূর্ণমান নিয়ামক ব্যবহার করার সময়, ফোকাসযোগ্য দৃশ্যগুলির একটি হাইলাইট করা হয়। স্ক্রীন স্পর্শ করার সময়, কোন ফোকাস হাইলাইট প্রদর্শিত হয় না৷ ব্যবহারকারী যেকোনো সময় এই ইনপুট মোডগুলির মধ্যে স্যুইচ করতে পারেন:
- ঘূর্ণমান → স্পর্শ। যখন ব্যবহারকারী স্ক্রীন স্পর্শ করে, ফোকাস হাইলাইট অদৃশ্য হয়ে যায়।
- স্পর্শ → ঘূর্ণমান. যখন ব্যবহারকারী কেন্দ্র বোতামটি নাজেন, ঘোরান বা চাপেন, তখন ফোকাস হাইলাইট প্রদর্শিত হয়।
ইনপুট মোডে ব্যাক এবং হোম বোতামের কোন প্রভাব নেই।
অ্যান্ড্রয়েডের টাচ মোডের বিদ্যমান ধারণায় রোটারি পিগিব্যাক। ব্যবহারকারী কোন ইনপুট মোড ব্যবহার করছেন তা নির্ধারণ করতে আপনি View.isInTouchMode()
ব্যবহার করতে পারেন। পরিবর্তনের জন্য আপনি OnTouchModeChangeListener
ব্যবহার করতে পারেন। যদিও এটি বর্তমান ইনপুট মোডের জন্য আপনার ইউজার ইন্টারফেস কাস্টমাইজ করতে ব্যবহার করা যেতে পারে, কোনো বড় পরিবর্তন এড়িয়ে চলুন কারণ সেগুলি বিরক্তিকর হতে পারে।
সমস্যা সমাধান
স্পর্শের জন্য ডিজাইন করা একটি অ্যাপে, নেস্টেড ফোকাসযোগ্য ভিউ থাকা সাধারণ ব্যাপার। উদাহরণস্বরূপ, একটি ImageButton
চারপাশে একটি FrameLayout
থাকতে পারে, উভয়ই ফোকাসযোগ্য। এটি স্পর্শের জন্য কোন ক্ষতি করে না তবে এটি ঘূর্ণমান ব্যবহারকারীর জন্য একটি দুর্বল অভিজ্ঞতার কারণ হতে পারে কারণ ব্যবহারকারীকে পরবর্তী ইন্টারেক্টিভ ভিউতে যাওয়ার জন্য কন্ট্রোলারটিকে দুবার ঘোরাতে হবে। একটি ভাল ব্যবহারকারীর অভিজ্ঞতার জন্য, Google আপনাকে বাইরের দৃশ্য বা অভ্যন্তরীণ দৃশ্য ফোকাসযোগ্য করার পরামর্শ দেয়, তবে উভয়ই নয়।
রোটারি কন্ট্রোলারের মাধ্যমে চাপ দেওয়ার সময় যদি একটি বোতাম বা সুইচ ফোকাস হারায়, তাহলে এই শর্তগুলির মধ্যে একটি প্রযোজ্য হতে পারে:
- বোতাম টিপানোর কারণে বোতাম বা সুইচটি নিষ্ক্রিয় করা হচ্ছে (সংক্ষিপ্ত বা অনির্দিষ্টকালের জন্য)। উভয় ক্ষেত্রেই, এটি মোকাবেলা করার দুটি উপায় রয়েছে:
-
android:enabled
স্টেটটিকেtrue
হিসাবে ছেড়ে দিন এবং কাস্টম স্টেটে বর্ণিত বোতাম বা সুইচ ধূসর করতে একটি কাস্টম স্থিতি ব্যবহার করুন। - বোতাম বা সুইচের চারপাশে একটি ধারক ব্যবহার করুন এবং বোতাম বা সুইচের পরিবর্তে ধারকটিকে ফোকাসযোগ্য করে তুলুন। (ক্লিক শ্রোতা অবশ্যই পাত্রে থাকতে হবে।)
-
- বোতাম বা সুইচ প্রতিস্থাপন করা হচ্ছে। উদাহরণ স্বরূপ, বোতাম টিপলে বা সুইচ টগল করা হলে গৃহীত পদক্ষেপগুলি উপলব্ধ অ্যাকশনগুলির একটি রিফ্রেশ ট্রিগার করতে পারে যার ফলে বিদ্যমান বোতামগুলিকে প্রতিস্থাপন করতে নতুন বোতামগুলি ঘটতে পারে৷ এটি মোকাবেলা করার দুটি উপায় আছে:
- একটি নতুন বোতাম বা সুইচ তৈরি করার পরিবর্তে, বিদ্যমান বোতাম বা সুইচের আইকন এবং/অথবা পাঠ্য সেট করুন।
- উপরের মত, বোতাম বা সুইচের চারপাশে একটি ফোকাসযোগ্য পাত্র যোগ করুন।
রোটারি খেলার মাঠ
RotaryPlayground
হল রোটারির জন্য একটি রেফারেন্স অ্যাপ। আপনার অ্যাপ্লিকেশানগুলিতে ঘূর্ণমান বৈশিষ্ট্যগুলিকে কীভাবে একীভূত করতে হয় তা শিখতে এটি ব্যবহার করুন৷ RotaryPlayground
এমুলেটর বিল্ড এবং Android Automotive OS (AAOS) চালিত ডিভাইসগুলির জন্য বিল্ডে অন্তর্ভুক্ত।
-
RotaryPlayground
সংগ্রহস্থল:packages/apps/Car/tests/RotaryPlayground/
- সংস্করণ: Android 11 QPR3, Android 11 Car, এবং Android 12
RotaryPlayground
অ্যাপটি বাম দিকে নিম্নলিখিত ট্যাবগুলি দেখায়:
- কার্ড। ফোকাস এলাকার চারপাশে নেভিগেট করার পরীক্ষা করুন, ফোকাসযোগ্য উপাদান এবং টেক্সট ইনপুট এড়িয়ে যান।
- সরাসরি ম্যানিপুলেশন। পরীক্ষা উইজেট যা সহজ এবং উন্নত সরাসরি ম্যানিপুলেশন মোড সমর্থন করে। এই ট্যাবটি বিশেষভাবে অ্যাপ উইন্ডোর মধ্যে সরাসরি ম্যানিপুলেশনের জন্য।
- Sys UI ম্যানিপুলেশন। পরীক্ষা উইজেট যা সিস্টেম উইন্ডোতে সরাসরি ম্যানিপুলেশন সমর্থন করে যেখানে শুধুমাত্র সাধারণ সরাসরি ম্যানিপুলেশন মোড সমর্থিত।
- গ্রিড। স্ক্রলিং সহ জেড-প্যাটার্ন রোটারি নেভিগেশন পরীক্ষা করুন।
- বিজ্ঞপ্তি। হেড-আপ বিজ্ঞপ্তিগুলির মধ্যে এবং বাইরে নডিং পরীক্ষা করুন।
- স্ক্রল করুন। ফোকাসযোগ্য এবং ফোকাসযোগ্য বিষয়বস্তুর মিশ্রণের মাধ্যমে পরীক্ষা স্ক্রলিং।
- ওয়েবভিউ।
WebView
লিঙ্কগুলির মাধ্যমে নেভিগেট করার পরীক্ষা করুন। - কাস্টম
FocusArea
।FocusArea
কাস্টমাইজেশন পরীক্ষা করুন:- চারপাশে মোড়ানো.
-
android:focusedByDefault
এবংapp:defaultFocus
. - সুস্পষ্ট নাজ লক্ষ্যবস্তু.
- নজ শর্টকাট.
- কোন ফোকাসযোগ্য দৃশ্য ছাড়া
FocusArea
.