JavaScript实现图片合成下载的示例


Posted in Javascript onNovember 19, 2020

最近项目一个功能需求,需实现将两张图片合成后下载的一个功能。分析完功能需求后,决定直接使用前端技术来实现。为提高效率,使用插件(html2canvas)配合编写此功能。有关插件(html2canvas)的介绍,这里不多说明,大家可自行网上查阅。以下直接附上效果演示图以及完整代码

效果演示:

JavaScript实现图片合成下载的示例

完整代码:(代码复制可直接使用)

注:最好将代码文件放在服务器环境下运行,以防止插件(html2canvas)出错,这里使用的服务器环境为phpStudy,为本地服务器环境。有关本地服务器有哪些以及下载使用,可自行网上查阅

<!DOCTYPE html> 
<html> 
<head> 
<meta charset="utf-8"> 
<title>JS实现图片合成下载</title> 
<script src="https://cdn.bootcss.com/jquery/1.10.2/jquery.min.js"></script> 
<script src="//apps.bdimg.com/libs/jqueryui/1.10.4/jquery-ui.min.js"></script><!--加载jquery ui主要作用是使用其拖拽的功能--> 
<script src="https://cdn.bootcss.com/html2canvas/0.5.0-beta4/html2canvas.min.js"></script><!--想要图片合成,核心就是加载使用这个插件--> 
<script> 
function BaseImage(imgFile) {//图片1上传的函数方法 
   var f = imgFile.files[0];//获取上传的图片文件 
   var filereader = new FileReader();//新建一个图片对象 
  filereader.onload = function (event) {//图片加载完成后执行的函数 
      var srcpath = event.target.result;//这里获取图片的路径(图片会被转为base6格式) 
      $("#baseimg").attr("src",srcpath);//将获取的图片使用jquery的attr()方法插入到id为baseimg的图片元素里 
   }; 
   filereader.readAsDataURL(f);//读取图片(将插入的图片读取显示出来) 
 } 
 
function StyleImage(imgFile) { //图片2上传的函数方法(原理同上) 
   var f = imgFile.files[0]; 
  var filereader = new FileReader(); 
   filereader.onload = function (event) { 
      var srcpath = event.target.result; 
      $("#styleimg").attr("src",srcpath); 
  }; 
    filereader.readAsDataURL(f); 
 }  
 
$(function() { 
    $( ".drg" ).draggable();//这里使用jquery ui的拖拽方法  draggable();作用是可以让图片2进行拖拽 
}); 
 
function down(){//这个函数是点击下载执行的方法 
   html2canvas($(".whole"),{ //这是使用了html2canvas这个插件的方法,将class为whole的整个节点绘制成画布 
     onrendered:function(canvas){  //画布绘制完成后执行下面内容,function内的canvas这个参数就是已经被绘制成画布 
          var link = document.createElement('a');//创建一个a标签 
          link.download = 'my-image-name.jpg';//a标签增加一个download属性,属性值(my-image-name.jpg)就是合成下载后的文件名 
          link.href = canvas.toDataURL();//canvas.toDataURL()就是画布的路径,将路径赋给a标签的href 
          link.click();//模拟a标签被点击,这样就可以下载了 
     }, 
  }) 
} 
</script> 
</head> 
<body> 
 
<fieldset> 
 <input type="file"  onchange="BaseImage(this)" > 
<legend>上传图1</legend> 
</fieldset> 
<fieldset> 
<input  type="file"  onchange="StyleImage(this)" > 
 <legend>上传图2</legend> 
</fieldset> 
<fieldset> 
 <button onclick="down()" >点击合成下载</button> 
</fieldset> 
 
<span class="whole" style="width: 544px;display: inline-block;position: relative;"> 
<img id="baseimg"  style="width:100%;height:auto;"  > 
<div style="height: 100%;width: 100%;top:0;position: absolute;overflow: hidden;"> 
<div class="drg" style="position: absolute;width:100px;top: 0px;left: 0px;display: inline-block;"> 
<img id="styleimg"  style="width:100%;cursor: pointer;" > 
</div> 
</div> 
</span> 
 
</body> 
</html>

