Я использую Kotlin для разработки приложения, подобного Spotify. В приведенном ниже фрагменте кода он генерировал индикацию прогресса, когда я прокручивал (например, в какой момент я прокрутил). < /P>
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.material3.Slider
import androidx.compose.material3.SliderDefaults
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.alpha
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import kotlin.math.roundToInt
@Composable
fun SeekSlider(
progress: Float,
durationMillis: Int,
onSeekFinished: (Float) -> Unit,
modifier: Modifier = Modifier
) {
var sliderPosition by remember { mutableStateOf(progress) }
var isDragging by remember { mutableStateOf(false) }
LaunchedEffect(progress) {
if (!isDragging) {
sliderPosition = progress
}
}
val currentSeconds = ((sliderPosition * durationMillis) / 1000).roundToInt()
fun formatTime(seconds: Int): String {
val m = seconds / 60
val s = seconds % 60
return "%d:%02d".format(m, s)
}
val currentTimeText = formatTime(currentSeconds)
Column(
modifier = modifier.fillMaxWidth(),
horizontalAlignment = Alignment.CenterHorizontally
) {
Row(
modifier = Modifier.fillMaxWidth(),
verticalAlignment = Alignment.CenterVertically
) {
Slider(
value = sliderPosition,
onValueChange = { newValue ->
sliderPosition = newValue
isDragging = true
},
onValueChangeFinished = {
isDragging = false
onSeekFinished(sliderPosition)
},
modifier = Modifier
.weight(1f)
.fillMaxWidth(),
colors = SliderDefaults.colors(
thumbColor = Color.White,
activeTrackColor = Color.White,
inactiveTrackColor = Color.Gray
)
)
}
Box(modifier = Modifier.height(24.dp)) {
Text(
text = currentTimeText,
fontSize = 14.sp,
color = Color.White,
modifier = Modifier
.align(Alignment.Center)
.alpha(if (isDragging) 1f else 0f)
)
}
}
}
< /code>
Проблема состоит в том, что: < /p>
Панель прогресса выглядит действительно странно, в отличие от той, которая на Spotify. < /li>
Прогресс на перетаске может отображаться только после того, как я закончил перетаскивать и показать на коробке в самом конце, когда я хочу, чтобы его было в состоянии изменить значение. /> Есть идеи, как это исправить? src = "https://i.sstatic.net/1mncd73l.png"/>
плюс продолжительность прогресса при перетаскивании также изменяется на левой стороне слайдера.
Подробнее здесь: https://stackoverflow.com/questions/795 ... -in-kotlin
Прогресс слайдера не работает в реальном времени в Котлине [закрыто] ⇐ Android
Форум для тех, кто программирует под Android
1744644713
Anonymous
Я использую Kotlin для разработки приложения, подобного Spotify. В приведенном ниже фрагменте кода он генерировал индикацию прогресса, когда я прокручивал (например, в какой момент я прокрутил). < /P>
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.material3.Slider
import androidx.compose.material3.SliderDefaults
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.alpha
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import kotlin.math.roundToInt
@Composable
fun SeekSlider(
progress: Float,
durationMillis: Int,
onSeekFinished: (Float) -> Unit,
modifier: Modifier = Modifier
) {
var sliderPosition by remember { mutableStateOf(progress) }
var isDragging by remember { mutableStateOf(false) }
LaunchedEffect(progress) {
if (!isDragging) {
sliderPosition = progress
}
}
val currentSeconds = ((sliderPosition * durationMillis) / 1000).roundToInt()
fun formatTime(seconds: Int): String {
val m = seconds / 60
val s = seconds % 60
return "%d:%02d".format(m, s)
}
val currentTimeText = formatTime(currentSeconds)
Column(
modifier = modifier.fillMaxWidth(),
horizontalAlignment = Alignment.CenterHorizontally
) {
Row(
modifier = Modifier.fillMaxWidth(),
verticalAlignment = Alignment.CenterVertically
) {
Slider(
value = sliderPosition,
onValueChange = { newValue ->
sliderPosition = newValue
isDragging = true
},
onValueChangeFinished = {
isDragging = false
onSeekFinished(sliderPosition)
},
modifier = Modifier
.weight(1f)
.fillMaxWidth(),
colors = SliderDefaults.colors(
thumbColor = Color.White,
activeTrackColor = Color.White,
inactiveTrackColor = Color.Gray
)
)
}
Box(modifier = Modifier.height(24.dp)) {
Text(
text = currentTimeText,
fontSize = 14.sp,
color = Color.White,
modifier = Modifier
.align(Alignment.Center)
.alpha(if (isDragging) 1f else 0f)
)
}
}
}
< /code>
Проблема состоит в том, что: < /p>
Панель прогресса выглядит действительно странно, в отличие от той, которая на Spotify. < /li>
Прогресс на перетаске может отображаться только после того, как я закончил перетаскивать и показать на коробке в самом конце, когда я хочу, чтобы его было в состоянии изменить значение. /> Есть идеи, как это исправить? src = "https://i.sstatic.net/1mncd73l.png"/>
плюс продолжительность прогресса при перетаскивании также изменяется на левой стороне слайдера.
Подробнее здесь: [url]https://stackoverflow.com/questions/79568435/slider-progress-not-working-realtime-in-kotlin[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия