鸿蒙UI系统组件05——切换按钮(Toggle)

如果你也对鸿蒙开发感兴趣,加入“Harmony自习室”吧!扫描下面名片,关注公众号。

1、概述

Toggle组件提供状态按钮样式,勾选框样式及开关样式,一般用于两种状态之间的切换。

2、创建切换按钮

Toggle通过调用接口来创建,接口调用形式如下:

Toggle(options: { type: ToggleType, isOn?: boolean })

该接口用于创建切换按钮,其中ToggleType为开关类型,包括Button、Checkbox和Switch,isOn为切换按钮的状态,接口调用有以下两种形式:

  • 创建不包含子组件的Toggle。

    当ToggleType为Checkbox或者Switch时,用于创建不包含子组件的Toggle:

Toggle({ type: ToggleType.Checkbox, isOn: false })Toggle({ type: ToggleType.Checkbox, isOn: true })

图片

Toggle({ type: ToggleType.Switch, isOn: false })Toggle({ type: ToggleType.Switch, isOn: true })

图片

  • 创建包含子组件的Toggle。

当ToggleType为Button时,只能包含一个子组件,如果子组件有文本设置,则相应的文本内容会显示在按钮内部。

Toggle({ type: ToggleType.Button, isOn: false }) {  Text('status button')  .fontColor('#182431')  .fontSize(12)}.width(100)Toggle({ type: ToggleType.Button, isOn: true }) {  Text('status button')  .fontColor('#182431')  .fontSize(12)}.width(100)

图片

3、自定义样式

  • 通过selectedColor属性设置Toggle打开选中后的背景颜色。

Toggle({ type: ToggleType.Button, isOn: true }) {  Text('status button')  .fontColor('#182431')  .fontSize(12)}.width(100).selectedColor(Color.Pink)Toggle({ type: ToggleType.Checkbox, isOn: true })  .selectedColor(Color.Pink)Toggle({ type: ToggleType.Switch, isOn: true })  .selectedColor(Color.Pink)

图片

  • 通过switchPointColor属性设置Switch类型的圆形滑块颜色,仅对type为ToggleType.Switch生效

Toggle({ type: ToggleType.Switch, isOn: false })  .switchPointColor(Color.Pink)Toggle({ type: ToggleType.Switch, isOn: true })  .switchPointColor(Color.Pink)

图片

4、添加事件

除支持通用事件外,Toggle通常用于选中和取消选中后触发某些操作,可以绑定onChange事件来响应操作后的自定义行为。

Toggle({ type: ToggleType.Switch, isOn: false })  .onChange((isOn: boolean) => {      if(isOn) {        // 需要执行的操作      }  })

5、demo

Toggle可用于切换蓝牙开关状态。

图片

// xxx.etsimport promptAction from '@ohos.promptAction';@Entry@Componentstruct ToggleExample {  build() {    Column() {      Row() {        Text("Bluetooth Mode")        .height(50)        .fontSize(16)      }      Row() {        Text("Bluetooth")          .height(50)          .padding({left: 10})          .fontSize(16)          .textAlign(TextAlign.Start)          .backgroundColor(0xFFFFFF)        Toggle({ type: ToggleType.Switch })          .margin({left: 200, right: 10})          .onChange((isOn: boolean) => {            if(isOn) {              promptAction.showToast({ message: 'Bluetooth is on.' })            } else {              promptAction.showToast({ message: 'Bluetooth is off.' })            }          })      }      .backgroundColor(0xFFFFFF)    }    .padding(10)    .backgroundColor(0xDCDCDC)    .width('100%')    .height('100%')  }}

### HarmonyOS 中设置功能的增加与删除 在 HarmonyOS 开发环境中,通过 DevEco Studio 提供的强大工具链可以轻松实现应用中的设置功能管理。以下是关于如何在 HarmonyOS 应用中实现设置项的增删操作的具体方法。 #### 1. 添加设置功能 为了向 HarmonyOS 应用添加新的设置选项,开发者可以通过 XML 文件定义 UI 结构并结合 Java 或 JavaScript 编写逻辑代码来完成配置。以下是一个简单的示例: ```xml <!-- settings_page.xml --> <DirectionalLayout xmlns:ohos="http://schemas.huawei.com/res/ohos" ohos:height="match_parent" ohos:width="match_parent" ohos:orientation="vertical"> <!-- 新增开关按钮 --> <Switch ohos:id="$+id:switch_feature_toggle" ohos:height="match_content" ohos:width="match_content" ohos:text_off="Off" ohos:text_on="On"/> </DirectionalLayout> ``` 上述代码片段展示了如何创建一个用于控制特定功能启停的开关控件[^1]。 接着,在对应的 AbilitySlice 类中绑定事件处理程序以响应用户的交互行为: ```java // SettingsAbilitySlice.java @Override public void onStart(Intent intent) { super.onStart(intent); Switch switchFeatureToggle = (Switch) findComponentById(ResourceTable.Id_switch_feature_toggle); // 绑定状态改变监听器 switchFeatureToggle.setChangedListener((component, value) -> { if (value) { enableFeature(); // 启用某功能 } else { disableFeature(); // 禁用某功能 } }); } private void enableFeature() { Log.info(TAG, "Enabling feature..."); // 执行启用逻辑... } private void disableFeature() { Log.info(TAG, "Disabling feature..."); // 执行禁用逻辑... } ``` 此部分实现了当用户切换开关时触发对应的功能开启或关闭动作[^3]。 #### 2. 删除设置功能 如果需要移除某个已有的设置条目,则只需修改布局文件 `settings_page.xml` 并重新编译项目即可。例如,要完全去除上面提到的那个开关组件,仅需将其从 XML 定义中剔除掉: ```diff - <!-- New Feature Toggle Button Removed Here --> - <Switch ... /> ``` 对于动态调整的情况(即运行期间决定隐藏某些选项),则可以在初始化界面之前调用相关 API 来隐藏不需要显示的部分。比如利用 `setVisibility(Component.HIDE)` 方法让指定部件不可见。 另外值得注意的是,假如涉及到更复杂的业务需求——像注销账户这样的敏感操作,还需要额外考虑权限验证以及数据清理等问题[^4]。 --- ### 总结 综上所述,无论是新增还是移除 HarmonyOS 应用内的设置模块都相对直观简便。主要依赖于清晰的设计思路配合灵活运用框架所提供的各类资源便可达成目标。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值