本文具体要实现的效果类似下面这张图片,主题流程大概是,页面上有类似这样布局的结构,点击中间那个紫色的按钮就会生成一张这样的图片,并且能够让用户下载图片的
1、首先我们布局页面的时候用的都是图片来布局成这个样子[CSS自己脑补],class为pho-bg这一段是页面开始显示的结构,几张图片定位,按钮在中间的样子。class为photo的就是用来到时候放置生成的图片。canvas就是画布。至于下面的两张图片其实就是按钮的图片和背景图,到时候一并加入画布里面【不过在页面的时候不显示】
<div class="pho-bg"> <img src="/UploadFiles/2021-04-02/man-1.png">2、重要的是js部分,这里面有几个部分
- 在点击按钮时隐藏掉本来的页面,显示画布生成的图片
- canvas.width,canvas.height是设置你生成的图片的大小。举个例子:如果我在canvas的html标签里面设置的width=750,height=1180,但是在js里面设置了canvas.width=500,canvas.height=500,那么生成的图片的大小就会是500*500.
- 使用createPattern来制作图片的背景图
- 使用drawImage()来制作组成图片的小元素也就是红、黄、蓝、绿、紫那几张图片
- 最后用toDataURL()将画布的内容转为图片并且渲染到页面上
$('.btn').click(function() { $('.pho-bg').hide(); // $('#myCanvas').show(); var man1 = document.getElementById("man-1"), man2 = document.getElementById("man-2"), man3 = document.getElementById("man-3"), man4 = document.getElementById("man-4"), sen1 = document.getElementById("sen1"), btn1 = document.getElementById("btn1"), canvasBg = document.getElementById("bg1"); var canvas = document.getElementById("myCanvas"); ctx = canvas.getContext("2d"); canvas.width = 750; canvas.height = 1180; // 制作背景图 var patBg = ctx.createPattern(canvasBg, "repeat"); ctx.rect(0, 0, 750, 1180); ctx.fillStyle = patBg; ctx.fill(); // 将man1,man2,man3,man4,sen1,btn加入画布 ctx.drawImage(man1, 0, 0, 341, 474); ctx.drawImage(man2, 410, 0, 341, 474); ctx.drawImage(man3, 0, 474, 341, 474); ctx.drawImage(man4, 410, 474, 341, 474); ctx.drawImage(sen1, 40, 950, 669, 109); ctx.drawImage(btn1, 150, 350, 449, 288); var newImg = new Image(); newImg.src = canvas.toDataURL("image/png"); $('.photo').append(newImg); });
最后的结果生成的图片就是这样子的
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“js canvas实现5张图片合成一张图片”评论...
更新动态
2024年11月15日
2024年11月15日
- 黄乙玲1988-无稳定的爱心肝乱糟糟[日本东芝1M版][WAV+CUE]
- 群星《我们的歌第六季 第3期》[320K/MP3][70.68MB]
- 群星《我们的歌第六季 第3期》[FLAC/分轨][369.48MB]
- 群星《燃!沙排少女 影视原声带》[320K/MP3][175.61MB]
- 乱斗海盗瞎6胜卡组推荐一览 深暗领域乱斗海盗瞎卡组分享
- 炉石传说乱斗6胜卡组分享一览 深暗领域乱斗6胜卡组代码推荐
- 炉石传说乱斗本周卡组合集 乱斗模式卡组最新推荐
- 佟妍.2015-七窍玲珑心【万马旦】【WAV+CUE】
- 叶振棠陈晓慧.1986-龙的心·俘虏你(2006复黑限量版)【永恒】【WAV+CUE】
- 陈慧琳.1998-爱我不爱(国)【福茂】【WAV+CUE】
- 咪咕快游豪礼放送,百元京东卡、海量欢乐豆就在咪咕咪粉节!
- 双11百吋大屏焕新“热”,海信AI画质电视成最大赢家
- 海信电视E8N Ultra:真正的百吋,不止是大!
- 曾庆瑜1990-曾庆瑜历年精选[派森][WAV+CUE]
- 叶玉卿1999-深情之选[飞图][WAV+CUE]