HarmonyOS 鸿蒙Next 外层Scroll或Refresh组件内WaterFlow跟随滑动实现

HarmonyOS 鸿蒙Next 外层Scroll或Refresh组件内WaterFlow跟随滑动实现

首页数据结构比较复杂,在瀑布流上面还有4个条目,无法使用WaterFlow全部包含进去,
现在实现方式是使用外层Scroll或者Refresh组件内包含WaterFlow如何实现WaterFlow,现在WaterFlow无法跟随一起滑动,

这是CodeGenie给出的方案也不行
要在鸿蒙OS的WaterFlow组件中禁止滚动,可以通过设置scroller参数为null或者不绑定任何滚动控制对象来实现。具体步骤如下:

1.设置scroller参数为null: 在WaterFlow组件的配置中,将scroller参数设置为null。这将使WaterFlow组件无法滚动 。

2.不绑定滚动控制对象: 如果你不想将scroller参数设置为null,也可以不绑定任何滚动控制对象。默认情况下,WaterFlow组件会绑定到其子组件的滚动控制器上 。通过不绑定滚动控制对象,可以实现禁止滚动的效果。

3.其他相关参数:

direction.Column:设置为false以确保WaterFlow组件不会滚动 。
nestedScroll:如果需要嵌套滚动,可以设置为null或者不使用。
通过以上配置,你可以实现WaterFlow组件的禁止滚动效果。


更多关于HarmonyOS 鸿蒙Next 外层Scroll或Refresh组件内WaterFlow跟随滑动实现的实战教程也可以访问 https://www.itying.com/category-93-b0.html

3 回复
[@Entry](/user/Entry)
[@ComponentV2](/user/ComponentV2)
struct Index {
[@Local](/user/Local) minSize: number = 80
[@Local](/user/Local) maxSize: number = 180
[@Local](/user/Local) fontSize: number = 24
[@Local](/user/Local) colors: number[] = [0xFFC0CB, 0xDA70D6, 0x6B8E23, 0x6A5ACD, 0x00FFFF, 0x00FF7F]
scroller: Scroller = new Scroller()
dataSource: WaterFlowDataSource = new WaterFlowDataSource()
private itemWidthArray: number[] = []
private itemHeightArray: number[] = []

// 计算FlowItem宽/高
getSize() {
let ret = Math.floor(Math.random() * this.maxSize)
return (ret > this.minSize ? ret : this.minSize)
}

// 设置FlowItem的宽/高数组
setItemSizeArray() {
for (let i = 0; i < 100; i++) {
this.itemWidthArray.push(this.getSize())
this.itemHeightArray.push(this.getSize())
}
}

aboutToAppear() {
this.setItemSizeArray()
}

build() {
Scroll() {
Column() {
Row() {
Text('1')
Text('2')
Text('3')
Text('4')
}.width('100%')
.height('15%')
.backgroundColor(Color.Blue)
.justifyContent(FlexAlign.SpaceBetween)

WaterFlow() {
LazyForEach(this.dataSource, (item: number) => {
FlowItem() {
Column() {
Text("N" + item).fontSize(12).height('16')
// 存在对应的jpg文件才会显示图片
// Image('res/waterFlowTest(' + item % 5 + ').jpg')
// .objectFit(ImageFit.Fill)
// .width('100%')
// .layoutWeight(1)
}
}
.onAppear(() => {
// 即将触底时提前增加数据
if (item + 20 == this.dataSource.totalCount()) {
for (let i = 0; i < 100; i++) {
this.dataSource.addLastItem()
}
}
})
.width('100%')
.height(this.itemHeightArray[item % 100])
.backgroundColor(this.colors[item % 5])
}, (item: string) => item)
}
.columnsTemplate("1fr 1fr")
.columnsGap(10)
.rowsGap(5)
.backgroundColor(0xFAEEE0)
.width('100%')
.height('100%')
.height('100%')
.backgroundColor(Color.Orange)
.nestedScroll({
scrollForward: NestedScrollMode.PARENT_FIRST,
scrollBackward: NestedScrollMode.SELF_FIRST,
})
}
}
.size({ width: '100%', height: '100%' })
.scrollBar(BarState.Off)
}
}

// WaterFlowDataSource.ets

