鸿蒙开发(13)---ProgressBar与RoundProgressBar组件

简介: 鸿蒙开发(13)---ProgressBar与RoundProgressBar组件

ProgressBar组件


从名字我们就可以看出来,这是一个加载进度条。但是你不要小看这款进度条,Android的进度条非常不容易自定义。


鸿蒙的进度条可以玩出各种花样。今天,我们就来看看如何在鸿蒙手机上实现各式各样的进度条。


基本实现

首先,还是使用XML布局文件,展示一下ProgressBar组件的默认样子。示例代码如下所示:

<ProgressBar
    ohos:id="$+id:test_progressbar"
    ohos:height="150vp"
    ohos:width="match_parent"
    ohos:margin="20vp"
    ohos:max="100"
    ohos:min="0"
    ohos:progress="60"
    ohos:orientation="horizontal"
    ohos:background_instruct_element="#FF0000"
    ohos:progress_color="#555555"
    ohos:divider_lines_enabled="true"
    ohos:divider_lines_number="5"/>


运行之后,效果如下:

上面有一些前面没有见过的属性,这里有必要列出一个表格说明一下:

属性 含义
max 进度条最大值
min 进度条最小值
progress 进度条当前进度值
orientation 进度条是垂直还是水平
background_instruct_element 进度条没有加载部分的颜色
progress_color 进度条加载部分的颜色
divider_lines_enabled 进度条是否有分割线
divider_lines_number 进度条divider_lines_enabled为True之后,通过它设置几个分割段


代码实现样式操作

这里分割段落的颜色无法通过XML布局文件进行定义,因为鸿蒙没有给我们这个属性。但它提供了分割线Java方法进行设置。


示例如下:

public class MainAbilitySlice extends AbilitySlice{
    HiLogLabel label=new HiLogLabel(HiLog.LOG_APP, 0x00201, "TAG");
    private ProgressBar progressBar;
    @Override
    public void onStart(Intent intent) {
        super.onStart(intent);
        super.setUIContent(ResourceTable.Layout_ability_main);
        this.progressBar=(ProgressBar)findComponentById(ResourceTable.Id_test_progressbar);
        this.progressBar.setDividerLineColor(Color.MAGENTA);//这段代码
    }
}


这里设置分割段的颜色为红色。下图就是,读者可以对比一下上面分割段的效果(上面默认灰色,这里设置为洋红)。



显示加载的数值

当然,我们在实际的项目中,往往给用户更加直观的进度视觉体验,也就是将值以百分比的形式显示出来给用户。


一般来说,加载的数值代码是通过Java代码进行操作。毕竟一般使用进度条的都是一些网络耗时任务。XML布局文件一次性设置肯定不合适。


但是XML布局文件可以通过progress_hint_text属性进行设置。这里,我们只讲解项目中用到的Java设置方式。示例如下:

this.progressBar.setProgressHintText("60%");
this.progressBar.setProgressHintTextColor(Color.RED);
this.progressBar.setProgressHintTextSize(60);


这里一共就3行代码,从方法名应该很容易看出来,一个设置加载进度多少,一个设置加载进度的文字颜色,一个设置加载进度文字的字体大小。



RoundProgressBar组件


从名字上看这个组件也是一个进度条,不过前面加了一个Round,那么说明这是一个圆形的进度条。


属性基本差不多,我们直接用XML布局创建出来,看看样式即可。至于Java代码与ProgressBar组件使用规则基本一致。

<RoundProgressBar
     ohos:id="$+id:test_progressbar"
     ohos:height="300vp"
     ohos:width="300vp"
     ohos:margin="20vp"
     ohos:progress="60"
     ohos:start_angle="30"
     ohos:max_angle="270"/>


运行之后,效果如下:



这里,我们通过start_angle与max_angle实现了非闭合进度条,删除这段代码就是一个正规的圆形进度条。不过这么设置,就是从30度开始,270度结束,整整240是100%。

