梦见你的名字 发表于 2024-12-18 00:48:00

鸿蒙OpenHarmony【Scroll】ArkTS滚动与滑动

子组件

支持单个子组件。
接口

Scroll(scroller?: Scroller)
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析scroller否可滚动组件的控制器。用于与可滚动组件进行绑定。 属性

除支持[通用属性]和[滚动组件通用属性]外,还支持以下属性:
scrollable

scrollable(value: ScrollDirection)
设置滚动方向。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析value是滚动方向。默认值:ScrollDirection.Vertical scrollBar

scrollBar(barState: BarState)
设置滚动条状态。如果容器组件无法滚动,则滚动条不显示。如果容器组件的子组件大小为无穷大,则滚动条不支持拖动和伴随滚动。
从API version 10开始,当滚动组件存在圆角时,为克制滚动条被圆角截断,滚动条会自动盘算距顶部和底部的避让间隔。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析barState是滚动条状态。默认值:BarState.Auto scrollBarColor

scrollBarColor(color: Color | number | string)
设置滚动条的颜色。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析colornumberstring scrollBarWidth

scrollBarWidth(value: number | string)
设置滚动条的宽度,不支持百分比设置。宽度设置后,滚动条正常状态和按压状态宽度均为滚动条的宽度值。如果滚动条的宽度凌驾Scroll组件主轴方向的高度,则滚动条的宽度会变为默认值。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析valuenumberstring是 scrollSnap10+

scrollSnap(value: ScrollSnapOptions)
设置Scroll组件的限位滚动模式。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析value是Scroll组件的限位滚动模式。 edgeEffect

edgeEffect(edgeEffect: EdgeEffect, options?: EdgeEffectOptions)
设置边缘滑动效果。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析edgeEffect是Scroll组件的边缘滑动效果,支持弹簧效果和阴影效果。默认值:EdgeEffect.Noneoptions11+否组件内容大小小于组件自身时,是否开启滑动效果。设置为{ alwaysEnabled: true }会开启滑动效果,{ alwaysEnabled: false }不开启。默认值:{ alwaysEnabled: true } enableScrollInteraction10+

enableScrollInteraction(value: boolean)
设置是否支持滚动手势,当设置为false时,无法通过手指或者鼠标滚动,但不影响控制器的滚动接口。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析valueboolean是是否支持滚动手势。默认值:true nestedScroll10+

nestedScroll(value: NestedScrollOptions)
设置向前向后两个方向上的嵌套滚动模式,实现与父组件的滚动联动。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析value是嵌套滚动选项。默认值:{ scrollForward: NestedScrollMode.SELF_ONLY, scrollBackward: NestedScrollMode.SELF_ONLY } friction10+

friction(value: number | Resource)
设置摩擦系数,手动划动滚动区域时生效,只对惯性滚动过程有影响,对惯性滚动过程中的链式效果有间接影响。设置为小于等于0的值时,按默认值处置惩罚
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析valuenumber是 enablePaging11+

enablePaging(value: boolean)
设置是否支持划动翻页。如果同时设置了划动翻页enablePaging和限位滚动scrollSnap,则scrollSnap优先生效,enablePaging不生效。
元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析valueboolean是是否支持划动翻页。设置为true支持滑动翻页,false不支持。默认值:false initialOffset12+

initialOffset(value: OffsetOptions)
设置初始滚动偏移量。只在首次布局时生效,后续动态修改该属性值不生效。
元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析value是当输入的大小为百分比时,初始滚动偏移量为Scroll组件主轴方向大小与百分比数值之积。 ScrollDirection枚举分析

体系本事: SystemCapability.ArkUI.ArkUI.Full
名称描述Horizontal仅支持程度方向滚动。元服务API: 从API version 11开始,该接口支持在元服务中利用。Vertical仅支持竖直方向滚动。元服务API: 从API version 11开始,该接口支持在元服务中利用。None不可滚动。元服务API: 从API version 11开始,该接口支持在元服务中利用。Free(deprecated)支持竖直或程度方向滚动从API version 9开始废弃。 ScrollSnapOptions10+

元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
名称类型必填分析snapAlign是设置Scroll组件限位滚动时的对齐方式。**分析:**1.该属性默认值为ScrollSnapAlign.NONE。snapPaginationArray否enableSnapToStartboolean否在Scroll组件限位滚动模式下,该属性设置为false后,允许Scroll在开头和第一个限位点间自由滑动。**分析:**1.该属性值默认为true。2.该属性仅当snapPagination属性为Array时生效,不支持Dimension。enableSnapToEndboolean否在Scroll组件限位滚动模式下,该属性设置为false后,允许Scroll在最后一个限位点和末端间自由滑动。**分析:**1.该属性值默认为true。2.该属性仅当snapPagination属性为Array时生效,不支持Dimension。 变乱

除支持[通用变乱]和[滚动组件通用变乱]外,还支持以下变乱:
onScrollFrameBegin9+

onScrollFrameBegin(event: (offset: number, state: ScrollState) => { offsetRemain: number; })
每帧开始滚动时触发,变乱参数传入即将发生的滚动量,变乱处置惩罚函数中可根据应用场景盘算现实必要的滚动量并作为变乱处置惩罚函数的返回值返回,Scroll将按照返回值的现实滚动量进行滚动。
支持offsetRemain为负值。
若通过onScrollFrameBegin变乱和scrollBy方法实现容器嵌套滚动,需设置子滚动节点的EdgeEffect为None。如Scroll嵌套List滚动时,List组件的edgeEffect属性需设置为EdgeEffect.None。
触发该变乱的条件:
1、滚动组件触发滚动时触发,包括键鼠操作等其他触发滚动的输入设置。
2、调用控制器接口时不触发。
3、越界回弹不触发。
4、拖动滚动条不触发。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析offsetnumber是即将发生的滑动量,单位vp。state是当前滑动状态。 返回值:
类型分析{ offsetRemain: number }现实滑动量,单位vp。 onScroll(deprecated)

onScroll(event: (xOffset: number, yOffset: number) => void)
滚动变乱回调,返回滚动时程度、竖直方向偏移量,单位vp。
触发该变乱的条件 :
1、滚动组件触发滚动时触发,支持键鼠操作等其他触发滚动的输入设置。
2、通过滚动控制器API接口调用。
3、越界回弹。
从API version12开始废弃不再利用,保举利用变乱更换。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析xOffsetnumber是每帧滚动时程度方向的偏移量,Scroll的内容向左滚动时偏移量为正,向右滚动时偏移量为负。单位vp。yOffsetnumber是每帧滚动时竖直方向的偏移量,Scroll的内容向上滚动时偏移量为正,向下滚动时偏移量为负。单位vp。 onWillScroll12+

onWillScroll(handler: ScrollOnWillScrollCallback)
滚动变乱回调,Scroll滚动前触发。
回调当前帧将要滚动的偏移量和当前滚动状态和滚动操作来源,此中回调的偏移量为盘算得到的将要滚动的偏移量值,并非最终现实滚动偏移。可以通过该回调返回值指定Scroll将要滚动的偏移。
触发该变乱的条件 :
1、滚动组件触发滚动时触发,支持键鼠操作等其他触发滚动的输入设置。
2、通过滚动控制器API接口调用。
3、越界回弹。
元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析handler是Scroll滚动前触发的回调。 onDidScroll12+

onDidScroll(handler: ScrollOnScrollCallback)
滚动变乱回调,Scroll滚动时触发。
返回当前帧滚动的偏移量和当前滚动状态。
触发该变乱的条件 :
1、滚动组件触发滚动时触发,支持键鼠操作等其他触发滚动的输入设置。
2、通过滚动控制器API接口调用。
3、越界回弹。
元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析handler是Scroll滚动时触发的回调 onScrollEdge

onScrollEdge(event: (side: Edge) => void)
滚动到边缘变乱回调。
触发该变乱的条件 :
1、滚动组件滚动到边缘时触发,支持键鼠操作等其他触发滚动的输入设置。
2、通过滚动控制器API接口调用。
3、越界回弹。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析side是滚动到的边缘位置。 onScrollEnd(deprecated)

