Swipeable, alt sayfalar, çekmeceler veya kaydırarak kapatma gibi ayrı durumlar arasında kaydırılabilir bileşenler oluşturmanıza yardımcı olan bir Compose Material API'sidir. Bileşenin boyutuna bağlı olarak sabitler gibi gelişmiş kullanım alanlarını daha iyi desteklemek için Compose-Temel 1.6.0-alpha01: AnchoredDraggable sürümünde bir takipçi yayınlandı. AnchoredDraggable, alt sayfalar, çekmeceler veya kaydırarak kapatma gibi sabitlenmiş duruma sahip sürüklenebilir bileşenler oluşturmak için kullanılan bir Foundation API'sidir.
Material'ın Swipeable API'lerinin desteği sonlandırıldı ve Foundation'ın AnchoredDraggable API'leri kullanılmaya başlandı. Bu API'ler gelecekteki bir sürümde kaldırılacak. Bu kılavuzda, Swipeable API'lerinden AnchoredDraggable API'lerine nasıl geçiş yapılacağı açıklanmaktadır.
SwipeableState'ü AnchoredDraggableState'e taşıma
Eyalet tüzel kişinizdeki değişiklikleri belirleyerek başlayın. AnchoredDraggableState, başka bir nesneden devralınamaz ve ofset, başlatılmadan önce Float.NaN olarak gösterilir.
Durum sahibinizi güncelleme
AnchoredDraggableState nihai bir sınıftır. Yani bu sınıftan miras alınamaz. Mevcut bileşeniniz SwipeableState'dan devralındıysa durum tutucunuzu, AnchoredDraggableState'dan devralmak yerine AnchoredDraggableState'a referans verecek şekilde güncelleyin:
Kaydırılabilir
class MySwitchState: SwipeableState()
AnchoredDraggable
class MySwitchState {
private val anchoredDraggableState = AnchoredDraggableState(...)
}
Durum tutucunuz artık SwipeableState'ten devralmadığı için API'leri kendiniz göstermeniz gerekebilir. Kullanabileceğiniz en yaygın API'ler şunlardır: offset, progress, currentValue ve targetValue.
Ofsete erişme
Swipeable'tekinin aksine, AnchoredDraggableState'un offset özelliği başlatılmadan önce Float.NaN değerini alır. AnchoredDraggable'te ankörler AnchoredDraggableState'un oluşturucusuna iletilebilir veya AnchoredDraggableState#updateAnchors aracılığıyla güncellenebilir. Sabit noktaları AnchoredDraggableState'ın kurucusuna iletmek, ofseti hemen başlatır.
Sabitleme noktalarınız düzene bağlıysa veya değişebilirse sabitleme noktaları değiştiğinde durumu yeniden oluşturmamak için AnchoredDraggableState#updateAnchors kullanın.
updateAnchors kullanırsanız ankrajlar updateAnchors'e iletilmeden önce ofset Float.NaN olur. Bileşenlere yanlışlıkla Float.NaN iletmeyi önlemek için, ofsetin okunurken başlatılmasını zorunlu kılmak üzere AnchoredDraggableState#requireOffset kullanın. Bu sayede tutarsızlıkları veya olası hataları erkenden yakalayabilirsiniz.
@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'e taşıma
Modifier.anchoredDraggable(), Modifier.swipeable yerine geçer. Modifier.swipeable() parametrelerinden bazıları, aşağıdaki bölümlerde açıklandığı gibi doğrudan AnchoredDraggableState parametresine taşındı.
Sabit bağlantıları tanımlama
DraggableAnchors oluşturucu yöntemini kullanarak ankrajları tanımlayın. Ardından, bunları AnchoredDraggableState#updateAnchors veya AnchoredDraggableState oluşturucusuna iletin:
Oluşturucu
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) }
)
}
updateAnchors
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) }
)
}
Sabit ankrajlar varsa bunları kurucuya iletin. Bu öğeler düzene bağlıysa veya statik değilse updateAnchors kullanın.
Konumsal eşikleri tanımlama
thresholds parametresinin türü ve adı değişti. Ayrı bir ThresholdConfig arayüzü yerine AnchoredDraggableState, eşiğin konumunu döndüren bir lambda işlevi alan bir positionalThreshold parametresine sahiptir. Örneğin, %50'lik bir konumsal eşik şu şekilde ifade edilebilir:
val anchoredDraggableState = AnchoredDraggableState(
positionalThreshold = { distance -> distance * 0.5f },
...
)
56dp konum eşiği şu şekilde ifade edilebilir:
val density = LocalDensity.current
val anchoredDraggableState = AnchoredDraggableState(
positionalThreshold = { with(density) { 56.dp.toPx() } },
...
)
Hız eşiklerini tanımlama
Hız eşikleri, AnchoredDraggableState'ün kurucusuna da iletilir ve lambda olarak da ifade edilir:
val density = LocalDensity.current
val anchoredDraggableState = AnchoredDraggableState(
velocityThreshold = { with(density) { 125.dp.toPx() } },
...
)
API yüzeyinde yapılan değişiklikler
API yüzeyindeki değişikliklere genel bakışı aşağıda bulabilirsiniz.
AnchoredDraggableState
|
|
|---|---|
|
|
|
|
|
|
|
|
|
|
|
Yok |
|
|
|
|
|
|
|
|
|
|
|
Modifier.anchoredDraggable
|
|
|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Henüz desteklenmiyor. Son durum için b/288084801 adresine bakın. |
|
|