IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 开发台组件转换——环形进度条 -> 正文阅读

[游戏开发]开发台组件转换——环形进度条

准备工作

  1. 同前章 :滑动选择器
  2. 在widget目录下增加CircularSeekBar.java文件
  3. 在res/values下,替换attrs.xml和style.xml文件

一、添加组件及基本属性配置

操作示例

开发台新建环形进度条,

此时开发台配置参数如下:

					{
                        "areaState": false,
                        "uuid": "WgjR5zwRp",
                        "isLock": false,
                        "style": {
                            "height": 150,
                            "strokeWidth": 10,
                            "width": 150,
                            "top": 0,
                            "left": 0,
                            "backgroundColor": "#EAEFF4",
                            "rotate": 0,
                            "pivotColor": "#20a0ff"
                        },
                        "control": {
                            "drawable": false,
                            "max_value": "100",
                            "min_value": "0",
                            "binding_data": "",
                            "percentage": 10,
                            "binding_max": "Diy"
                        },
                        "aspectRatio": true,
                        "events": {},
                        "component": "brick-circle",
                        "name": "",
                        "iconName": "wk-icon-widget-circle",
                        "title": "环形进度条",
                        "ID": 0
                    }

转换规则

xml文件:

需要在该对应页面的xml布局文件下增加该组件,代码如下:

    <com.kaida.myapplication.widget.myProgressSeekBar.CircularSeekBar
        android:id="@+id/widget_csb_wgjr5zwrp"
        android:layout_width="150dp"
        android:layout_height="150dp"
        android:layout_marginLeft="0dp"
        android:layout_marginTop="0dp"
        app:circle_stroke_width="15dp"
        app:progress="10"
        app:circle_progress_color="#20a0ff"
        app:circle_color="#EAEFF4"
        />

其中 id 根据配置文件中该滑动选择器组件的 uuid 命名

kt文件:

在该页面的fragment.kt中,onViewCreated方法内,with(binding){ }代码段内,增加如下代码:

            //环形进度条基本属性配置
            widgetCsbWgjr5zwrp.let {
                it.maxValue = 100    //自定义最大值  Diy
                //it.maxValue = vm.setTimeLiveData.value?:100     //绑定最大值 为 设定时间SetTime
                it.minValue = 0
                it.isTouchEnabled = false   //是否可拖动
//                it.isShowPointer = false    //是否显示拖动点
            }

转换规则下图所示,结合注释文字:
在这里插入图片描述

二、功能属性配置——用户可拖动为否

操作示例

如下,配置用户可拖动为否,绑定进度值为“当前温度”(WorkTemp)或“已工作时间”(WorkTime)时

在这里插入图片描述

此时配置属性如下:

                         "control": {
                            "drawable": false,
                            "max_value": "220",
                            "min_value": "0",
                            "binding_data": "WorkTemp",
                            "percentage": 10,
                            "binding_max": "Diy"
                        },

转换规则

xml文件:

同上不变

kt文件:

在该页面的fragment.kt中,onViewCreated方法内,with(binding){ }代码段内,增加如下代码:

            //监听数据变化,更新环形进度条
            vm.workTempLiveData.observe(this@MainFragment.viewLifecycleOwner){
                Log.d(TAG, "observed workTempLiveData changed to $it")
                widgetCsbWgjr5zwrp.progress = it + widgetCsbWgjr5zwrp.minValue  //实际值转进度值
            }

转换规则下图所示:
在这里插入图片描述

三、功能属性配置——用户可拖动为是

xml文件:

同上不变

kt文件:

在该页面的fragment.kt中,onViewCreated方法内,with(binding){ }代码段内,增加如下代码:

            //环形进度条进度变化监听
            widgetCsbWgjr5zwrp.run {
                setOnSeekBarChangeListener(
                        object : CircularSeekBar.OnCircularSeekBarChangeListener{
                            override fun onProgressChanged(
                                circularSeekBar: CircularSeekBar?,
                                progress: Int,
                                fromUser: Boolean
                            ) {
                                Log.d(TAG, "onProgressChanged, progress= $progress , " +
                                        "value= ${progress+(circularSeekBar?.minValue?:0)} , " +
                                        "fromUser= $fromUser")
                                if (fromUser) {
                                    vm.setTime(progress+(circularSeekBar?.minValue?:0))    //设定工作时间,进度值转实际值
                                }
                            }

                            override fun onStopTrackingTouch(seekBar: CircularSeekBar?) {}

                            override fun onStartTrackingTouch(seekBar: CircularSeekBar?) {}

                        }
                    )
            }

转换规则下图所示:
在这里插入图片描述

四、绑定最大值

操作示例

当(binding_max)不为 Diy时,如下是设置时间(SetTime),则不管max_value的值:

                        "control": {
                            "drawable": false,
                            "max_value": "100",
                            "min_value": "0",
                            "binding_data": "WorkTemp",
                            "percentage": 10,
                            "binding_max": "SetTime"
                        },

转换规则

kt文件:

            //环形进度条基本属性配置
            widgetCsbWgjr5zwrp.let {
//                it.maxValue = 100    //自定义最大值  Diy
                it.maxValue = vm.setTimeLiveData.value?:100     //绑定最大值 为 设定时间SetTime
                it.minValue = 0
                it.progress = 10
                it.isTouchEnabled = true   //是否可拖动
//                it.isShowPointer = false    //是否显示拖动点
            }

在这里插入图片描述

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-03-17 22:31:30  更:2022-03-17 22:31:43 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 16:46:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码