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

网站重构什么是核心关键词

网站重构,什么是核心关键词,网站设计杭州,网上项目外包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/397064.html

相关文章:

  • 用discuz做门户网站百度首页排名优化服务
  • 烟台网络科技有限公司seo关键词优化指南
  • 商标查询官方网站百度官网认证价格
  • 毕业设计做网站难吗百度导航最新版本下载安装
  • 开发网站需要学什么今日重大新闻
  • 做二手机网站百度广告太多
  • 佛山优化网站互联网推广引流公司
  • 秀山网站建设端午节手抄报获奖sem电子扫描显微镜
  • 京东联盟网站建设电脑版平台交易网
  • 做实验用哪些国外网站广点通
  • 关于WordPress的摘要爱站网seo查询
  • 网站怎么做图片滚动成都短视频代运营
  • 佛山建设网站制作百度快照查询入口
  • 建设银行网站怎么取消短信服务手机网站百度关键词排名查询
  • 网站建设制度都有哪些王通seo赚钱培训
  • 大数据营销系统软件广州seo快速排名
  • 房子已交房 建设局网站查不到世界十大网站排名
  • 源码建站之网站建设谷歌seo推广公司
  • 小企业网站建设的基础知识招工 最新招聘信息
  • wordpress 评论 邮件人教版优化设计电子书
  • 用asp.net做简易网站竞价服务托管公司
  • 温州瓯北做网站系统设置友情链接有什么作用
  • 天津公司做网站郑州百度seo
  • 珠海网站建设小程序国内十大搜索引擎网站
  • 要怎么判断网站是什么cms做的谷歌关键词搜索排名
  • 无锡地区做网站怎么样推广自己的网站
  • wordpress后台换地址长沙seo全网营销
  • ps做网站logo免费行情软件网站下载大全
  • 安庆 做网站搜索技巧
  • 行业网站建设方式有哪些河南整站百度快照优化