图片进行画笔或者马赛克绘制

​通过pan手势在图片上绘制图形以及打马赛克

HarmonyOS
2024-05-23 22:56:17
浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
好难的昵称

使用的核心API

手势事件以及Canvas画布

核心代码

1. 给画布添加移动手势

Canvas(this.viewModel.context) 
  .width('100%') 
  .height('75%') 
  .onAreaChange((oldValue: Area, newValue: Area) => { 
    this.viewModel.canvasAreaChange(newValue) 
  }) 
  .gesture( 
    GestureGroup(GestureMode.Exclusive, 
      PanGesture() 
        .onActionStart((event: GestureEvent) => { 
          let finger: FingerInfo = event.fingerList[0]; 
          if (finger == undefined) { return } 
          let x = finger.localX 
          let y = finger.localY 
          this.viewModel.moveStart(x,y) 
        }) 
        .onActionUpdate((event: GestureEvent) => { 
          let finger: FingerInfo = event.fingerList[0]; 
          if (finger == undefined) { return } 
          let x = finger.localX 
          let y = finger.localY 
          this.viewModel.moveUpdate(x,y) 
        }) 
        .onActionEnd((event: GestureEvent) => { 
          let finger: FingerInfo = event.fingerList[0]; 
          if (finger == undefined) { return } 
          this.viewModel.moveEnd() 
        }) 
    ) 
  ) 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.

2. 绘制路径 以及马赛克

moveStart(x: number, y: number) { 
  this.points.push({x: x, y: y}) 
  this.drawPath.moveTo(x, y) 
  this.drawCurrentPathModel()} 
moveUpdate(x: number, y: number) { 
  let lastPoint = this.points[this.points.length - 1] 
  this.points.push({x: x, y: y}) 
  this.drawPath.quadraticCurveTo((x + lastPoint.x) / 2, (y + lastPoint.y) / 2, x, y) 
  this.drawCurrentPathModel() 
} 
moveEnd() { 
  this.points = [] 
  this.drawPath = new Path2D() 
} 
clearPath() { 
  this.points = [] 
  this.drawPath = new Path2D() 
  this.context.clearRect(0, 0, this.canvasWidth, this.canvasHeight) 
} 
canvasAreaChange(area: Area) { 
  this.canvasHeight = area.height as number 
  this.canvasWidth = area.width as number 
} 
private drawCurrentPathModel() { 
  this.context.globalCompositeOperation = 'source-over' 
  this.context.lineWidth = this.drawModel.lineWidth 
  if (this.drawModel.pathType == DrawPathType.pen) { 
    this.context.strokeStyle = this.drawModel.color 
  } else { 
    if (this.pattern) { 
      this.context.strokeStyle = this.pattern 
    } 
  } 
  this.context.lineJoin = 'round' 
  this.context.stroke(this.drawPath) 
} 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.

马赛克的关键点: 其实就是设置 RenderingContext 线条的颜色,线条支持image

IDE版本:4.1.3.500

SDK版本:api11

分享
微博
QQ
微信
回复
2024-05-24 22:29:45
相关问题
HarmonyOS 如何实现马赛克功能
645浏览 • 1回复 待解决
Canvas画的时候,怎么设置画笔颜色
1234浏览 • 1回复 待解决
HarmonyOS canvas如何绘制图片导出
714浏览 • 1回复 待解决
使用Drawing进行2d图像绘制
1798浏览 • 1回复 待解决
HarmonyOS 文件或者图片的下载
535浏览 • 1回复 待解决
画布上绘制图片如何实现?
830浏览 • 1回复 待解决
HarmonyOS Canvas中关于绘制图片问题
1024浏览 • 1回复 待解决
canvas怎么绘制资源目录下的图片
1456浏览 • 1回复 待解决
Canvas如何绘制app.media下面的图片?
3257浏览 • 1回复 待解决
怎么进行应用名称或者图标的修改?
248浏览 • 0回复 待解决
HarmonyOS 对于图片或者背景图拉伸
783浏览 • 1回复 待解决