onScrollEnd(event: () => void)
滚动克制变乱回调。
触发该变乱的条件 :
1、滚动组件触发滚动后克制,支持键鼠操作等其他触发滚动的输入设置。
2、通过滚动控制器API接口调用后克制,带过渡动效。
该变乱从API version 9开始废弃,利用onScrollStop变乱更换。
体系本事: SystemCapability.ArkUI.ArkUI.Full
onScrollStart9+

onScrollStart(event: () => void)
滚动开始时触发。手指拖动Scroll或拖动Scroll的滚动条触发的滚动开始时,会触发该变乱。利用滚动控制器触发的带动画的滚动,动画开始时会触发该变乱。
触发该变乱的条件 :
1、滚动组件开始滚动时触发,支持键鼠操作等其他触发滚动的输入设置。
2、通过滚动控制器API接口调用后开始,带过渡动效。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
onScrollStop9+

onScrollStop(event: () => void)
滚动克制时触发。手拖动Scroll或拖动Scroll的滚动条触发的滚动,手脱离屏幕并且滚动克制时会触发该变乱。利用滚动控制器触发的带动画的滚动,动画克制时会触发该变乱。
触发该变乱的条件 :
1、滚动组件触发滚动后克制,支持键鼠操作等其他触发滚动的输入设置。
2、通过滚动控制器API接口调用后开始,带过渡动效。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
ScrollOnScrollCallback12+

type ScrollOnScrollCallback = (xOffset: number, yOffset: number, scrollState: ScrollState) => void
Scroll滚动时触发的回调。
元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数名类型必填分析xOffsetnumber是每帧滚动时程度方向的偏移量,Scroll中的内容向左滚动时偏移量为正,向右滚动时偏移量为负。单位vp。yOffsetnumber是每帧滚动时竖直方向的偏移量,Scroll中的内容向上滚动时偏移量为正,向下滚动时偏移量为负。单位vp。scrollState是当前滚动状态。 分析
若通过onScrollFrameBegin变乱和scrollBy方法实现容器嵌套滚动,需设置子滚动节点的EdgeEffect为None。如Scroll嵌套List滚动时,List组件的edgeEffect属性需设置为EdgeEffect.None。
ScrollOnWillScrollCallback12+

type ScrollOnWillScrollCallback = (xOffset: number, yOffset: number, scrollState: ScrollState, scrollSource: ScrollSource) => void | OffsetResult
Scroll滚动前触发的回调。
元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数名类型必填分析xOffsetnumber是每帧滚动时程度方向的偏移量,Scroll中的内容向左滚动时偏移量为正,向右滚动时偏移量为负。单位vp。yOffsetnumber是每帧滚动时竖直方向的偏移量,Scroll中的内容向上滚动时偏移量为正,向下滚动时偏移量为负。单位vp。scrollState是当前滚动状态。scrollSource是当前滚动操作的来源。 返回值:
类型分析void Scroller

可滚动容器组件的控制器,可以将此组件绑定至容器组件,然后通过它控制容器组件的滚动,同一个控制器不可以控制多个容器组件,目前支持绑定到List、Scroll、ScrollBar、Grid、WaterFlow上。
导入对象

scroller: Scroller = new Scroller()
constructor

constructor()
Scroller的构造函数。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
scrollTo

scrollTo(value: { xOffset: number | string, yOffset: number | string, animation?: ScrollAnimationOptions | boolean })
滑动到指定位置。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析xOffsetnumberstring是yOffsetnumberstring是animation12+boolean10+否 scrollEdge

scrollEdge(value: Edge, options?: ScrollEdgeOptions)
滚动到容器边缘,不区分滚动轴方向,Edge.Top和Edge.Start表现雷同,Edge.Bottom和Edge.End表现雷同。
Scroll组件默认有动画,Grid、List、WaterFlow组件默认无动画。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析value是滚动到的边缘位置。元服务API: 从API version 11开始,该接口支持在元服务中利用。options12+否设置滚动到边缘位置的模式。元服务API: 从API version 12开始,该接口支持在元服务中利用。 fling12+

fling(velocity: number): void
滚动类组件开启按传入的初始速率进行惯性滚动。
元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析velocitynumber是惯性滚动的初始速率值。单位:vp/s**分析:**velocity值设置为0,视为异常值,本次滚动不生效。如果值为正数,则向下滚动;如果值为负数,则向上滚动。 错误码ID错误信息401Parameter error. Possible causes: 1. Mandatory parameters are left unspecified; 2.Incorrect parameters types; 3. Parameter verification failed.100004Controller not bound to component. scrollPage9+

scrollPage(value: { next: boolean }): void
滚动到下一页或者上一页。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析nextboolean是是否向下翻页。true表示向下翻页,false表示向上翻页。 scrollPage(deprecated)

scrollPage(value: { next: boolean, direction?: Axis })
滚动到下一页或者上一页。从API version 9开始, 该接口不再维护,保举利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析nextboolean是是否向下翻页。true表示向下翻页,false表示向上翻页。direction否设置滚动方向为程度或竖直方向。 currentOffset

currentOffset(): OffsetResult
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
类型描述返回当前的滚动偏移量。**分析:**当scroller控制器未绑定容器组件或者容器组件被异常释放时,currentOffset的返回值为空。 scrollToIndex

scrollToIndex(value: number, smooth?: boolean, align?: ScrollAlign, options?: ScrollToIndexOptions)
滑动到指定Index,支持设置滑动额外偏移量。
开启smooth动效时,会对颠末的所有item进行加载和布局盘算,当大量加载item时会导致性能问题。
分析
仅支持Grid、List、WaterFlow组件。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析valuenumber是要滑动到的目标元素在当前容器中的索引值。**分析:**value值设置成负值或者大于当前容器子组件的最大索引值,视为异常值,本次跳转不生效。smoothboolean否设置滑动到列表项在列表中的索引值时是否有动效,true表示有动效,false表示没有动效。默认值:false。align否指定滑动到的元素与当前容器的对齐方式。List中的默认值为:ScrollAlign.START。Grid中默认值为:ScrollAlign.AUTO。WaterFlow中的默认值为:ScrollAlign.START。**分析:**仅List、Grid、WaterFlow组件支持该参数。options12+否设置滑动到指定Index的选项,如额外偏移量。默认值:0,单位:vp。 scrollBy9+

scrollBy(dx: Length, dy: Length)
滑动指定间隔。
分析
支持Scroll、List、Grid、WaterFlow组件。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析dx是程度方向滚动间隔,不支持百分比情势。dy是竖直方向滚动间隔,不支持百分比情势。 isAtEnd10+

isAtEnd(): boolean
查询组件是否滚动到底部。
分析
支持Scroll、List、Grid、WaterFlow组件。
元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
返回值
类型描述booleantrue表示组件已经滚动到底部,false表示组件还没滚动到底部。 getItemRect11+

getItemRect(index: number): RectResult
获取子组件的大小及相对容器组件的位置。
分析
支持Scroll、List、Grid、WaterFlow组件。
元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填分析indexnumber是子组件的索引值。 分析


[*]index必须是当前显示区域显示的子组件的索引值,否则视为非法值。
[*]非法值返回的大小和位置均为0。
返回值:
类型分析子组件的大小和相对于组件的位置。单位:vp。 错误码ID错误信息401Parameter error. Possible causes: 1. Mandatory parameters are left unspecified; 2.Incorrect parameters types; 3. Parameter verification failed.100004Controller not bound to component. OffsetResult11+

元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
名称类型只读可选分析xOffsetnumber否否程度滑动偏移。返回值单位为vp。yOffsetnumber否否竖直滑动偏移。返回值单位为vp。 ScrollAnimationOptions12+

元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
名称类型必填分析durationnumber否设置滚动时长。默认值:1000。**分析:**设置为小于0的值时,按默认值显示。curve9+否canOverScrollboolean否设置滚动是否可越界。默认值:false。**分析:**仅在设置为true,且组件的edgeEffect设置为时,滚动可以或许越界,并在越界时启动回弹动画。 ScrollAlign10+枚举分析

