HarmonyOS 横纵滚动两个scroll怎么实现同时滚动

​横纵滚动两个scroll怎么实现同时滚动,我看了很久相关组件参数设置,也没达到想要的效果


HarmonyOS
2024-08-04 14:48:09
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
youganlan

横纵滚动的两个scroll,通过彼此的滚动事件.onScroll的回调,实现两个scroll的联动,

demo如下:

@Entry 
@Component 
struct ScrollIndex02 { 
  scrollerTop: Scroller = new Scroller() 
  scrollerLeft: Scroller = new Scroller() 
  @State dataListTop: string[] = ["a", "b", 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', "l"] 
  @State dataListLeft: string[] = ["1", "2", '3', '4', '5', '6', '7', '8', '9', '10', '11', "12"] 
 
  build() { 
    Stack({alignContent:Alignment.TopStart}) { 
      Row(){ 
        //任意图片:resources\base\media\icon.png 
        Image($r('app.media.icon')) 
          .height(60) 
        List({ space: 4, scroller: this.scrollerTop }) { 
          ForEach(this.dataListTop, (item: string) => { 
            ListItem() { 
              Row() { 
                Text("item" + item) 
              } 
              .alignItems(VerticalAlign.Center) 
              .width(60) 
              .justifyContent(FlexAlign.Center) 
              .backgroundColor(Color.Pink) 
              .borderRadius(5) 
              .height("100%") 
            }.height("100%") 
          }) 
        } 
        .margin({left:2}) 
        .height(60) 
        .listDirection(Axis.Horizontal) 
        .edgeEffect(EdgeEffect.None) 
        .scrollBar(BarState.Off) 
        .onScroll((offset: number, state: ScrollState) => { 
          this.scrollerLeft.scrollBy(offset, 0) 
        }) 
      } 
      .height(60)
分享
微博
QQ
微信
回复
2024-08-05 12:17:34
相关问题
HarmonyOS scroll和list滚动冲突
202浏览 • 1回复 待解决
HarmonyOS Scroll组件滚动问题
258浏览 • 1回复 待解决
栅格布局怎么实现滚动效果?
313浏览 • 0回复 待解决
Scroll初始时自动滚动一段距离
733浏览 • 1回复 待解决
HarmonyOS 如何实现滚动渐变效果?
185浏览 • 1回复 待解决
页面导航如何实现两个页面叠层
1724浏览 • 1回复 待解决
HarmonyOS 两个同级的组件问题
265浏览 • 1回复 待解决
两个重叠的组件如何实现事件透传
390浏览 • 1回复 待解决
如何实现嵌套滚动技术
917浏览 • 1回复 待解决
HarmonyOS 如何比较两个日期的大小?
57浏览 • 1回复 待解决
页面导航如何实现A B两个页面叠层
554浏览 • 1回复 待解决
如何获取Scroll组件的当前滚动偏移量
1933浏览 • 1回复 待解决
两个设备控制相关问题
8958浏览 • 3回复 已解决
提问
该提问已有0人参与 ,帮助了0人