Swipeable
হল একটি কম্পোজ ম্যাটেরিয়াল এপিআই যা আপনাকে এমন উপাদান তৈরি করতে সাহায্য করে যা বিচ্ছিন্ন অবস্থার মধ্যে সোয়াইপ করা যায়, যেমন নীচের শীট, ড্রয়ার বা সোয়াইপ-টু-খারিজ। উন্নত ব্যবহারের ক্ষেত্রে আরও ভালভাবে সমর্থন করার জন্য, যেমন অ্যাঙ্করগুলি যেগুলি একটি উপাদানের আকারের উপর নির্ভর করে, একটি উত্তরসূরী Compose-Foundation 1.6.0-alpha01: AnchoredDraggable
এ প্রকাশিত হয়েছিল। AnchoredDraggable
হল একটি ফাউন্ডেশন এপিআই যা নোঙরযুক্ত অবস্থার সাথে টেনে আনা যায় এমন উপাদান তৈরি করার জন্য, যেমন নীচের শীট, ড্রয়ার বা সোয়াইপ-টু-খারিজ।
ফাউন্ডেশনের AnchoredDraggable
পক্ষে উপাদানের Swipeable
APIগুলিকে অবমূল্যায়ন করা হয়েছে এবং ভবিষ্যতে রিলিজে সরিয়ে দেওয়া হবে। এই নির্দেশিকা বর্ণনা করে কিভাবে Swipeable
API থেকে AnchoredDraggable
এ স্থানান্তর করা যায়।
SwipeableState
কে AnchoredDraggableState
এ স্থানান্তর করুন
আপনার রাজ্য ধারক পরিবর্তন সনাক্ত করে শুরু করুন. AnchoredDraggableState
থেকে উত্তরাধিকারসূত্রে প্রাপ্ত করা যায় না, এবং অফসেটটি শুরু হওয়ার আগে Float.NaN
হিসাবে উপস্থাপন করা হয়।
আপনার রাষ্ট্র ধারক আপডেট
AnchoredDraggableState
একটি চূড়ান্ত শ্রেণী, যার অর্থ এটি থেকে উত্তরাধিকারসূত্রে পাওয়া যাবে না। যদি আপনার বিদ্যমান উপাদানটি SwipeableState
থেকে উত্তরাধিকারসূত্রে প্রাপ্ত হয়, তাহলে আপনার রাজ্য ধারককে এটি থেকে উত্তরাধিকার না করে AnchoredDraggableState
এর একটি রেফারেন্স ধরে রাখতে আপডেট করুন:
সোয়াইপযোগ্য
class MySwitchState: SwipeableState()
নোঙর করা ড্র্যাগেবল
class MySwitchState {
private val anchoredDraggableState = AnchoredDraggableState(...)
}
যেহেতু আপনার স্টেট হোল্ডার আর SwipeableState
থেকে উত্তরাধিকারী হয় না, তাই আপনাকে হয়তো APIs প্রকাশ করতে হবে। আপনি ব্যবহার করতে পারেন এমন সবচেয়ে সাধারণ APIগুলি হল offset
, progress
, currentValue
এবং targetValue
।
অফসেট অ্যাক্সেস করুন
Swipeable
এর বিপরীতে, AnchoredDraggableState
এর offset
হল Float.NaN
শুরু হওয়ার আগে। AnchoredDraggable
এ, অ্যাঙ্করগুলি AnchoredDraggableState
এর কনস্ট্রাক্টরের কাছে পাঠানো যেতে পারে বা AnchoredDraggableState#updateAnchors
এর মাধ্যমে আপডেট করা যেতে পারে। AnchoredDraggableState
এর কনস্ট্রাক্টরের কাছে অ্যাঙ্করগুলি পাস করা হলে অফসেটটি অবিলম্বে শুরু হয়।
যদি আপনার অ্যাঙ্করগুলি লেআউটের উপর নির্ভর করে বা পরিবর্তন করতে পারে, অ্যাঙ্করগুলি পরিবর্তন করার সময় রাষ্ট্রটি পুনরায় তৈরি করা এড়াতে AnchoredDraggableState#updateAnchors
ব্যবহার করুন।
আপনি যদি updateAnchors
ব্যবহার করেন, তাহলে অ্যাঙ্করগুলিকে updateAnchors
করার আগে অফসেট Float.NaN
হবে। ঘটনাক্রমে Float.NaN
কে কম্পোনেন্টে পাস করা এড়াতে, AnchoredDraggableState#requireOffset
ব্যবহার করুন যাতে এটি পড়ার সময় অফসেট আরম্ভ করা হয়েছে। এটি আপনাকে প্রথম দিকে অসঙ্গতি বা সম্ভাব্য বাগ ধরতে সাহায্য করে।
@Composable
fun AnchoredDraggableBox() {
val state = remember { AnchoredDraggableState(...) }
val density = LocalDensity.current
val anchors = remember { DraggableAnchors { ... } }
SideEffect {
state.updateAnchors(anchors)
}
Box(
Modifier.offset { IntOffset(x = state.requireOffset(), y = 0) }
}
}
Modifier.swipeable
এ Modifier.anchoredDraggable
এ মাইগ্রেট করুন
Modifier.anchoredDraggable()
পরিবর্তন করে Modifier.swipeable
. Modifier.swipeable()
এর কিছু প্যারামিটার সরাসরি AnchoredDraggableState
এ চলে গেছে, যেমনটি নিম্নলিখিত বিভাগে বর্ণিত হয়েছে।
অ্যাঙ্কর সংজ্ঞায়িত করুন
DraggableAnchors
বিল্ডার পদ্ধতি ব্যবহার করে অ্যাঙ্করগুলিকে সংজ্ঞায়িত করুন। তারপরে, এগুলিকে AnchoredDraggableState#updateAnchors
বা AnchoredDraggableState
কনস্ট্রাক্টরের কাছে প্রেরণ করুন:
কনস্ট্রাক্টর
enum class DragValue { Start, Center, End }
@Composable
fun AnchoredDraggableBox() {
val anchors = DraggableAnchors {
Start at -100.dp.toPx()
Center at 0f
End at 100.dp.toPx()
}
val state = remember {
AnchoredDraggableState(anchors = anchors)
}
Box(
Modifier.offset { IntOffset(x = state.requireOffset(), y = 0) }
)
}
আপডেট অ্যাঙ্কর
enum class DragValue { Start, Center, End }
@Composable
fun AnchoredDraggableBox() {
val state = remember { AnchoredDraggableState(...) }
val density = LocalDensity.current
val anchors = with (density) {
DraggableAnchors {
Start at -100.dp.toPx()
Center at 0f
End at 100.dp.toPx()
}
}
SideEffect {
state.updateAnchors(anchors)
}
Box(
Modifier.offset { IntOffset(x = state.requireOffset(), y = 0) }
)
}
যদি অ্যাঙ্করগুলি স্থির থাকে তবে সেগুলিকে কনস্ট্রাক্টরের কাছে পাঠান। যদি তারা লেআউটের উপর নির্ভর করে বা স্থির না হয়, updateAnchors
ব্যবহার করুন।
অবস্থানগত থ্রেশহোল্ড সংজ্ঞায়িত করুন
থ্রেশহোল্ড প্যারামিটারের ধরন এবং নাম পরিবর্তিত হয়েছে। একটি পৃথক ThresholdConfig
ইন্টারফেস থাকার পরিবর্তে, AnchoredDraggableState
একটি positionalThreshold
প্যারামিটার রয়েছে যা একটি ল্যাম্বডা ফাংশন নেয় যা থ্রেশহোল্ডের অবস্থান ফিরিয়ে দেয়। উদাহরণস্বরূপ, 50% এর একটি অবস্থানগত থ্রেশহোল্ড এভাবে প্রকাশ করা যেতে পারে:
val anchoredDraggableState = AnchoredDraggableState(
positionalThreshold = { distance -> distance * 0.5f },
...
)
56dp
এর একটি অবস্থানগত থ্রেশহোল্ড এভাবে প্রকাশ করা যেতে পারে:
val density = LocalDensity.current
val anchoredDraggableState = AnchoredDraggableState(
positionalThreshold = { with(density) { 56.dp.toPx() } },
...
)
বেগ থ্রেশহোল্ড সংজ্ঞায়িত করুন
বেগ থ্রেশহোল্ডগুলি AnchoredDraggableState
স্টেটের কনস্ট্রাক্টরের কাছেও পাস করা হয় এবং ল্যাম্বডা হিসাবেও প্রকাশ করা হয়:
val density = LocalDensity.current
val anchoredDraggableState = AnchoredDraggableState(
velocityThreshold = { with(density) { 125.dp.toPx() } },
...
)
API পৃষ্ঠের পরিবর্তন
নীচে API পৃষ্ঠের পরিবর্তনগুলির একটি ওভারভিউ খুঁজুন।
AnchoredDraggableState
| |
---|---|
| |
| |
| |
| |
| |
| N/A |
| |
| |
| |
| |
| |
|
Modifier.anchoredDraggable
| |
---|---|
| |
| |
| |
| |
| |
| |
| |
| এখনও সমর্থিত না. সর্বশেষ অবস্থার জন্য b/288084801 দেখুন। |
| |