相关文章
|
2天前
|
UED 开发者
鸿蒙next版开发:ArkTS组件通用属性(运动模糊)
在HarmonyOS 5.0中,ArkTS引入了运动模糊功能,允许开发者为组件添加动态模糊效果,增强视觉表现。本文详细解读了运动模糊的属性和使用方法,并提供了示例代码。运动模糊可增强视觉效果、提升用户体验和实现动态效果,适用于多种场景。
78 2
|
2天前
|
开发者 UED 容器
鸿蒙next版开发:ArkTS组件通用属性(图像效果)
在HarmonyOS 5.0中,ArkTS提供了丰富的图像效果属性,如阴影、灰度、高光、饱和度、对比度、图像反转、叠色、色相旋转等,极大丰富了用户界面的表现力。本文详细介绍这些属性并提供示例代码。
57 2
|
2天前
|
UED
鸿蒙next版开发:ArkTS组件通用属性(前景色设置)
在HarmonyOS 5.0中,ArkTS提供了丰富的组件样式设置能力,包括前景色设置。本文详细解读了ArkTS中前景色设置的通用属性,并通过示例代码展示了如何使用foregroundColor属性设置组件的前景色,从而提升界面美观性和用户体验。
59 1
|
2天前
|
JavaScript 开发者 索引
鸿蒙next版开发:ArkTS组件通用属性(复用标识)
在HarmonyOS 5.0中,ArkTS的复用标识(Reused Identifier)是关键机制,用于标识和引用组件,特别是在列表渲染和组件复用中。本文详细解读了复用标识的通用属性和作用,并提供了示例代码,帮助开发者提高应用性能和效率。
55 1
|
2天前
|
UED 开发者
鸿蒙next版开发:ArkTS组件通用属性(多态样式)
在HarmonyOS 5.0中,ArkTS的多态样式(stateStyles)功能允许开发者根据不同状态(如正常、按压、禁用、聚焦、选中等)为组件设置不同的样式,从而提供更丰富的用户体验。通过stateStyles属性,可以动态改变组件样式,提升用户交互的直观性和界面美观性。示例代码展示了如何为文本组件设置正常和按压状态的样式。
55 1
|
2天前
|
开发者
鸿蒙next版开发:ArkTS组件通用属性(组件标识)
在HarmonyOS 5.0中,ArkTS的组件标识(ID)为每个组件提供唯一标识符,方便开发者引用和操作组件。本文详细解读了id和key属性的使用方法,并提供了示例代码,展示了如何通过组件标识获取属性、发送事件及动态操作组件。
56 1
|
2天前
|
开发者 UED
鸿蒙next版开发:ArkTS组件通用属性(悬浮态效果)
在HarmonyOS 5.0中,ArkTS引入了悬浮态效果的控制属性,使开发者能为组件添加鼠标悬浮时的视觉反馈,增强用户体验。本文详解了hoverEffect属性及其常见效果(Auto、Scale、Highlight、None),并提供了示例代码,展示了如何为按钮设置悬浮效果。通过这些属性,开发者可以实现更生动和互动的界面。
57 1
HarmonyOS实战—组件的外边距和内边距
HarmonyOS实战—组件的外边距和内边距
273 0
HarmonyOS实战—组件的外边距和内边距
|
12天前
|
前端开发 API
鸿蒙开发:走进stateStyles多态样式
stateStyles为多态样式,可以依据组件的内部状态的不同,快速设置不同样式,比如背景颜色,颜色、大小等等常见的通用属性,此种行为,很类似于css中的伪类,但语法稍有不同
鸿蒙开发:走进stateStyles多态样式
|
2天前
|
API 开发者 UED
鸿蒙next版开发:ArkTS组件通用属性(焦点控制)
在HarmonyOS 5.0中,ArkTS提供了完善的焦点控制属性,如focusable、defaultFocus、onFocus和onBlur,帮助开发者管理和响应用户界面中的焦点变化。本文详细介绍这些属性,并通过示例代码展示如何使用FocusController类进行焦点管理,提升应用的交互性和无障碍支持。
56 1

热门文章

最新文章