circleindicator组件,使指示器风格更加多样化

OpenHarmony开发者社区 OpenHarmony开发者社区     2022-11-29     240

关键词:

CircleIndicator组件,使指示器风格更加多样化​

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

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

CircleIndicator介绍​

CircleIndicator组件UI效果展示

圆形指示器:

CircleIndicator组件,使指示器风格更加多样化_字段

长条指示器:

CircleIndicator组件,使指示器风格更加多样化_git_02

横幅指示器:

CircleIndicator组件,使指示器风格更加多样化_字段_03

三角指示器:

CircleIndicator组件,使指示器风格更加多样化_git_04

图标指示器:

CircleIndicator组件,使指示器风格更加多样化_git_05

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

CircleIndicator组件,使指示器风格更加多样化_ui界面_06

固定位置Tabs指示器:

CircleIndicator组件,使指示器风格更加多样化_git_07

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

CircleIndicator组件,使指示器风格更加多样化_git_08

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

CircleIndicator组件,使指示器风格更加多样化_git_09

可滑动Tabs指示器:

CircleIndicator组件,使指示器风格更加多样化_字段_10

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

CircleIndicator组件,使指示器风格更加多样化_ui界面_11

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

CircleIndicator组件,使指示器风格更加多样化_字段_12

titles指示器:

CircleIndicator组件,使指示器风格更加多样化_git_13

什么是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应用组件化:

@Component
struct 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完成创建。

CircleIndicator组件,使指示器风格更加多样化_字段_14

创建工程

添加依赖

成功创建项目后,接下来就是将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)
@State itemIndex: 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),更多优秀的组件等你来发现!

css灵活的google风格进度指示器(代码片段)

查看详情

css灵活的google风格进度指示器(代码片段)

查看详情

css灵活的google风格进度指示器(代码片段)

查看详情

QListView 放置指示器样式

】QListView放置指示器样式【英文标题】:QListViewdropindicatorstyling【发布时间】:2012-07-0602:05:25【问题描述】:我正在使用QListView显示我可以拖放以更改其顺序的项目列表。问题是:下降指示器只是一条很小的线(1px粗)放置区域... 查看详情

restful风格数据获取(代码片段)

Restful就是一个资源定位及资源操作的风格。不是标准也不是协议,只是一种风格。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。 资源:互联网所有的事物都可以被抽象为资源资源操作:使用POST... 查看详情

css使用svg和css动画尝试chrome风格的进度指示器(代码片段)

查看详情

如何在Vuetify组件中将光标默认更改为指针

】如何在Vuetify组件中将光标默认更改为指针【英文标题】:HowtochangethecursordefaulttopointerinVuetifycomponent【发布时间】:2020-11-1112:19:46【问题描述】:我想在Vuetify中激活自动完成时将光标默认更改为指针。我试图制作css代码来更改... 查看详情

Material Design Components React 风格按钮

...6:36【问题描述】:我正在将我们的UI转换为使用材料设计组件(来自Bootstrap),并且遇到了各种小困难。Bootstrap使创建辅助按钮、对比文本/轮廓按钮等及其主题类变得非常容易。在使用材料设计组件时,我使用的是Butto 查看详情

如何在引导轮播下使缩略图可滚动?

...2005:36:44【问题描述】:我正在尝试将Bootstrap4.4carousel中的指示符从破折号更改为幻灯片下方的缩略图。我还希望能够单独滚动/滑动缩略图,以使用户能够浏览所有缩略图。我能够将指示符从破折号更改为缩略图。但是,我遇到... 查看详情

让对象的组件在足够远的地方禁用一次

】让对象的组件在足够远的地方禁用一次【英文标题】:HavingComponentsofObjectsDisableoncefarenoughaway【发布时间】:2021-10-0223:31:45【问题描述】:我正在制作一个无限街机风格的游戏,当玩家开始游戏时,球会在地图上随机生成,玩... 查看详情

为自定义活动指示器视图使 UIView 半透明

】为自定义活动指示器视图使UIView半透明【英文标题】:MakeUIViewtranslucentforcustomactivityindicatorview【发布时间】:2014-06-1006:06:30【问题描述】:我已经为我的iOS应用程序实现了一个自定义活动指示器视图,它运行流畅。要求是在自... 查看详情

具有三个组件的自定义 UIPickerView,每个组件在选择指示器上显示标签

】具有三个组件的自定义UIPickerView,每个组件在选择指示器上显示标签【英文标题】:CustomUIPickerViewwiththreeComponentseachshowinglabelonSelectionIndicator【发布时间】:2013-05-2412:05:49【问题描述】:在我的应用程序中,我正在尝试制作一... 查看详情

SwiftUI - 隐藏 ScrollView 的指示器使其停止滚动

】SwiftUI-隐藏ScrollView的指示器使其停止滚动【英文标题】:SwiftUI-HidingaScrollView\'sindicatorsmakesitstopscrolling【发布时间】:2019-11-3014:28:16【问题描述】:我试图隐藏ScrollView的指示符,但当我尝试这样做时,ScrollView不再滚动。如果这... 查看详情

情感风格不是压倒一切的组件

】情感风格不是压倒一切的组件【英文标题】:Emotionstylednotoveridingcomponent【发布时间】:2021-08-2502:27:52【问题描述】:我正在使用next.js和@emotion/styled创建一个网站。我有一个卡片组件如下。importReactfrom\'react\';importstyledfrom\'@emoti... 查看详情

使用jsx建立markup组件风格-前端组件化(代码片段)

这里我们一起从0开始搭建一个组件系统。首先通过上一篇《前端组件化基础知识》和《用JSX建立组件Parser(解析器)》中知道,一个组件可以通过Markup和JavaScript访问的一个环境。所以我们的第一步就是建立一个可以... 查看详情

如何使 WPF 应用程序在 Windows 经典风格和 Windows XP 风格中都一样?

】如何使WPF应用程序在Windows经典风格和WindowsXP风格中都一样?【英文标题】:HowtomakeaWPFapplicationthesameinbothWindowsclassicstyleandwindowsXPstyle?【发布时间】:2011-09-2503:39:22【问题描述】:我在WPF中编写了一个应用程序。我正在为我的应... 查看详情

unrealengine4编码风格的思考

第一次拿到UE4源码,扫了一遍。各种宏定义,各种模板,各种类层次。杂乱无章。后来慢慢明确其规律:UE4的编码风格是在匈牙利命名法的基础下做了改进,使其更适用游戏引擎业务(业务特点:数据可视编辑、脚本化)。U... 查看详情

如何设置qtquickcontrols2的风格

1QtQuickControls2的默认风格是一种朴素,轻量的风格,这种风格体现在控件的所有方面。其好处就是能够最大程度提高你的App性能2QtQuick还根据谷歌提出的MaterialDesign设计规则,提供了一套界面精美诱人的风格方案,相对默认风格来... 查看详情