元服务API: 从API version 11开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
名称描述START首部对齐。指定item首部与List首部对齐。CENTER居中对齐。指定item主轴方向居中对齐于List。END尾部对齐。指定item尾部与List尾部对齐。AUTO自动对齐。若指定item完全处于显示区,不做调整。否则依照滑动间隔最短的原则,将指定item首部对齐或尾部对齐于List,使指定item完全处于显示区。 ScrollToIndexOptions12+对象分析

元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
名称类型必填分析extraOffset否滑动到指定Index的额外偏移量。 OffsetOptions12+对象分析

元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
名称类型必填分析xOffset否程度滑动偏移默认值:0yOffset否垂直滑动偏移默认值:0 ScrollEdgeOptions12+对象分析

元服务API: 从API version 12开始,该接口支持在元服务中利用。
体系本事: SystemCapability.ArkUI.ArkUI.Full
名称类型必填分析velocitynumber否设置滚动到容器边缘的固定速率。如果设置小于等于0的值,参数不生效。默认值:0单位: vp/s 示例

示例1

该示例展示了Scroll组件部分属性和scroller控制器的利用。
// xxx.etsimport { curves } from '@kit.ArkUI'@Entry@Componentstruct ScrollExample {scroller: Scroller = new Scroller()
private arr: number[] = build() {    Stack({ alignContent: Alignment.TopStart }) {      Scroll(this.scroller) {      Column() {          ForEach(this.arr, (item: number) => {            Text(item.toString())            .width('90%')            .height(150)            .backgroundColor(0xFFFFFF)            .borderRadius(15)            .fontSize(16)            .textAlign(TextAlign.Center)            .margin({ top: 10 })          }, (item: string) => item)      }.width('100%')      }      .scrollable(ScrollDirection.Vertical) // 滚动方向纵向      .scrollBar(BarState.On) // 滚动条常驻显示      .scrollBarColor(Color.Gray) // 滚动条颜色      .scrollBarWidth(10) // 滚动条宽度      .friction(0.6)      .edgeEffect(EdgeEffect.None)      .onWillScroll((xOffset: number, yOffset: number, scrollState: ScrollState) => {      console.info(xOffset + ' ' + yOffset)      })      .onScrollEdge((side: Edge) => {      console.info('To the edge')      })      .onScrollStop(() => {      console.info('Scroll Stop')      })      Button('scroll 150')      .height('5%')      .onClick(() => { // 点击后下滑指定间隔150.0vp          this.scroller.scrollBy(0, 150)      })      .margin({ top: 10, left: 20 })      Button('scroll 100')      .height('5%')      .onClick(() => { // 点击后滑动到指定位置,即下滑100.0vp的间隔          const yOffset: number = this.scroller.currentOffset().yOffset;          this.scroller.scrollTo({ xOffset: 0, yOffset: yOffset + 100 })      })      .margin({ top: 60, left: 20 })      Button('scroll 100')      .height('5%')      .onClick(() => { // 点击后滑动到指定位置,即下滑100.0vp的间隔,滑动过程设置有动画          let curve = curves.interpolatingSpring(10, 1, 228, 30) //创建一个门路曲线          const yOffset: number = this.scroller.currentOffset().yOffset;          this.scroller.scrollTo({ xOffset: 0, yOffset: yOffset + 100, animation: { duration: 1000, curve: curve } })      })      .margin({ top: 110, left: 20 })      Button('back top')      .height('5%')      .onClick(() => { // 点击后回到顶部          this.scroller.scrollEdge(Edge.Top)      })      .margin({ top: 160, left: 20 })      Button('next page')      .height('5%')      .onClick(() => { // 点击后滑到下一页          this.scroller.scrollPage({ next: true })      })      .margin({ top: 210, left: 20 })    }.width('100%').height('100%').backgroundColor(0xDCDCDC)}} https://i-blog.csdnimg.cn/direct/680ee20bc0fb4fa3bb3e87c61cf49eab.png
示例2

该示例利用onScrollFrameBegin变乱实现了内层List组件和外层Scroll组件的嵌套滚动。
import { LengthMetrics } from '@kit.ArkUI'

@Entry
@Component
struct NestedScroll {
@State listPosition: number = 0; // 0代表滚动到List顶部,1代表中间值,2代表滚动到List底部。
private arr: number[] =
private scrollerForScroll: Scroller = new Scroller()
private scrollerForList: Scroller = new Scroller()

build() {
    Flex() {
      Scroll(this.scrollerForScroll) {
      Column() {
          Text("Scroll Area")
            .width("100%")
            .height("40%")
            .backgroundColor(0X330000FF)
            .fontSize(16)
            .textAlign(TextAlign.Center)
            .onClick(() => {
            this.scrollerForList.scrollToIndex(5, false, ScrollAlign.START, { extraOffset: LengthMetrics.vp(5) })
            })

          List({ space: 20, scroller: this.scrollerForList }) {
            ForEach(this.arr, (item: number) => {
            ListItem() {
                Text("ListItem" + item)
                  .width("100%")
                  .height("100%")
                  .borderRadius(15)
                  .fontSize(16)
                  .textAlign(TextAlign.Center)
                  .backgroundColor(Color.White)
            }.width("100%").height(100)
            }, (item: string) => item)
          }
          .width("100%")
          .height("50%")
          .edgeEffect(EdgeEffect.None)
          .friction(0.6)
          .onReachStart(() => {
            this.listPosition = 0
          })
          .onReachEnd(() => {
            this.listPosition = 2
          })
          .onScrollFrameBegin((offset: number) => {
            if ((this.listPosition == 0 && offset <= 0) || (this.listPosition == 2 && offset >= 0)) {
            this.scrollerForScroll.scrollBy(0, offset)
            return { offsetRemain: 0 }
            }
            this.listPosition = 1
            return { offsetRemain: offset };
          })

          Text("Scroll Area")
            .width("100%")
            .height("40%")
            .backgroundColor(0X330000FF)
            .fontSize(16)
            .textAlign(TextAlign.Center)
      }
      }
      .width("100%").height("100%")
    }.width('100%').height('100%').backgroundColor(0xDCDCDC).padding(20)
}
}
https://i-blog.csdnimg.cn/direct/d42e6f3e2f9b4ca6840911eef40e539d.png
示例3

该示例利用nestedScroll属性实现了内层List组件和外层Scroll组件的嵌套滚动。
@Entry
@Component
struct StickyNestedScroll {
@State arr: number[] = []

@Styles
listCard() {
    .backgroundColor(Color.White)
    .height(72)
    .width("100%")
    .borderRadius(12)
}

build() {
    Scroll() {
      Column() {
      Text("Scroll Area")
          .width("100%")
          .height("40%")
          .backgroundColor('#0080DC')
          .textAlign(TextAlign.Center)
      Tabs({ barPosition: BarPosition.Start }) {
          TabContent() {
            List({ space: 10 }) {
            ForEach(this.arr, (item: number) => {
                ListItem() {
                  Text("item" + item)
                  .fontSize(16)
                }.listCard()
            }, (item: string) => item)
            }.width("100%")
            .edgeEffect(EdgeEffect.Spring)
            .nestedScroll({
            scrollForward: NestedScrollMode.PARENT_FIRST,
            scrollBackward: NestedScrollMode.SELF_FIRST
            })
          }.tabBar("Tab1")

          TabContent() {
          }.tabBar("Tab2")
      }
      .vertical(false)
      .height("100%")
      }.width("100%")
    }
    .edgeEffect(EdgeEffect.Spring)
    .friction(0.6)
    .backgroundColor('#DCDCDC')
    .scrollBar(BarState.Off)
    .width('100%')
    .height('100%')
}

aboutToAppear() {
    for (let i = 0; i < 30; i++) {
      this.arr.push(i)
    }
}
}
https://i-blog.csdnimg.cn/direct/aed257422def4176a307adb707f4990a.png
示例4

该示例实现了Scroll组件的限位滚动。
@Entry
@Component
struct Index {
scroller: Scroller = new Scroller;
private arr: number[] =
build() {
    Scroll(this.scroller) {
      Column() {
      ForEach(this.arr, (item: number) => {
          Text(item.toString())
            .width('90%')
            .height(200)
            .backgroundColor(0xFFFFFF)
            .borderWidth(1)
            .borderColor(Color.Black)
            .borderRadius(15)
            .fontSize(16)
            .textAlign(TextAlign.Center)
      }, (item: string) => item)
      }.width('100%').backgroundColor(0xDCDCDC)
    }
    .backgroundColor(Color.Yellow)
    .height('100%')
    .edgeEffect(EdgeEffect.Spring)
    .scrollSnap({snapAlign:ScrollSnapAlign.START, snapPagination:400, enableSnapToStart:true, enableSnapToEnd:true})
}
}
https://i-blog.csdnimg.cn/direct/77bf979ba789415fba47a68962625495.png
示例5

该示例通过scroller控制器的Fling接口触发Scroll组件的惯性滚动。
@Entry
@Component
//滚动控制器新增按给定速度执行惯性滚动的函数fling
struct ListExample {
private arr: number[] =
scrollerForList: Scroller = new Scroller()
build() {
    Column() {
      Button('Fling-1000')
      .height('5%')
      .onClick(() => {
          this.scrollerForList.fling(-1000)
      })
      Button('Fling3000')
      .height('5%')
      .onClick(() => {
          this.scrollerForList.fling(3000)
      })
      List({ space: 20, initialIndex: 0, scroller: this.scrollerForList }) {
      ForEach(this.arr, (item: number) => {
          ListItem() {
            Text('' + item)
            .width('100%').height(100).fontSize(16)
            .textAlign(TextAlign.Center).borderRadius(10).backgroundColor(0xFFFFFF)
          }
      }, (item: string) => item)
      }
      .listDirection(Axis.Vertical) // 排列方向
      .scrollBar(BarState.Off)
      .friction(0.9)
      .divider({ strokeWidth: 2, color: 0xFFFFFF, startMargin: 20, endMargin: 20 }) // 每行之间的分界线
      .edgeEffect(EdgeEffect.Spring) // 边缘效果设置为Spring
      .width('90%')
    }
    .width('100%')
    .height('100%')
    .backgroundColor(0xDCDCDC)
    .padding({ top: 5 })
}
}
https://i-blog.csdnimg.cn/direct/aaf73ed543a34746908de6d2fd862f35.png
示例6

该示例实现了按速率700vp/s向Scroll下边缘滚动。
// xxx.ets@Entry@Componentstruct ScrollExample {scroller: Scroller = new Scroller()
private arr: number[] = build() {    Stack({ alignContent: Alignment.TopStart }) {      Scroll(this.scroller) {      Column() {          ForEach(this.arr, (item: number) => {            Text(item.toString())            .width('90%')            .height(150)            .backgroundColor(0xFFFFFF)            .borderRadius(15)            .fontSize(16)            .textAlign(TextAlign.Center)            .margin({ top: 10 })          }, (item: string) => item)      }.width('100%')      }      .scrollable(ScrollDirection.Vertical) // 滚动方向纵向      .scrollBar(BarState.On) // 滚动条常驻显示      .scrollBarColor(Color.Gray) // 滚动条颜色      .scrollBarWidth(10) // 滚动条宽度      .friction(0.6)      .edgeEffect(EdgeEffect.None)      .onWillScroll((xOffset: number, yOffset: number, scrollState: ScrollState) => {      console.info(xOffset + ' ' + yOffset)      })      .onScrollEdge((side: Edge) => {      console.info('To the edge')      })      .onScrollStop(() => {      console.info('Scroll Stop')      })      Button('scroll to bottom 700')      .height('5%')      .onClick(() => { // 点击后滑到下边缘,速率值是700vp/s          this.scroller.scrollEdge(Edge.Bottom, { velocity: 700 })      })      .margin({ top: 100, left: 20 })    }.width('100%').height('100%').backgroundColor(0xDCDCDC)}} https://i-blog.csdnimg.cn/direct/63f3329c288a4272b9a91d00059ec981.png

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 鸿蒙OpenHarmony【Scroll】ArkTS滚动与滑动