// 实现IDataSource接口的对象,用于瀑布流组件加载数据
export class WaterFlowDataSource implements IDataSource {
private dataArray: number[] = []
private listeners: DataChangeListener[] = []

constructor() {
for (let i = 0; i < 100; i++) {
this.dataArray.push(i)
}
}

// 获取索引对应的数据
public getData(index: number): number {
return this.dataArray[index]
}

// 通知控制器数据重新加载
notifyDataReload(): void {
this.listeners.forEach(listener => {
listener.onDataReloaded()
})
}

// 通知控制器数据增加
notifyDataAdd(index: number): void {
this.listeners.forEach(listener => {
listener.onDataAdd(index)
})
}

// 通知控制器数据变化
notifyDataChange(index: number): void {
this.listeners.forEach(listener => {
listener.onDataChange(index)
})
}

// 通知控制器数据删除
notifyDataDelete(index: number): void {
this.listeners.forEach(listener => {
listener.onDataDelete(index)
})
}

// 通知控制器数据位置变化
notifyDataMove(from: number, to: number): void {
this.listeners.forEach(listener => {
listener.onDataMove(from, to)
})
}

//通知控制器数据批量修改
notifyDatasetChange(operations: DataOperation[]): void {
this.listeners.forEach(listener => {
listener.onDatasetChange(operations);
})
}

// 获取数据总数
public totalCount(): number {
return this.dataArray.length
}

// 注册改变数据的控制器
registerDataChangeListener(listener: DataChangeListener): void {
if (this.listeners.indexOf(listener) < 0) {
this.listeners.push(listener)
}
}

// 注销改变数据的控制器
unregisterDataChangeListener(listener: DataChangeListener): void {
const pos = this.listeners.indexOf(listener)
if (pos >= 0) {
this.listeners.splice(pos, 1)
}
}

// 增加数据
public add1stItem(): void {
this.dataArray.splice(0, 0, this.dataArray.length)
this.notifyDataAdd(0)
}

// 在数据尾部增加一个元素
public addLastItem(): void {
this.dataArray.splice(this.dataArray.length, 0, this.dataArray.length)
this.notifyDataAdd(this.dataArray.length - 1)
}

// 在指定索引位置增加一个元素
public addItem(index: number): void {
this.dataArray.splice(index, 0, this.dataArray.length)
this.notifyDataAdd(index)
}

// 删除第一个元素
public delete1stItem(): void {
this.dataArray.splice(0, 1)
this.notifyDataDelete(0)
}

// 删除第二个元素
public delete2ndItem(): void {
this.dataArray.splice(1, 1)
this.notifyDataDelete(1)
}

// 删除最后一个元素
public deleteLastItem(): void {
this.dataArray.splice(-1, 1)
this.notifyDataDelete(this.dataArray.length)
}

// 在指定索引位置删除一个元素
public deleteItem(index: number): void {
this.dataArray.splice(index, 1)
this.notifyDataDelete(index)
}

// 重新加载数据
public reload(): void {
this.dataArray.splice(1, 1)
this.dataArray.splice(3, 2)
this.notifyDataReload()
}
}

更多关于HarmonyOS 鸿蒙Next 外层Scroll或Refresh组件内WaterFlow跟随滑动实现的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


waterflow要控制高度,这里写了 100%,代表着waterflow占了一屏的高度。 然后是嵌套滑动nestedScroll。scrollForward: NestedScrollMode.PARENT_FIRST,代表向下滑动查看更多的时候,优先滑动外面的scroll, 当waterflow展示高度为一个屏幕高度时,这时候scroll的已经滑到底。继续滑动就是waterflow响应滑动事件。

在HarmonyOS鸿蒙Next系统中,实现外层Scroll或Refresh组件内WaterFlow(瀑布流)跟随滑动的效果,可以通过以下方式实现:

  1. 组件嵌套:确保外层Scroll或Refresh组件正确嵌套WaterFlow组件。通过XML或Java UI框架布局实现嵌套结构。

  2. 事件监听:在外层Scroll或Refresh组件上添加滚动事件监听器。利用组件的滚动事件(如onScrollStateChanged)来感知滚动状态。

  3. 同步滚动:在滚动事件监听器中,根据外层组件的滚动位置和速度,动态调整WaterFlow组件的显示内容或位置,实现跟随效果。这通常涉及计算WaterFlow组件的偏移量或重新布局。

  4. 优化性能:考虑到瀑布流组件可能包含大量图片或复杂布局,需优化内存使用和渲染性能。如使用图片懒加载、分页加载等技术。

  5. 调试与测试:在不同设备和屏幕尺寸上进行充分测试,确保跟随滑动效果流畅且稳定。

实现过程中,注意保持代码结构清晰,便于维护和后续功能扩展。如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html

回到顶部