canvas指定区域生成图片(canvas实现图片镜像翻转的2种方式)
类别:Web前端 浏览量:851
时间:2021-10-18 11:31:08 canvas指定区域生成图片
canvas实现图片镜像翻转的2种方式1. 通过canvas自带的画布方法进行翻转
var img = new Image(); //这个就是 img标签的dom对象 img.src = './sy.png'; img.onload = function () { //图片加载完成后,执行此方法 ctx.drawImage(img, posx, posy, 210, 80); };
play.addEventListener('click', function () { ctx.clearRect(0, 0, canvas.width, canvas.height);//清除画布 //位移来做镜像翻转 ctx.translate(210+ posx * 2, 0); ctx.scale(-1, 1); //左右镜像翻转 //ctx.translate(0, 160 + posy * 2); //ctx.scale(1, -1); //上下镜像翻转 ctx.drawImage(img, 0, 0, 210, 80); });
2.像素点的镜像翻转方法
//竖向像素反转 function imageDataVRevert(sourceData, newData) { for (var i = 0, h = sourceData.height; i < h; i++) { for (var j = 0, w = sourceData.width; j < w; j++) { newData.data[i * w * 4 + j * 4 + 0] = sourceData.data[(h - i) * w * 4 + j * 4 + 0]; newData.data[i * w * 4 + j * 4 + 1] = sourceData.data[(h - i) * w * 4 + j * 4 + 1]; newData.data[i * w * 4 + j * 4 + 2] = sourceData.data[(h - i) * w * 4 + j * 4 + 2]; newData.data[i * w * 4 + j * 4 + 3] = sourceData.data[(h - i) * w * 4 + j * 4 + 3]; } } return newData; }
//横向像素反转 function imageDataHRevert(sourceData, newData) { for (var i = 0, h = sourceData.height; i < h; i++) { for (j = 0, w = sourceData.width; j < w; j++) { newData.data[i * w * 4 + j * 4 + 0] = sourceData.data[i * w * 4 + (w - j) * 4 + 0]; newData.data[i * w * 4 + j * 4 + 1] = sourceData.data[i * w * 4 + (w - j) * 4 + 1]; newData.data[i * w * 4 + j * 4 + 2] = sourceData.data[i * w * 4 + (w - j) * 4 + 2]; newData.data[i * w * 4 + j * 4 + 3] = sourceData.data[i * w * 4 + (w - j) * 4 + 3]; } } return newData; } `` var img = new Image(); //这个就是 img标签的dom对象 img.src = './sy.png'; img.onload = function () { //图片加载完成后,执行此方法 ctx.drawImage(img, 0, 0, 210, 80); }; //像素点操作 var imgData = ctx.getImageData(0, 0, 210, 80); var newImgData = ctx.getImageData(0, 0, 210, 80); // var newImgData = ctx.getImageData(0, 0, w, h); ctx.putImageData(imageDataVRevert(newImgData, imgData), 0, 0); //上下翻转 // ctx.putImageData(imageDataHRevert(newImgData, imgData), 0, 0);//左右翻转~~~~
到此这篇关于canvas实现图片镜像翻转的2种方式的文章就介绍到这了,更多相关canvas图片镜像翻转内容请搜索开心学习网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持开心学习网!
您可能感兴趣
- canvas 中增加组件(如何在Canvas中添加事件的方法示例)
- canvas 裁剪画布(Canvas图片分割效果的实现)
- html5canvas怎么改扇形起始角(HTML5 Canvas实现放大镜效果示例)
- canvas设置点击(Canvas高级路径操作之拖拽对象的实现)
- 使用canvas的好坏(关于canvas绘制模糊问题的解决方法)
- 获取canvas画布内容(清除canvas画布内容点擦除+线擦除)
- canvas图片填充位置(手摸手教你用canvas实现给图片添加平铺水印的实现)
- htmlcanvas的使用(html2canvas生成清晰的图片实现打印的示例代码)
- canvas如何调试(关于canvas.toDataURL 在iOS运行失败的问题解决)
- canvas实现滚动列表(Canvas实现贝赛尔曲线轨迹动画的示例代码)
- canvas图片显示报错(html2canvas生成的图片偏移不完整的解决方法)
- canvas里面图片如何获取(canvas生成带二维码海报的踩坑记录)
- html5 canvas 特效(JavaScript canvas实现流星特效)
- canvas进阶教程(原生canvas制作画图小工具的踩坑和爬坑)
- canvas绘制渐变图形(Canvas实现放大镜效果完整案例分析附代码)
- 小程序canvas不显示(小程序canvas中文字设置居中锚点)
- 《刘老根3》热播,去世15年的她却再次被 伤害(去世15年的她却再次被)
- 十二星座爱情支配欲指数(十二星座爱情支配欲指数)
- 虐待儿童是发泄支配欲的愚蠢行为(虐待儿童是发泄支配欲的愚蠢行为)
- 你或许不知道你隐藏的支配欲望(你或许不知道你隐藏的支配欲望)
- 把宽体丰田86卖了,换成7.5代高尔夫GTI玩起姿态与性能并存的改装(把宽体丰田86卖了)
- 大众推出了第五代高尔夫GT(大众推出了第五代高尔夫GT)
热门推荐
- linux中ceph的状态(Wdcp linux控制面板配置多PHP版本记录)
- mysql中的默认mysql数据库作用(MySQL安装后默认自带数据库的作用详解)
- css图片3D效果(用CSS实现图片的3D凹凸感凸出镜框外或凹陷镜框里)
- mysql查看执行计划
- 服务器启动nginx服务的命令(Nginx服务器添加Systemd自定义服务过程解析)
- arm堆栈解析程序(浅析ARM架构下的函数的调用过程)
- sql转字符串函数(sql中的常用的字符串处理函数大全)
- dockerswarm网络架构(docker swarm外部验证负载均衡时不生效的解决方案)
- vue验证码怎么用(vue验证码组件使用方法详解)
- mysql8.0设置root密码(MySQL8.0.23版本的root密码重置最优解法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9