【鸿蒙 HarmonyOS】UI 组件 ( 多选按钮 | Checkbox 组件 )

简介: 【鸿蒙 HarmonyOS】UI 组件 ( 多选按钮 | Checkbox 组件 )

文章目录

一、布局文件中配置 Checkbox 组件

二、代码中配置 Checkbox 组件选中事件

三、完整代码示例

四、GitHub 地址





一、布局文件中配置 Checkbox 组件


Checkbox 组件就是多选按钮 ;


Checkbox 多选按钮之间不存在互斥关系 , 可以 同时选择 ;


如 : 给出 3 33 个 Checkbox 按钮 , 可以同时选中其中的 0 00 个 , 1 11 个 , 2 22 个 , 3 33 个 ;



布局文件配置 Checkbox :


<?xml version="1.0" encoding="utf-8"?>
<DirectionalLayout
    xmlns:ohos="http://schemas.huawei.com/res/ohos"
    ohos:height="match_parent"
    ohos:width="match_parent"
    ohos:orientation="vertical">
    <Checkbox
        ohos:id="$+id:checkbox0"
        ohos:height="match_content"
        ohos:width="match_content"
        ohos:text="多选按钮 0"
        ohos:text_size="100"/>
</DirectionalLayout>






二、代码中配置 Checkbox 组件选中事件


调用 Checkbox 对象的 setCheckedStateChangedListener 方法设置 选中 / 取消选中 的 AbsButton.CheckedStateChangedListener 监听器 , 当用户 选中 / 取消选中 时 , 会回调上述监听器的 onCheckedChanged 方法 , 其中第二个参数 boolean b , b 为 true 多选按钮选中 , false 取消选中 ;


代码示例 :


   

// 获取 XML 布局中的 Checkbox 多选按钮
        Checkbox checkbox0 = (Checkbox) findComponentById(ResourceTable.Id_checkbox0);
        checkbox0.setCheckedStateChangedListener(new AbsButton.CheckedStateChangedListener() {
            @Override
            public void onCheckedChanged(AbsButton absButton, boolean b) {
                // b 为 true 多选按钮选中 , false 取消选中
                if(b) {
                    text.setText("当前 多选按钮 0 选中状态 : 选中");
                }else{
                    text.setText("当前 多选按钮 0 选中状态 : 未选中");
                }
            }
        });






三、完整代码示例


布局文件代码示例 :


<?xml version="1.0" encoding="utf-8"?>
<DirectionalLayout
    xmlns:ohos="http://schemas.huawei.com/res/ohos"
    ohos:height="match_parent"
    ohos:width="match_parent"
    ohos:orientation="vertical">
    <Checkbox
        ohos:id="$+id:checkbox0"
        ohos:height="match_content"
        ohos:width="match_content"
        ohos:text="多选按钮 0"
        ohos:text_size="100"/>
    <Checkbox
        ohos:id="$+id:checkbox1"
        ohos:height="match_content"
        ohos:width="match_content"
        ohos:text="多选按钮 1"
        ohos:text_size="100"/>
    <Checkbox
        ohos:id="$+id:checkbox2"
        ohos:height="match_content"
        ohos:width="match_content"
        ohos:text="多选按钮 2"
        ohos:text_size="100"/>
    <Text
        ohos:id="$+id:text"
        ohos:height="match_content"
        ohos:width="match_content"
        ohos:layout_alignment="horizontal_center"
        ohos:text="当前 多选按钮 0 选中状态 : 未选中"
        ohos:text_size="50"
        ohos:text_color="#FF0000"/>
</DirectionalLayout>



Java 代码示例 :


