HarmonyOS 气泡内容过多超出屏幕范围时,固定气泡大小内部支持滑动显示

气泡内容很多,显示完全会超出屏幕范围,此时需将气泡大小限制在一定范围内,气泡内部支持滑动展示;如何实现此效果

HarmonyOS
2025-01-09 15:02:48
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
put_get

请看下以下demo是否满足您的需求:

@Entry
@Component
struct BindPopupDemo {

  // 第一步:定义变量控制弹窗显示
  @State customPopup: boolean = false;

  // 第二步:popup构造器定义弹框内容
  @Builder popupBuilder() {
    Column({ space: 2 }) {
      Row()
        .width(64)
        .height(64)
        .backgroundColor(0x409eff)

      Text('Popup')
        .fontSize(10)
        .fontColor(Color.White)
    }
    .justifyContent(FlexAlign.SpaceAround)
    .width(100)
    .height(100)
    .padding(5)
  }
  @Builder
  customBubbleInstructionBuilder() {
    Stack() {
      List(){
        ListItem(){
          Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }){
            Text() {
              Span("2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件2021年12月20日-2022月1日30日每人限购8件 您已购买3件")
                .fontSize(12)
            }.fontColor(Color.White)
            .maxLines(100).ellipsisMode(EllipsisMode.END)
          }

        }
      }

    }.backgroundColor(0x409eff)
    .width(300)
    .height(300)
    .padding({
      left: 12,
      right: 12,
      top: 18,
      bottom: 8
    })
  }
  build() {
    Column() {

      Button('click')
        // 第四步:创建点击事件,控制弹窗显隐
        .onClick(() => {
          this.customPopup = !this.customPopup;
        })
        .backgroundColor(0xf56c6c)
          // 第三步:使用bindPopup接口将弹窗内容绑定给元素
        .bindPopup(this.customPopup, {
          builder: this.customBubbleInstructionBuilder,
          placement: Placement.Top,
          maskColor: 0x33000000,
          popupColor: 0xf56c6c,
          enableArrow: true,
          radius: '10vp', // 设置气泡的圆角
          backgroundBlurStyle: BlurStyle.NONE,
          onStateChange: (e) => {
            if (!e.isVisible) {
              this.customPopup = false;
            }
          }
        })
    }
    .justifyContent(FlexAlign.Center)
    .width('100%')
    .height(437)
  }
}
分享
微博
QQ
微信
回复
2025-01-09 17:56:04
相关问题
HarmonyOS Popup气泡支持边框问题
741浏览 • 1回复 待解决
HarmonyOS Slider组件气泡提示显示不全
1029浏览 • 1回复 待解决
HarmonyOS 如何实现气泡样式
771浏览 • 1回复 待解决
HarmonyOS 气泡背景颜色问题
684浏览 • 1回复 待解决
HarmonyOS如何修改气泡位置
967浏览 • 1回复 待解决
HarmonyOS 修改气泡弹出的位置
749浏览 • 1回复 待解决
HarmonyOS web加载内容过多时,无法显示
1338浏览 • 1回复 待解决
HarmonyOS 气泡点击蒙层问题
1126浏览 • 1回复 待解决
HarmonyOS 地图自定义气泡功能
845浏览 • 1回复 待解决
HarmonyOS bindPopup自定义气泡问题
712浏览 • 1回复 待解决
气泡组件有推荐的实现方式么?
1557浏览 • 1回复 待解决