0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是CircleIndicator?CircleIndicator的源码实现

OpenAtom OpenHarmony 来源:OpenAtom OpenHarmony 作者:OpenAtom OpenHarmony 2022-07-22 11:01 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

UI界面是应用程序可视化必不可少的部分。设计精致的UI界面可以使得整个可视化应用程序给用户留下深刻的印象,是改善用户界面体验最直接的方式。

ArkUI开发框架为开发者提供了丰富的UI原生组件,如Navigation(Page页面的根容器)、ScrollBar(滚动条组件)、Swiper(滑动容器)及Tabs(通过页签进行内容视图切换的容器组件)等。其中,Swiper组件和Tabs组件在应用程序开发中对于指示器的使用引入较多,但是直接使用原生的Swiper组件和Tabs组件不适用于表现复杂的UI指示器交互变化。因此,我们针对Swiper组件和Tabs组件在指示器应用方向做了一个简单的封装,以CiecleIndicator三方组件的形式提供应用程序依赖使用,从而提升了ArkUI开发框架的UI界面之指示器风格多样化的能力。

CircleIndicator介绍

CircleIndicator组件UI效果展示

圆形指示器:

43bfd5b6-08f6-11ed-ba43-dac502259ad0.gif

长条指示器:

43d86de2-08f6-11ed-ba43-dac502259ad0.gif

横幅指示器:

440b5036-08f6-11ed-ba43-dac502259ad0.gif

三角指示器:

4442946a-08f6-11ed-ba43-dac502259ad0.gif

图标指示器:

4453fbba-08f6-11ed-ba43-dac502259ad0.gif

携带中央视图的Tabs指示器:

446f79a8-08f6-11ed-ba43-dac502259ad0.gif

固定位置Tabs指示器:

44951fe6-08f6-11ed-ba43-dac502259ad0.gif

固定位置Tabs指示器(胶囊风格):

44b9837c-08f6-11ed-ba43-dac502259ad0.gif

固定位置Tabs指示器(携带角标):

44e57ac2-08f6-11ed-ba43-dac502259ad0.gif

可滑动Tabs指示器:

4502913e-08f6-11ed-ba43-dac502259ad0.gif

可滑动Tabs指示器(水滴滑块):

453a41ec-08f6-11ed-ba43-dac502259ad0.gif

可滑动Tabs指示器(首列固定):

4559933a-08f6-11ed-ba43-dac502259ad0.gif

titles指示器:

4589f840-08f6-11ed-ba43-dac502259ad0.gif

什么是CircleIndicator?

CircleIndicator顾名思义,它指的是圆形指示器。不过在我们OpenHarmony三方组件中的CircleIndicator组件不再是狭义的圆形指示器,而是将多种表现形式的指示器汇集为一体的归一化指示器合集组件。

CircleIndicator的源码实现

这里我们以CircleIndicator组件源码中的TriangularIndicator.ets文件为源码解析样例对象展开分析。首先创建TriangularIndicator.ets文件,使用命名空间建立TriangularIndicator初始化模型:
 
