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 相关文章推荐
js验证模型自我实现的具体方法
Jun 21 Javascript
js+css实现的圆角边框TAB选项卡滑动门代码分享(2款)
Aug 26 Javascript
使用jquery+CSS3实现仿windows10开始菜单的下拉导航菜单特效
Sep 24 Javascript
JS中input表单隐藏域及其使用方法
Feb 13 Javascript
node.js+jQuery实现用户登录注册AJAX交互
Apr 28 jQuery
Vue.js对象转换实例
Jun 07 Javascript
用Webpack构建Vue项目的实践
Nov 07 Javascript
深入了解Hybrid App技术的相关知识
Jul 17 Javascript
ES6 Promise对象概念及用法实例详解
Oct 15 Javascript
Nuxt v-bind绑定img src不显示的解决
Dec 05 Javascript
react+antd 递归实现树状目录操作
Nov 02 Javascript
详解JavaScript的计时器和按钮效果设置
Feb 18 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
thinkphp 多表 事务详解
2013/06/17 PHP
PHP采用XML-RPC构造Web Service实例教程
2014/07/16 PHP
php中mysql操作buffer用法详解
2015/03/19 PHP
PHP中strnatcmp()函数“自然排序算法”进行字符串比较用法分析(对比strcmp函数)
2016/01/07 PHP
深入浅析PHP无限极分类的案例教程
2016/05/09 PHP
PHP微信发送推送消息乱码的解决方法
2019/02/28 PHP
jquery 取子节点及当前节点属性值
2014/07/25 Javascript
在for循环中length值是否需要缓存
2015/07/27 Javascript
javascript中FOREACH数组方法使用示例
2016/03/01 Javascript
使用jquery获取url以及jquery获取url参数的实现方法
2016/05/25 Javascript
Vue系列:通过vue-router如何传递参数示例
2017/01/16 Javascript
JavaScript Date 知识浅析
2017/01/29 Javascript
微信小程序getPhoneNumber获取用户手机号
2017/09/29 Javascript
axios中cookie跨域及相关配置示例详解
2017/12/20 Javascript
从零开始最小实现react服务器渲染详解
2018/01/26 Javascript
vue项目部署上线遇到的问题及解决方法
2018/06/10 Javascript
Vue2实时监听表单变化的示例讲解
2018/08/30 Javascript
在移动端使用vue-router和keep-alive的方法示例
2018/12/02 Javascript
Vue-cli 移动端布局和动画使用详解
2020/08/10 Javascript
[02:11]DOTA2上海特级锦标赛主赛事第二日RECAP
2016/03/04 DOTA
python通过scapy获取局域网所有主机mac地址示例
2014/05/04 Python
Python实现类似jQuery使用中的链式调用的示例
2016/06/16 Python
python中返回矩阵的行列方法
2018/04/04 Python
Python网络爬虫信息提取mooc代码实例
2020/03/06 Python
TensorFlow的reshape操作 tf.reshape的实现
2020/04/19 Python
使用Python下载抖音各大V视频的思路详解
2021/02/06 Python
梅西百货澳大利亚:Macy’s Australia
2017/07/26 全球购物
马歇尔耳机官网:Marshall Headphones
2020/02/04 全球购物
新电JAVA笔试题目
2014/08/31 面试题
Linux管理员面试题 Linux admin interview questions
2016/07/08 面试题
生产管理的三大手法
2013/11/11 职场文书
九年级政治教学反思
2014/02/06 职场文书
幼儿园开学家长寄语(2015秋季)
2015/05/27 职场文书
Python保存并浏览用户的历史记录
2022/04/29 Python
详解NumPy中的线性关系与数据修剪压缩
2022/05/25 Python
纯CSS打字动画的实现示例
2022/08/05 HTML / CSS