热门标签 | 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图片



推荐阅读
  • 本文介绍了使用FormData对象上传文件同时附带其他参数的方法。通过创建一个表单,将文件和参数添加到FormData对象中,然后使用ajax发送POST请求进行文件上传。在发送请求时,需要设置processData为false,告诉jquery不要处理发送的数据;同时设置contentType为false,告诉jquery不要设置content-Type请求头。 ... [详细]
  • 本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ... [详细]
  • XMLhttpREquest_Ajax技术总结之XmlHttpRequest
    Ajax1、 什么是ajax   ... [详细]
  • 第一种<script>$(".eq").on(&qu ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
  • 【爬虫】关于企业信用信息公示系统加速乐最新反爬虫机制
    ( ̄▽ ̄)~又得半夜修仙了,作为一个爬虫小白,花了3天时间写好的程序,才跑了一个月目标网站就更新了,是有点悲催,还是要只有一天的时间重构。升级后网站的层次结构并没有太多变化,表面上 ... [详细]
  • html和js代码互转,html转html5
    本文目录一览:1、html网页跳转javascript代码实现 ... [详细]
  • 用ESP32与Python实现物联网(IoT)火焰检测报警系统
    下图是本案例除硬件连线外的3步导学开发过程,每个步骤中实现的功能请参考图中的说明。在硬件连线完成之后我们建议您先使用“一分钟上云体验”功能预先体验本案例的实际运行效果 ... [详细]
  • Java大文件HTTP断点续传到服务器该怎么做?
    最近由于笔者所在的研发集团产品需要,需要支持高性能的大文件http上传,并且要求支持http断点续传。这里在简要归纳一下,方便记忆 ... [详细]
  • 1、概述首先和大家一起回顾一下Java消息服务,在我之前的博客《Java消息队列-JMS概述》中,我为大家分析了:然后在另一篇博客《Java消息队列-ActiveMq实战》中 ... [详细]
  • 表单代码 ... [详细]
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社区 版权所有