namespace TriangularIndicator {  export class Model {//设置指示器高度    mHeight: number = 18//设置指示器宽度    mWidth: number = lpx2px(720)//设置指示器背景色    mBackgroundColor: string//字段过多,此处进行省略//各字段set与get方法,此处只以height字段为例    public getHeight(): number {      return this.mHeight    }    public setHeight(height: number): Model {      this.mHeight = height      return this    }    //触摸事件拦截    onPageTouch: (event: TouchEvent, currentIndicator: number) => void    public notifyTouch(event: TouchEvent, currentIndex: number) {      this.onPageTouch(event, currentIndex)    }    //设置构造器    private tabsController: TabsController        (tabsController: TabsController) {      this.tabsController = tabsController    }    //页面切换监听    indexChange: (itemIndex: number) => void    public setChangeListener(callback: (index: number) => void): Model{      this.indexChange = callback      return this    }}

将TriangularIndicator应用组件化:
@Componentstruct TriangularIndicator {//获取TriangularIndicator实例  @State model: TriangularIndicator.Model = new TriangularIndicator.Model(null)//初始化指示器当前index  @Link @Watch("itemIndexChange") itemIndex: number//设置指示器总条数  @State count: number = 0//再分别实现itemIndexChange、aboutToAppear、onTouch、getOffset方法,此处实现不做展示//再在build方法里面描述UI结构    build() {      Column() {        Rect({ width: this.model.mWidth, height:     this.model.mLineHeight }).fill(this.model.mLineColor)        Polygon()          .points(this.model.mReverse ?        [[px2vp(this.model.mWidth) / (this.count * 2) - this.model.mTriangleWidth / 2, this.model.mLineHeight - this.model.mYOffset],        [px2vp(this.model.mWidth) / (this.count * 2), this.model.mLineHeight + this.model.mTriangleHeight - this.model.mYOffset],        [px2vp(this.model.mWidth) / (this.count * 2) + this.model.mTriangleWidth / 2, this.model.mLineHeight - this.model.mYOffset]] :        [[px2vp(this.model.mWidth) / (this.count * 2) - this.model.mTriangleWidth / 2, -this.model.mYOffset],  [px2vp(this.model.mWidth) / (this.count * 2), -this.model.mTriangleHeight - this.model.mYOffset],        [px2vp(this.model.mWidth) / (this.count * 2) + this.model.mTriangleWidth / 2, -this.model.mYOffset]])          .offset(this.model.mStartInterpolator ?            { x: px2vp(this.model.mWidth) / this.count * (this.itemIndex -     this.model.mStartInterpolator.interpolate(Math.abs(this.model.offs    et / this.model.mWidth)) * Math.sign(this.model.offset)),              y: 0 } :            { x: px2vp(this.model.mWidth) / this.count * (this.itemIndex - this.model.offset / this.model.mWidth),              y: 0 })          .fill(this.model.mLineColor)          .height(this.model.mHeight)          .width(this.model.mWidth)      }.width('100%').height(this.model.mHeight)      .backgroundColor(this.model.mBackgroundColor)    }}
最后将TriangularIndicator暴露出来供外部引用:
export default TriangularIndicator

CircleIndicator实战

创建项目

如图所示,在DevEco Studio中新建CircleIndicator_Test项目,项目类型选择Application,语言选择eTS,点击Finish完成创建。

459baf4a-08f6-11ed-ba43-dac502259ad0.png

创建工程

添加依赖

成功创建项目后,接下来就是将CircleIndicator组件下载至项目中。请在添加依赖之前参考如何安装OpenHarmony npm包(https://gitee.com/openharmony-tpc/docs/blob/master/OpenHarmony_npm_usage.md)完成OpenHarmony npm环境配置。完成OpenHarmony npm环境配置之后,在DevEco Studio的底部导航栏,点击“Terminal”(快捷键Alt+F12), 键入命令:npm install @ohos/circle-indicator --save并回车,此时CircleIndicator组件会自动下载至项目中。下载完成后工程根目录下会生成node_modules/@ohos/CircleIndicator目录。

编写逻辑代码

提供多种Indicator,使用方法类似,以TriangularIndicator为例

1.初始化:实例化TabsController和对应的Indicator.Model 对象, 并添加number类型成员以记录当前页下标


private controller: TabsController = new TabsController()@State model: TriangularIndicator.Model = new TriangularIndicator.Model(this.controller)@StateitemIndex:number=0
2.属性设置:通过Model类对象设置UI属性来自定义所需风格,也可以添加所需的回调
aboutToAppear() {  this.model    .setReverse(true)    .setLineHeight(4)    .setTriangleHeight(10)    .setLineColor("#e94220")    .setBackgroundColor("#eeeeee")    .setChangeListener((itemIndex) => {      console.info("change page to " + this.data[itemIndex])    })}
3.界面绘制:在Tabs组件旁放置Indicator组件,注意需要关闭原生的bar。并监听Tabs组件的touch事件,通知给Model类,以统一处理滑动逻辑
build() {  Column() {    TriangularIndicator({ itemIndex: $itemIndex, count: this.data.length, model: this.model })    Tabs({ index: this.itemIndex, controller: this.controller }) {      ……    }    .barWidth(0)    .onTouch((event: TouchEvent) => {      this.model.notifyTouch(event, this.itemIndex)    })  }.padding({ top: 40 })  .backgroundColor("#eeeeee")}
本期基于OpenHarmony API8的CircleIndicator组件1.0.3(https://gitee.com/openharmony-sig/CircleIndicator/tree/1.0.3)就为大家介绍到这,欢迎大家积极参与贡献。了解更多三方组件动态,请关注三方组件资源汇总(https://gitee.com/openharmony-tpc/tpc_resource),更多优秀的组件等你来发现!
审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 源码
    +关注

    关注

    8

    文章

    689

    浏览量

    31458
  • 应用程序
    +关注

    关注

    38

    文章

    3346

    浏览量

    60412

原文标题:CircleIndicator组件,使指示器风格更加多样化

文章出处:【微信号:gh_e4f28cfa3159,微信公众号:OpenAtom OpenHarmony】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    WebRTC源码级深度解析(完结) (讠果xingkeit-top)#WebRTC #源码

    源码
    jf_82580774
    发布于 :2026年03月30日 15:22:21

    SaaS云门诊系统源码,诊所his系统源码

    一套成熟的SaaS云门诊系统源码,采用B/S架构,基于SpringBoot+Vue.js技术栈开发。 云门诊系统支持医保结算,包含预约挂号、医生工作站、收费管理、药房发药、库存管理、会员管理等核心
    的头像 发表于 11-19 15:51 565次阅读
    SaaS云门诊系统<b class='flag-5'>源码</b>,诊所his系统<b class='flag-5'>源码</b>

    一款基于Java+Spring Boot+Vue的智慧随访管理系统源码

    智慧随访管理系统源码,一款基于Java+Spring Boot+Vue的B/S架构医院随访管理系统源码,采用前后端分离技术(Ant-Design+MySQL5),具有自主版权和落地案例。 随访管理
    的头像 发表于 11-13 15:38 500次阅读
    一款基于Java+Spring Boot+Vue的智慧随访管理系统<b class='flag-5'>源码</b>

    医院随访管理系统源码,三级随访系统源码,Java+Springboot,Vue,Ant-Design+MySQL5

    Java版随访系统源码,医院随访管理系统源码,三级随访系统源码,B/S前后端分离架构,自主版权,落地案例。 技术框架:Java+Springboot,Vue,Ant-Design+MySQL5 开发
    的头像 发表于 11-08 14:48 717次阅读
    医院随访管理系统<b class='flag-5'>源码</b>,三级随访系统<b class='flag-5'>源码</b>,Java+Springboot,Vue,Ant-Design+MySQL5

    E203工程源码时钟树解析

    的system.v文件以及引脚约束文件,和rtl文件夹内的源码,我们参考源码绘制了E203在MCU200T的时钟树,方便我们团队对E203源码的时钟进行修改,分享如下:
    发表于 10-29 07:25

    BEKEN BK7252芯片源码编译不过是什么原因?

    在编译麻雀一号开发板的源码里,提示如下错误,请大家帮忙看看什么原因,谢谢 这是源码: 这个错误源码的地方,但没有看到哪里错了 这个是用menuconfig,也不能显示菜单。
    发表于 10-13 07:52

    智能小车设计源码和图纸资料

    智能小车设计源码和图纸
    发表于 08-25 15:38 1次下载

    揭秘Air780EGH定位功能:源码开放助力极速开发 !

    例,带你快速上手定位功能的基本使用方法,可根据实际需求灵活扩展和应用。   一、Air780EGH定位示例源码开放 Air780EGH示例持续更新中,本文将讲解Air780EGH核心板实现定位功能
    的头像 发表于 07-29 16:11 839次阅读
    揭秘Air780EGH定位功能:<b class='flag-5'>源码</b>开放助力极速开发 !

    RTsmart源码编译错误,提醒我缺少文件导致make失败,为什么?

    最近重新拉取Gitee的源码,根据官网文档来操作的 选择的硬件配置是k230_rtos_01studio_defconfig 一直到执行make,都是和以前一样可以实现的,但是在配置了
    发表于 06-20 06:25

    单片机常用算法源码下载!

    单片机常用算法源码下载!
    发表于 06-10 20:44

    【经验分享】在Omni3576上编译Redis-8.0.2源码,并安装及性能测试

    本文首先介绍Redis是什么,然后介绍如何在Omni3576上编译Redis-8.0.2源码,以及从源码编译、安装Redis,最后介绍如何在Omni3576上运行Redis性能测试,并与树莓派5上的结果进行对比。一、Redis是什么维基百科的介绍是:Redi
    的头像 发表于 06-05 08:05 1078次阅读
    【经验分享】在Omni3576上编译Redis-8.0.2<b class='flag-5'>源码</b>,并安装及性能测试

    基于stm32 nucleo_L476的智能灯(操作说明+源码

    基于stm32 nucleo_L476的智能灯(操作说明+源码)推荐下载!
    发表于 05-28 21:29

    【每周推荐】基于STM32开发项目实例下载(含PCB、原理图、源码等)

    1、手机APP远程控制,智能家居监测、智能控制系统(含源码)手机APP远程控制,智能家居监测、智能控制系统(STM32L4、服务器、安卓源码)项目实例下载!2、基于STM32蓝牙控制小车系统
    的头像 发表于 05-27 08:05 1448次阅读
    【每周推荐】基于STM32开发项目实例下载(含PCB、原理图、<b class='flag-5'>源码</b>等)

    每周推荐!基于STM32开发项目实例下载(含PCB、原理图、源码等)

    1、手机APP远程控制,智能家居监测、智能控制系统(含源码) 手机APP远程控制,智能家居监测、智能控制系统(STM32L4、服务器、安卓源码) 项目实例下载! 2、基于STM32蓝牙控制小车系统
    发表于 05-26 14:01

    云MES系统源码,支持 SaaS 多租户,支持二次开发

    万界星空科技MES生产制造执行系统源码,有演示,多个项目应用案例,成熟稳定。支持二次开发,商业授权后可商用。
    的头像 发表于 05-07 11:14 920次阅读
    云MES系统<b class='flag-5'>源码</b>,支持 SaaS 多租户,支持二次开发