以上就是JavaScript实现图片合成下载的示例的详细内容,更多关于JavaScript 图片合成下载的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
在javascript将NodeList作为Array数组处理的方法
Jul 09 Javascript
Javascript学习笔记-详解in运算符
Sep 13 Javascript
jQuery教程 $()包装函数来实现数组元素分页效果
Aug 13 Javascript
js获取或设置当前窗口url参数的小例子
Oct 14 Javascript
JavaScript中的数值范围介绍
Dec 29 Javascript
JavaScript页面模板库handlebars的简单用法
Mar 02 Javascript
浅谈$(document)和$(window)的区别
Jul 15 Javascript
学习JavaScript设计模式之迭代器模式
Jan 19 Javascript
JavaScript判断页面加载完之后再执行预定函数的技巧
May 17 Javascript
p5.js绘制创意自画像
Nov 04 Javascript
vue 根据选择条件显示指定参数的例子
Nov 09 Javascript
JS实现音量控制拖动
Jan 15 Javascript
vue 获取到数据但却渲染不到页面上的解决方法
Nov 19 #Vue.js
vue 插槽简介及使用示例
Nov 19 #Vue.js
微信小程序实现点击导航条切换页面
Nov 19 #Javascript
详解Vue的mixin策略
Nov 19 #Vue.js
微信小程序自定义底部弹出框功能
Nov 18 #Javascript
微信小程序实现底部弹出框
Nov 18 #Javascript
微信小程序实现弹幕墙(祝福墙)
Nov 18 #Javascript
You might like
[原创]php正则删除html代码中class样式属性的方法
2017/05/24 PHP
php图片合成方法(多张图片合成一张)
2017/11/25 PHP
PHP中strtr与str_replace函数运行性能简单测试示例
2019/06/22 PHP
JQuery1.4+ Ajax IE8 内存泄漏问题
2010/10/15 Javascript
node.js中的fs.chownSync方法使用说明
2014/12/16 Javascript
BootStrap制作导航条实例代码
2016/05/06 Javascript
原生js封装二级城市下拉列表的实现代码
2016/06/16 Javascript
jquery实现拖动效果(代码分享)
2017/01/25 Javascript
JavaScript表单验证的两种实现方法
2017/02/11 Javascript
利用forever和pm2部署node.js项目过程
2017/05/10 Javascript
vue中子组件调用兄弟组件方法
2018/07/06 Javascript
Webpack4+Babel7+ES6兼容IE8的实现
2019/04/10 Javascript
vue+vant实现商品列表批量倒计时功能
2020/01/13 Javascript
Swiper实现导航栏滚动效果
2020/10/16 Javascript
VUE和Antv G6实现在线拓扑图编辑操作
2020/10/28 Javascript
Javascript生成器(Generator)的介绍与使用
2021/01/31 Javascript
[50:27]OG vs LGD 2018国际邀请赛淘汰赛BO3 第一场 8.26
2018/08/30 DOTA
Python 字符串中的字符倒转
2008/09/06 Python
python统计日志ip访问数的方法
2015/07/06 Python
Python实现将16进制字符串转化为ascii字符的方法分析
2017/07/21 Python
Jupyter notebook远程访问服务器的方法
2018/05/24 Python
python os.fork() 循环输出方法
2019/08/08 Python
Python 迭代,for...in遍历,迭代原理与应用示例
2019/10/12 Python
用ldap作为django后端用户登录验证的实现
2020/12/07 Python
Python3中的tuple函数知识点讲解
2021/01/03 Python
IE8下CSS3选择器nth-child() 不兼容问题的解决方法
2016/11/16 HTML / CSS
加拿大著名时装品牌:SOIA & KYO
2016/08/23 全球购物
JOSEPH官网:英国奢侈时尚品牌
2018/01/31 全球购物
Aurora London官网:奢华、负担得起的皮革手袋
2020/08/01 全球购物
小孩百日宴答谢词
2014/01/15 职场文书
法定代表人授权委托书范文
2014/08/02 职场文书
小学生迎国庆演讲稿
2014/09/05 职场文书
个人向公司借款协议书
2014/10/09 职场文书
论文答谢词
2015/01/20 职场文书
利用Python实现翻译HTML中的文本字符串
2022/06/21 Python
Nginx代理Redis哨兵主从配置的实现
2022/07/15 Servers