package com.example.checkbox.slice;
import com.example.checkbox.ResourceTable;
import ohos.aafwk.ability.AbilitySlice;
import ohos.aafwk.content.Intent;
import ohos.agp.components.AbsButton;
import ohos.agp.components.Button;
import ohos.agp.components.Checkbox;
import ohos.agp.components.Text;
public class MainAbilitySlice extends AbilitySlice {
    @Override
    public void onStart(Intent intent) {
        super.onStart(intent);
        super.setUIContent(ResourceTable.Layout_ability_main);
        // 获取文本组件
        Text text = (Text) findComponentById(ResourceTable.Id_text);
        // 获取 XML 布局中的 Checkbox 多选按钮
        Checkbox checkbox0 = (Checkbox) findComponentById(ResourceTable.Id_checkbox0);
        checkbox0.setCheckedStateChangedListener(new AbsButton.CheckedStateChangedListener() {
            @Override
            public void onCheckedChanged(AbsButton absButton, boolean b) {
                // b 为 true 多选按钮选中 , false 取消选中
                if(b) {
                    text.setText("当前 多选按钮 0 选中状态 : 选中");
                }else{
                    text.setText("当前 多选按钮 0 选中状态 : 未选中");
                }
            }
        });
    }
    @Override
    public void onActive() {
        super.onActive();
    }
    @Override
    public void onForeground(Intent intent) {
        super.onForeground(intent);
    }
}



运行结果 :


image.png



image.png




四、GitHub 地址


GitHub 主应用 : https://github.com/han1202012/HarmonyHelloWorld


CheckBox 组件示例 Module : https://github.com/han1202012/HarmonyHelloWorld/tree/master/checkbox


目录
相关文章
|
7月前
|
存储 缓存 5G
鸿蒙 HarmonyOS NEXT端云一体化开发-云存储篇
本文介绍用户登录后获取昵称、头像的方法,包括通过云端API和AppStorage两种方式,并实现上传头像至云存储及更新用户信息。同时解决图片缓存问题,添加上传进度提示,支持自动登录判断,提升用户体验。
297 1
|
7月前
|
存储 负载均衡 数据库
鸿蒙 HarmonyOS NEXT端云一体化开发-云函数篇
本文介绍基于华为AGC的端云一体化开发流程,涵盖项目创建、云函数开通、应用配置及DevEco集成。重点讲解云函数的编写、部署、调用与传参,并涉及环境变量设置、负载均衡、重试机制与熔断策略等高阶特性,助力开发者高效构建稳定云端服务。
681 1
鸿蒙 HarmonyOS NEXT端云一体化开发-云函数篇
|
7月前
|
存储 JSON 数据建模
鸿蒙 HarmonyOS NEXT端云一体化开发-云数据库篇
云数据库采用存储区、对象类型、对象三级结构,支持灵活的数据建模与权限管理,可通过AGC平台或本地项目初始化,实现数据的增删改查及端侧高效调用。
347 1
|
7月前
|
存储 开发者 容器
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
本文介绍了ArkTS语言中的Class类、泛型、接口、模块化、自定义组件及状态管理等核心概念,并结合代码示例讲解了对象属性、构造方法、继承、静态成员、访问修饰符等内容,同时涵盖了路由管理、生命周期和Stage模型等应用开发关键知识点。
526 1
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
|
7月前
鸿蒙 HarmonyOS NEXT星河版APP应用开发-阶段三
本文介绍了UI开发中的样式复用与组件构建技术,涵盖@Extend、@Styles和@Builder的使用方法,并通过Swiper轮播、Scroll滚动、Tabs导航等常用组件实现典型界面效果,结合生肖抽卡、小米轮播、回顶按钮等案例,展示实际应用技巧。
191 1
HarmonyOS实战—组件的外边距和内边距
HarmonyOS实战—组件的外边距和内边距
586 1
HarmonyOS实战—组件的外边距和内边距
|
10月前
|
容器
HarmonyOS NEXT仓颉开发语言实战案例:外卖App
仓颉语言实战分享,教你如何用仓颉开发外卖App界面。内容包括页面布局、导航栏自定义、搜索框实现、列表模块构建等,附完整代码示例。轻松掌握Scroll、List等组件使用技巧,提升HarmonyOS应用开发能力。
|
9月前
|
安全 JavaScript API
鸿蒙开发核心要素
鸿蒙开发核心要素
|
6月前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
1105 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
6月前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
869 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡

热门文章

最新文章

下一篇
开通oss服务