如何实现图片预览,有人知道吗?

需要一个图片点击放大,包含手势缩放的组件

HarmonyOS
2024-07-22 12:02:57
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
Heiang

通过stack做图片点击后展示的蒙层,点击蒙层后可退出预览,预览图中可对图片进行放大缩小等基础操作。

参考代码:

@Entry 
@Component 
struct Index { 
  @State visible: Visibility = Visibility.None 
  @State scaleValue: number = 1 
  @State pinchValue: number = 1 
  @State pinchX: number = 0 
  @State pinchY: number = 0 
  @State count: number = 0 
  @State offsetX: number = 0 
  @State offsetY: number = 0 
  @State positionX: number = 0 
  @State positionY: number = 0 
 
  build() { 
    Stack() { 
      Row() { 
        Column() { 
          Image($r('app.media.icon')) 
            .width(100) 
            .height(100) 
            .onClick(() => { 
              console.log("hit me!") 
              if (this.visible == Visibility.Visible) { 
                this.visible = Visibility.None 
              } else { 
                this.visible = Visibility.Visible 
              } 
            }) 
        } 
        .width('100%') 
        .justifyContent(FlexAlign.Center) 
        .alignItems(HorizontalAlign.Center) 
      } 
      .height('100%') 
 
 
      Text('') 
        .onClick(() => { 
          if (this.visible == Visibility.Visible) { 
            this.visible = Visibility.None 
          } else { 
            this.visible = Visibility.Visible 
          } 
        }) 
        .width('100%') 
        .height('100%')// 透明度可以自己调节一下 
        .opacity(0.16) 
        .backgroundColor(0x000000) 
        .visibility(this.visible) 
 
      Column() { 
        Image($r('app.media.icon')) 
          .width(300) 
          .height(300) 
          .draggable(false) 
          .visibility(this.visible) 
          .scale({ x: this.scaleValue, y: this.scaleValue, z: 1 }) 
          .translate({ x: this.offsetX, y: this.offsetY, z: 0 }) 
          .gesture( 
            GestureGroup(GestureMode.Parallel, 
              PinchGesture({ fingers: 2 }) 
                .onActionStart((event?: GestureEvent) => { 
                  console.info('Pinch start') 
                }) 
                .onActionUpdate((event?: GestureEvent) => { 
                  if (event) { 
                    this.scaleValue = this.pinchValue * event.scale 
                    this.pinchX = event.pinchCenterX 
                    this.pinchY = event.pinchCenterY 
                  } 
                }) 
                .onActionEnd(() => { 
                  this.pinchValue = this.scaleValue 
                  console.info('Pinch end') 
                }), 
 
              PanGesture() 
                .onActionUpdate((event?: GestureEvent) => { 
                  if (event) { 
                    this.offsetX = this.positionX + event.offsetX 
                    this.offsetY = this.positionY + event.offsetY 
                  } 
                  console.info('pan update') 
                }) 
                .onActionEnd(() => { 
                  this.positionX = this.offsetX 
                  this.positionY = this.offsetY 
                  console.info('pan end') 
                }) 
            ) 
          ) 
      } 
    } 
  } 
}
分享
微博
QQ
微信
回复
2024-07-22 19:48:42
相关问题
如何实现振动,有人知道吗
1174浏览 • 2回复 待解决
如何实现翻页功能,有人知道吗
1951浏览 • 1回复 待解决
如何实现镂空效果,有人知道吗?
386浏览 • 1回复 待解决
如何对网络图片处理,有人知道吗
360浏览 • 1回复 待解决
如何实现http长连接,有人知道吗
1680浏览 • 1回复 待解决
图片压缩并保存方法,有人知道吗
841浏览 • 0回复 待解决
热重载该如何实现有人知道吗
797浏览 • 1回复 待解决
如何保存faultLogger ,有人知道吗
632浏览 • 1回复 待解决
如何发送短信,有人知道吗?
1923浏览 • 1回复 待解决
$$语法如何使用?有人知道吗
666浏览 • 1回复 待解决
如何跳出ForEach,有人知道吗
2076浏览 • 1回复 待解决
如何实现防截屏功能,有人知道吗
1998浏览 • 1回复 待解决
如何获取windowStage,有人知道吗
471浏览 • 1回复 待解决
如何获取wifi列表,有人知道吗
564浏览 • 1回复 待解决
IDE如何开启ASAN,有人知道吗
342浏览 • 1回复 待解决
如何使用快速修复,有人知道吗
689浏览 • 1回复 待解决
导航栏如何适配,有人知道吗?
1828浏览 • 0回复 待解决
如何引用HSP库,有人知道吗?
1690浏览 • 1回复 待解决
深色模式如何屏蔽?有人知道吗
344浏览 • 0回复 待解决
如何定义dialog动画,有人知道吗?
1954浏览 • 1回复 待解决
IP地址如何转化,有人知道吗
646浏览 • 1回复 待解决
如何查询设备类型?有人知道吗
406浏览 • 1回复 待解决
ArkTS要如何使用this,有人知道吗
528浏览 • 1回复 待解决
如何获取系统电量,有人知道吗
2045浏览 • 1回复 待解决
如何获取组件高度,有人知道吗
2113浏览 • 1回复 待解决