📚往期推文全新看点(文中附带全新鸿蒙5.0全栈学习笔录)
🎯 鸿蒙(HarmonyOS)北向开发知识点记录~
🎯 鸿蒙(OpenHarmony)南向开发保姆级知识点汇总~
🎯 鸿蒙应用开发与鸿蒙系统开发哪个更有前景?
🎯 嵌入式开发适不适合做鸿蒙南向开发?看完这篇你就了解了~
🎯 对于大前端开发来说,转鸿蒙开发究竟是福还是祸?
🎯 鸿蒙岗位需求突增!移动端、PC端、IoT到底该怎么选?
🎯 记录一场鸿蒙开发岗位面试经历~
🎯 持续更新中……
简介
CircleIndicator是一款UI组件库,为Tabs/Swiper容器提供了多种自定义风格的指示器
效果展示:
圆形指示器:
长条指示器:
横幅指示器:
三角指示器:
图标指示器:
携带中央视图的Tabs指示器:
固定位置Tabs指示器:
固定位置Tabs指示器(胶囊风格):
固定位置Tabs指示器(携带角标):
可滑动Tabs指示器:
可滑动Tabs指示器(水滴滑块):
可滑动Tabs指示器(首列固定):
titles指示器:
下载安装
ohpm install @ohos/circleindicator
使用说明
提供多种Indicator,使用方法类似,以TriangularIndicator为例
- 初始化:实例化TabsController和对应的Model 对象, 并添加number类型成员以记录当前页下标
private controller: TabsController = new TabsController()
@State model: TriangularModel = new TriangularModel(this.controller)
@State itemIndex: number = 0
- 属性设置:通过Model类对象设置UI属性来自定义所需风格,也可以添加所需的回调
aboutToAppear() {
this.model
.setReverse(true)
.setLineHeight(4)
.setTriangleHeight(10)
.setLineColor("#e94220")
.setBackgroundColor("#eeeeee")
.setChangeListener((itemIndex: number) => {
console.info("change page to " + this.data[itemIndex])
})
}
- 界面绘制:在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")
}
更多详细用法请参考开源库sample页面的实现
接口说明
model: TriangularModel = new TriangularModel(this.controller) // (TriangularModel可替换为所需的Model类)
-
设置指示器宽度
model.setWidth(width: Length,context?:common.UIAbilityContext)
注意: 1.长宽等Length型属性暂不支持百分比写法 2.当前OpenHarmony 的UI计算对无单位的float.json资源和无单位的ets变量值处理逻辑不同,前者会当做px处理,后者则为vp,未避免歧义,当传入$r(‘app.float.[id]’)形式的参数时建议在定义资源处加上单位(px/vp/fp) -
设置指示器高度
model.setHeight(height: Length,context?:common.UIAbilityContext)
-
设置指示器背景色
setBackgroundColor(backgroundColor: ResourceColor)
-
触摸事件拦截
model.notifyTouch(event: TouchEvent, index: number)
-
设置页面切换监听
model.setChangeListener(callback: (index: number) => void)
约束与限制
在下述版本验证通过:
- DevEco Studio: NEXT Beta1-5.0.3.806, SDK: API12 Release(5.0.0.66)
HSP场景适配:
所有指示器的配置类中,使用到Length入参的接口, 后面新增了可选参数context, 在HSP场景下需要传入正确的context, 才能保证三方库后续正确获取Resource资源。
非HSP场景不影响原功能, context可以不传。
目录结构
|---- CircleIndicator
| |---- entry # 示例代码文件夹
| |---- library # CircleIndicator三方库核心文件夹
| |----src
| |----main
| |----ets
| |----components
| |----CircleIndicator.ets #指示器的核心实现
| |----utils #工具类,辅助UI的绘制
| |---- index.ets # 对外接口
| |---- README.md # 安装使用方法
| |---- README_zh.md # 安装使用方法