html2canvas截取页面

简介:

1.下载html2canvas.js

2.引入

3.修改html2canvas支持远程图片处理

function ImageContainer(src, cors) {
        this.src = src;
        this.image = new Image();
        var self = this;
        this.tainted = null;
        this.promise = new Promise(function(resolve, reject) {
            self.image.onload = resolve;
            self.image.onerror = reject;
            if (cors) {
                //self.image.crossOrigin = "anonymous";//1.去掉此处的anonymous代码改为空
                self.image.crossOrigin = "";
            }
            //self.image.src = src;//2.在源src后面添加一个随机数如时间戳+"?"+new Date().getTime();
            self.image.src = src+"?"+new Date().getTime();
            if (self.image.complete === true) {
                resolve(self.image);
            }
        });
    }

4.保存成base64,并处理

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="utf-8">
    <meta name="viewport"
          content="maximum-scale=1.0,minimum-scale=1.0,user-scalable=0,width=device-width,initial-scale=1.0"/>
    <meta name="format-detection" content="telephone=no,email=no,date=no,address=no">
    <title>群二维码名片</title>
    <link rel="stylesheet" href="../css/aui.2.0.css">
    <link rel="stylesheet" href="../css/message_style.css">
</head>
<body>

<header class="aui-bar aui-bar-nav aui-margin-b-15">
    <a class="aui-pull-left aui-btn" onclick="closeWin();">
        <span class="aui-iconfont aui-icon-left">返回</span>
    </a>
    <div class="aui-title">群二维码</div>
</header>

<div id="info_area"></div>

<script id="info_tmpl" type="text/html/x-dot-template">
<div class="s_cardbg">
    <div class="s_card" id="qrcode_card">
        <header>
            <img src="{{= it.groupAvatar}}"/>
            <span>{{= it.groupName}}</span>
        </header>
        <img id="qrcode_img" src="{{= it.qrcode}}" class="s_code"/>
    </div>
</div>
<div class="s_carbtnbg">
    <div class="s_caranimation">
        <button id="save">保存图片</button>
        <button class="s_sarcancel">取消</button>
    </div>
</div>
</script>
</body>
<script type="text/javascript" src="../script/api.js"></script>
<script type="text/javascript"  src="../script/jquery.min.js"></script>
<script type="text/javascript" src="../script/config.js"></script>
<script type="text/javascript" src="../script/common.js"></script>
<script type="text/javascript" src="../script/doT.min.js"></script>
<script type="text/javascript" src="../script/html2canvas.js"></script>

<script>
    apiready = function () {
        fix_status_bar();
        var groupId = api.pageParam.groupId;
        var groupName = api.pageParam.groupName;
        var groupAvatar = api.pageParam.groupAvatar;
        var qrcode  = BASE_URL_ACTION + '/Common/GetQrCode?dataId='+groupId+'&dataType=2&prefix=add';

        var data = {};
        data.groupId = groupId;
        data.groupName = groupName;
        data.groupAvatar = groupAvatar;
        data.qrcode = qrcode;
        var interText = doT.template($("#info_tmpl").text());
        $("#info_area").html(interText(data));

        $(".s_code").on("touchstart",function(){
            $(".s_carbtnbg").show();
        })
        $(".s_sarcancel").on("click",function(){
            $(".s_carbtnbg").hide()
        })

        $("#save").on("click", function () {
            html2canvas($("#qrcode_card"), {
                height: $("#qrcode_card").outerHeight() + 20,
                onrendered: function (canvas) {
                    var url = canvas.toDataURL("image/png");
                    var base64str = url.substr(22);
                    //以下代码为下载此图片功能
                    //                    $("#qrcode_img").attr('src',url);

                    var trans = api.require('trans');
                    trans.saveImage({
                        base64Str : base64str,
                        album : true,
                        imgPath : "fs://"
                    }, function(ret, err) {
                        if (ret.status) {
                            toast('保存成功');
                            $(".s_carbtnbg").hide();
                        }
                    });



                },useCORS:true});
        });

    }


</script>
</html>

实现了web截图,效果不错!!!


本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/7201289.html,如需转载请自行联系原作者

相关文章
|
1月前
使用HTML编写注册页面
使用HTML编写注册页面
13 1
|
2月前
|
移动开发 HTML5
html5初音未来减压页面源码
A Mainland China friendly and independent version extracted from https://aidn.jp/mikutap
80 2
|
2月前
|
数据采集 前端开发 JavaScript
html 页面里 noscript 标签的作用介绍
html 页面里 noscript 标签的作用介绍
30 0
|
2月前
|
Web App开发 前端开发 JavaScript
编程笔记 html5&css&js 004 我的第一个页面
编程笔记 html5&css&js 004 我的第一个页面
|
3月前
|
应用服务中间件
Tomcat8.5访问HTML页面出现乱码
Tomcat8.5访问HTML页面出现乱码
47 0
Tomcat8.5访问HTML页面出现乱码
|
4月前
|
JavaScript
用什么代码可以在页面添加html元素呢?
用什么代码可以在页面添加html元素呢?
|
5天前
|
移动开发 前端开发 JavaScript
如何实时准确地从HTML5视频中截取当前播放画面
如何实时准确地从HTML5视频中截取当前播放画面
21 4
|
7天前
|
移动开发 前端开发 JavaScript
【专栏:HTML与CSS实战项目篇】使用HTML5与CSS3制作一个动态表单验证页面
【4月更文挑战第30天】本文介绍了使用HTML5和CSS3创建动态表单验证页面的方法。首先,简述HTML5用于构建网页内容,CSS3用于描述样式。接着,分四步展示实现过程:1) 设计包含输入框和提示信息的表单结构;2) 使用CSS3创建样式,增强视觉效果;3) 使用JavaScript监听输入事件,动态验证表单并显示错误信息;4) 测试和调试确保跨平台兼容性。通过学习,开发者能掌握创建带验证功能的表单,提升用户体验。
|
7天前
|
前端开发 测试技术 UED
【专栏:HTML 与 CSS 实战项目篇】实现一个在线产品展示页面
【4月更文挑战第30天】本文介绍了使用HTML和CSS创建吸引人的在线产品展示页面的实战步骤,包括页面设计规划、HTML结构搭建、CSS样式设计、具体页面实现、交互效果添加、优化与提升。通过简洁布局、产品列表和详情页设计,实现易用且具吸引力的展示效果。优化图片和代码,提升性能,以助企业在数字时代脱颖而出。
|
19天前
|
机器人
机器人飞船404页面模板HTML源码
机器人飞船404页面模板HTML源码,源码由HTML+CSS+JS组成,记事本打开源码文件可以进行内容文字之类的修改,双击html文件可以本地运行效果,也可以上传到服务器里面,重定向这个界面
26 5
机器人飞船404页面模板HTML源码