热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php类似html2canvas,使用html2canvas在服务器端生成图片

需求:在项目中需要使用截图的功能,但是我们一般情况都是采用微信或者是QQ进行截图,而且这种方式不方便,更重要的是࿰

需求:在项目中需要使用截图的功能,但是我们一般情况都是采用微信或者是QQ进行截图,而且这种方式不方便,更重要的是,如果要截取的部分超出一屏的话,采用上述方式截图,只能截取一部分内容,而不能将所有的内容截取出来,因此,我们迫切的需要一种可以滚动截图的方式,并且是截取我想要的部分,因此就引出了下面的这种截图方式--html2canvas。

首先最基本的是:引入这个js文件。

下面是实现此功能的具体代码

1. HTML页面的代码

保存图片

2. js代码

$(function(){

$(".saveImage").on('click', function (event) {

var img={}

event.preventDefault();

html2canvas($(".fc-view-container"), {

allowTaint: true,

taintTest: false,

onrendered: function(canvas) {

canvas.id = "mycanvas";

//生成base64图片数据

var dataUrl = canvas.toDataURL();

img.img=dataUrl;

saveimg(img)

}

});

});

});

// 保存图片

function saveimg(img){

$.ajax({

url:"{:U('Index/saveImg')}",

type:'post',

data:img,

success:function(data){

if (data.status) {

//toast.success(data.info,'温馨提示');

setTimeout(function(){

window.location.href="/Uploads/Screen/"+data.url+".png";

}, 1000)

}else{

//toast.error(data.info,'温馨提示');

setTimeout(function(){

window.location.reload(true);

},1200)

};

}

})

}

首先是给保存图片的这个元素绑定一个未来事件,在事件中使用了canvas接口中的toDataURL()方法,我们来解释一下这个方法的作用:

参考Web Api接口 使用此方法,可以返回一个data: URL,根据type参数指定的类型将包含在canvas中的图片文件编码成字符串形式, type参数的默认值为image/png.

其次是:html2canvas($(".fc-view-container")),这个方法用来指定截取并生成图片的Dom对象。

最后我们是后端的代码:

3.PHP代码

/**

* 截图保存图片

*/

public function saveImg()

{

$pictureFlow=I('img');

//图片流转存

$pictureFlow = str_replace('data:image/png;base64,', '', $pictureFlow);

$pictureFlow = base64_decode($pictureFlow);

$NOW_TIME=NOW_TIME;

$new_pic_path = 'Uploads/Screen/'.$NOW_TIME.'.png';

$ret = file_put_contents($new_pic_path, $pictureFlow);

if ($ret) {

$this->success('下载成功',$NOW_TIME);

}else{

$this->error('下载失败');

}

}

服务器端的代码中使用替换操作和base64解码功能,这样就可以直接保存前面截取的部分为png格式的图片。

保存截图如下:

287e9eb6e36a

截取的png图片



推荐阅读
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • 深入探讨ASP.NET中的OAuth、JWT与OpenID Connect
    本文作为前文关于OAuth2.0和使用.NET实现OAuth身份验证的补充,详细阐述了OAuth与JWT及OpenID Connect之间的关系和差异,旨在提供更全面的理解。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 作为一名新手,您可能会在初次尝试使用Eclipse进行Struts开发时遇到一些挑战。本文将为您提供详细的指导和解决方案,帮助您克服常见的配置和操作难题。 ... [详细]
  • andr ... [详细]
  • Babylon.js 实例展示
    探索 Babylon.js 的强大功能,通过全屏演示体验其卓越性能。本文提供在线文档链接和默认渲染管线的源码调试地址,帮助您深入了解 Babylon.js 的工作原理。 ... [详细]
  • 本文详细介绍了 JavaScript 中的条件判断(if-else 和 switch)以及循环控制(for、while 和 do-while)。我们将探讨这些结构的基本语法、使用场景及注意事项,并补充一些实用技巧。 ... [详细]
  • 本文介绍了如何在 JavaScript 中对两个结构不同的数组进行数据合并,提供详细的代码示例和解释。 ... [详细]
author-avatar
dmcm0010
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有