如何实现图片的大图预览效果

经常会有点击图片进行大图预览的效果,并且可以对图片进行放大缩小和拖拽的功能。

HarmonyOS
2024-05-26 12:39:53
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
elucky

使用的核心API

核心代码解释

1. 点击图片时会在原有的图片上进行放大,放大的图会有一个蒙层,点击这个蒙层可关闭大图的显示,就需要设置一个visibility,通过改变visibility来控制蒙层和大图的出现。

2. 大图显示以后,给图片绑定组合手势,先给图片绑定PinchGesture,图片可以通过捏合从而进行放大缩小,在捏合手势执行时,就要改变图片的pinchX的值,和pinchY的值,后面绑定的拖拽手势也是相同的道理,通过改变相应的XY值去改变图片的位置。

@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') 
                }) 
            ) 
 
          ) 
 
      } 
    } 
 
  } 
}

适配的版本信息

  • IDE:DevEco    Studio 4.1.1.300
  • SDK:4.1.2.1
分享
微博
QQ
微信
回复
2024-05-27 16:22:10
相关问题
图片模糊效果如何实现
308浏览 • 1回复 待解决
如何使用预览器查看服务效果
838浏览 • 1回复 待解决
如何设置图片高斯模糊效果
1122浏览 • 1回复 待解决
如何实现类似.9 功能
442浏览 • 1回复 待解决
如何实现列表页单选效果
893浏览 • 0回复 待解决
canvas如何实现水印效果
353浏览 • 1回复 待解决
滑动组件如何实现单边spring效果
489浏览 • 1回复 待解决
如何实现双路预览+录制功能
442浏览 • 1回复 待解决
如何等效实现JSONObejct效果
209浏览 • 1回复 待解决
如何实现一个GIF显示指定次数
683浏览 • 1回复 待解决
如何实现组件阴影效果
321浏览 • 1回复 待解决
如何实现类似keyframes效果
648浏览 • 1回复 待解决
通过web上传图片并进行预览
372浏览 • 1回复 待解决
使用预览实现多端预览
377浏览 • 1回复 待解决
鸿蒙可以实现矢量
9801浏览 • 2回复 待解决
如何实现图片点击跳转?
3945浏览 • 1回复 待解决
如何实现通用吸顶效果
143浏览 • 1回复 待解决
如何实现分组列表吸顶/吸底效果
746浏览 • 1回复 待解决
如何实现拍照预览onPreviewFrame回调
161浏览 • 1回复 待解决
camera_lite预览功能如何实现
1004浏览 • 0回复 待解决
如何实现图片进度条
340浏览 • 1回复 待解决
如何实现动画转场效果
348浏览 • 1回复 待解决