最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    正文概述 掘金(程序员漫话编程)   2021-07-11   615

    上一篇原创文章 解析了 复选框 Chexkbox的功能和用法。也把这个功能用到了鸿蒙开发的知乎登录页面。

    各位尽快学习,后面更新会比较快了,现在是为了给新学习的一点事件来敢。

    好了,来说一下今天的重点......

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    下面我们开始今天的文章,还是老规矩,通过如下几点来说:

    简介

    Switch是一个可以在两种状态切换的开关控件。只有开关两种状态。

    一般引用在手机应用的设置界面 做一些开关操作,或者某一个功能的开关操作。

    用到的属性

    Switch的共有XML属性还是继承自:Text

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    属性中 有两个比较重要 :

    text_state_on // 开启显示的文本
    text_state_off //关闭显示的文本

    实战

    先来创建一个基本的开关试试把。
    1,开关默认效果

    <Switch
        ohos:id="$+id:switch_opt"
        ohos:height="match_content"
        ohos:width="match_content"
        ohos:text_state_off="关闭"
        ohos:text_state_on="开启"
        ohos:padding="5vp"
        ohos:text_size="16fp"
        />
    

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法1,默认效果 添加了 几个属性,开启和关闭文字,字体大小

    查看一下效果:

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    2,设置背景样式

    ShapeElement elementThumbOn = new ShapeElement();
    elementThumbOn.setShape(ShapeElement.OVAL);
    elementThumbOn.setRgbColor(RgbColor.fromArgbInt(0xFF1E90FF));
    elementThumbOn.setCornerRadius(50);
    

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法1,设置背景演示和圆角

    3,设置背景状态

    // 滑块样式的设置
    private StateElement trackElementInit(ShapeElement on, ShapeElement off){
        StateElement trackElement = new StateElement();
        trackElement.addState(new int[]{ComponentState.COMPONENT_STATE_CHECKED}, on);
        trackElement.addState(new int[]{ComponentState.COMPONENT_STATE_EMPTY}, off);
        return trackElement;
    }
    

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    1. 设置状态,状态是两种背景样式设置的切换

    完整代码:

    <?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:alignment="center"
        ohos:orientation="vertical">
    
        <Switch
            ohos:id="$+id:switch_opt"
            ohos:height="match_content"
            ohos:width="match_content"
            ohos:text_state_off="关闭"
            ohos:text_state_on="开启"
            ohos:padding="5vp"
            ohos:text_size="16fp"
            />
    
    </DirectionalLayout>
    

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    代码逻辑:

    package com.example.aswitch.slice;
    
    import com.example.aswitch.ResourceTable;
    import ohos.aafwk.ability.AbilitySlice;
    import ohos.aafwk.content.Intent;
    import ohos.agp.colors.RgbColor;
    import ohos.agp.components.ComponentState;
    import ohos.agp.components.Switch;
    import ohos.agp.components.element.ShapeElement;
    import ohos.agp.components.element.StateElement;
    
    public class MainAbilitySlice extends AbilitySlice {
        @Override
        public void onStart(Intent intent) {
            super.onStart(intent);
            super.setUIContent(ResourceTable.Layout_ability_main);
    
            // 开启状态下滑块的样式
            ShapeElement elementThumbOn = new ShapeElement();
            elementThumbOn.setShape(ShapeElement.OVAL);
            elementThumbOn.setRgbColor(RgbColor.fromArgbInt(0xFF1E90FF));
            elementThumbOn.setCornerRadius(50);
    
            // 关闭状态下滑块的样式
            ShapeElement elementThumbOff = new ShapeElement();
            elementThumbOff.setShape(ShapeElement.OVAL);
            elementThumbOff.setRgbColor(RgbColor.fromArgbInt(0xFFFFFFFF));
            elementThumbOff.setCornerRadius(50);
    
            // 开启状态下轨迹样式
            ShapeElement elementTrackOn = new ShapeElement();
            elementTrackOn.setShape(ShapeElement.RECTANGLE);
            elementTrackOn.setRgbColor(RgbColor.fromArgbInt(0xFF87CEFA));
            elementTrackOn.setCornerRadius(50);
    
            // 关闭状态下轨迹样式
            ShapeElement elementTrackOff = new ShapeElement();
            elementTrackOff.setShape(ShapeElement.RECTANGLE);
            elementTrackOff.setRgbColor(RgbColor.fromArgbInt(0xFF808080));
            elementTrackOff.setCornerRadius(50);
    
    
            // 设置切换属性
            Switch btnSwitch = (Switch) findComponentById(ResourceTable.Id_switch_opt);
            btnSwitch.setTrackElement(trackElementInit(elementTrackOn, elementTrackOff));
            btnSwitch.setThumbElement(thumbElementInit(elementThumbOn, elementThumbOff));
        }
    
        // 滑块样式的设置
        private StateElement trackElementInit(ShapeElement on, ShapeElement off){
            StateElement trackElement = new StateElement();
            trackElement.addState(new int[]{ComponentState.COMPONENT_STATE_CHECKED}, on);
            trackElement.addState(new int[]{ComponentState.COMPONENT_STATE_EMPTY}, off);
            return trackElement;
        }
        // 轨迹样式的设置
        private StateElement thumbElementInit(ShapeElement on, ShapeElement off) {
            StateElement thumbElement = new StateElement();
            thumbElement.addState(new int[]{ComponentState.COMPONENT_STATE_CHECKED}, on);
            thumbElement.addState(new int[]{ComponentState.COMPONENT_STATE_EMPTY}, off);
            return thumbElement;
        }
    
        @Override
        public void onActive() {
            super.onActive();
        }
    
        @Override
        public void onForeground(Intent intent) {
            super.onForeground(intent);
        }
    }
    

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    老规矩 代码不能少,要不然小伙伴该说我小气了。
    源码:
    Switch : gitee.com/codegrowth/…

    关注公众号【程序员漫话编程】,后台回复 ”鸿蒙“即可获得上千鸿蒙开源组件。

    觉得不错的小伙伴,记得帮我 点个赞和关注哟,笔芯笔芯~**

    有问题请留言或者私信,可以 微信搜索:程序员漫话编程,关注公众号获得更多免费学习资料。


    起源地下载网 » 鸿蒙应用开发 | 揭开神秘 开关(Switch)的功能与用法

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元