当前位置: 首页 > wzjs >正文

网站首页设计沈阳网站关键词优化公司

网站首页设计,沈阳网站关键词优化公司,flask做的网站,选择seo网站排名优化androidx.compose.material3 我用1.2.0版本的Slider非常好用,但是升级到1.3.2后滑轨后面多了个点,滑块背景也移除不掉而且默认透明了我暂时没有找到让他不透明。所以自定义了一个先用着。 Composable fun CustomSlider(state: CustomSliderState,modifi…

androidx.compose.material3 我用1.2.0版本的Slider非常好用,但是升级到1.3.2后滑轨后面多了个点,滑块背景也移除不掉而且默认透明了我暂时没有找到让他不透明。所以自定义了一个先用着。

@Composable
fun CustomSlider(state: CustomSliderState,modifier: Modifier = Modifier,trackHeight: Dp = 4.dp,thumbSize: Dp = 24.dp,trackColor: Color = Color.Gray,progressColor: Color = Color.Blue,thumbColor: Color = Color.White,onValueChange: ((Float) -> Unit)? = null,onValueChangeFinished: ((Float) -> Unit)? = null
) {var sliderWidth by remember { mutableFloatStateOf(0f) }Box(modifier = modifier.height(thumbSize + 16.dp) // 确保足够高度容纳滑块.pointerInput(Unit) {awaitEachGesture {val event = awaitPointerEvent(PointerEventPass.Initial)if (event.changes.firstOrNull()?.changedToDown() == true) {val down = awaitFirstDown(requireUnconsumed = true)state.setPressed(true)val newPosition = (event.changes.first().position.x / sliderWidth).coerceIn(0f, 1f)val newValue = state.range.start + newPosition * (state.range.endInclusive - state.range.start)state.updateValue(newValue)onValueChange?.invoke(state.value)var drag: PointerInputChange?do {drag = awaitTouchSlopOrCancellation(down.id) { change, _ ->if (change.positionChange() != Offset.Zero) change.consume()}} while (drag != null && !drag.isConsumed)if (drag != null) {val dragResult = drag(drag.id) {val newPosition = (it.position.x / sliderWidth).coerceIn(0f, 1f)val newValue = state.range.start + newPosition * (state.range.endInclusive - state.range.start)state.updateValue(newValue)onValueChange?.invoke(state.value)}// 确保完成回调被触发if (!dragResult || drag.isConsumed) {onValueChangeFinished?.invoke(state.value)}} else {onValueChangeFinished?.invoke(state.value)}}}},contentAlignment = Alignment.CenterStart) {// 绘制轨道(Track)Canvas(modifier = Modifier.fillMaxWidth().clip(CircleShape).height(trackHeight).align(Alignment.CenterStart).onSizeChanged { size ->sliderWidth = size.width.toFloat()}) {// 背景轨道drawRect(color = trackColor,size = Size(size.width.toFloat(), trackHeight.toPx()))// 进度轨道drawRect(color = progressColor,size = Size(width = (state.value - state.range.start) / (state.range.endInclusive - state.range.start) * size.width,height = trackHeight.toPx()))}// 滑块(Thumb)根据你自己需求替换Box(modifier = Modifier.offset {IntOffset(x = ((state.value - state.range.start) / (state.range.endInclusive - state.range.start) * sliderWidth - thumbSize.toPx()/2).toInt(),y = 0)}.shadow(4.dp, CircleShape).size(thumbSize).background(thumbColor, CircleShape))}
}class CustomSliderState(initialValue: Float,internal val range: ClosedFloatingPointRange<Float> = 0f..1f
) {private val _value = mutableFloatStateOf(initialValue.coerceIn(range))private val _isPressed = mutableStateOf(false) // 新增按下状态val value: Floatget() = _value.floatValueval isPressed: Boolean // 暴露给外部get() = _isPressed.valuefun updateValue(newValue: Float) {_value.floatValue = newValue.coerceIn(range)}fun setPressed(pressed: Boolean) { // 更新按下状态_isPressed.value = pressed}
}@Composable
fun rememberCustomSliderState(initialValue: Float = 0f,range: ClosedFloatingPointRange<Float> = 0f..1f
): CustomSliderState {return remember { CustomSliderState(initialValue, range) }
}

 使用

 val sliderState = rememberCustomSliderState(initialValue = 0.5f,range = 0f..100f)CustomSlider(state = sliderState,modifier = Modifier.fillMaxWidth().padding(horizontal = 36.dp),trackHeight = 12.dp,thumbSize = 24.dp,trackColor = Color.LightGray,progressColor = Color(0xFF6200EE),thumbColor = Color.White,onValueChange = {Log.e("onValueChange","float---$it")},onValueChangeFinished = {Log.e("onValueChangeFinished","float---$it")})

http://www.dtcms.com/wzjs/146910.html

相关文章:

  • 做360网站快速排名软件中山seo
  • 云南网站建设首选公司web网页制作成品免费
  • php如何做动态网站建设湖北网站seo设计
  • 如何从网站获取图片做全景图成都新站软件快速排名
  • 汕头免费建站公司北京网站建设公司报价
  • 深圳网站设计公司wx成都柚米科技15新的seo网站优化排名 排名
  • 太原网站制作电话淘宝seo对什么内容优化
  • 温州网络公司网站建设推广app的方法和策略
  • 嵊州建设局网站文员短期电脑培训
  • 北京网站设计公司新百度推广登录入口官网网址
  • 建网站盈利的几种方式快速提高关键词排名的软件
  • 长沙企业网站建立网络营销外包收费
  • 做期货应该看的网站太原今日头条
  • 通化网站推广武汉搜索引擎营销
  • 如何做 网站的seoseo网址
  • 旅游网站前端模板小程序模板
  • 做电子委托在那个网站java培训机构
  • 产品展示网站模板网站seo搜索
  • 做美女网站赚钱么上海最新疫情
  • 购物车功能网站怎么做的seo网络公司
  • 查询网站是否正规seo网站营销推广公司
  • 广西智能网站建设企业互联网广告行业分析
  • 人民日报政府网站建设seo视频教学网站
  • 网站dns解析失败软件开发公司推荐
  • 怎样自己做网站赚钱seo和sem哪个工资高
  • 做网站行业以网络营销为主题的论文
  • 无锡集团网站建设企业品牌策划
  • 政府网站内容建设规范无锡seo排名收费
  • 网站前台的功能模块sem网络推广公司
  • 做网站建设的上市公司有哪些深圳网站优化软件