zoukankan      html  css  js  c++  java
  • jSignature在线签字板保存为图片

    <!DOCTYPE html>
    <html lang="zh-CN">
    <head>
    <title>手写板签名demo</title>
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
    <meta charset="UTF-8">
    <meta name="description" content="overview & stats" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0" />
    </head>
    <body>
        <div id="signature"></div>
        <p style="text-align: center">
            <b style="color: red">请按着鼠标写字签名。</b>
        </p>
        <input type="button" value="保存" id="yes"/>
        <input type="button" value="下载" id="download"/>
        <input type="button" value="重写" id="reset"/>
        <div id="someelement"></div>
        <script src="jquery-2.0.3.min.js"></script>
        <!--[if lt IE 9]>
            <script src="jSignature/flashcanvas.js"></script>
        <![endif]-->
        <script src="jSignature/jSignature.min.js"></script>
        <script>
            $(function() {
                var $sigdiv = $("#signature");
                $sigdiv.jSignature(); // 初始化jSignature插件.
                $("#yes").click(function(){
                    //将画布内容转换为图片
                    var datapair = $sigdiv.jSignature("getData", "image");
                    var i = new Image();
                    i.src = "data:" + datapair[0] + "," + datapair[1];
                    $(i).appendTo($("#someelement")); // append the image (SVG) to DOM.
    
                     //var data = $sigdiv.jSignature('getData', 'default')   
                      //console.log(data);  这个和上面得到的结果一样
                      
                });
                //datapair = $sigdiv.jSignature("getData","base30");
                //$sigdiv.jSignature("setData", "data:" + datapair.join(","));
                $("#download").click(function(){
                    downloadFile("a.png", convertBase64UrlToBlob($("img").attr("src")));
                });
                $("#reset").click(function(){
                    $sigdiv.jSignature("reset"); //重置画布,可以进行重新作画.
                    $("#someelement").html("");
                });
            });
            function downloadFile(fileName, blob){
                var aLink = document.createElement('a');
                var evt = document.createEvent("HTMLEvents");
                evt.initEvent("click", false, false);//initEvent 不加后两个参数在FF下会报错, 感谢 Barret Lee 的反馈
                aLink.download = fileName;
                aLink.href = URL.createObjectURL(blob);
                aLink.dispatchEvent(evt);
            }
            /**
             * 将以base64的图片url数据转换为Blob
             * @param urlData
             *            用url方式表示的base64图片数据
             */
            function convertBase64UrlToBlob(urlData){
                 
                var bytes=window.atob(urlData.split(',')[1]);        //去掉url的头,并转换为byte
                 
                //处理异常,将ascii码小于0的转换为大于0
                var ab = new ArrayBuffer(bytes.length);
                var ia = new Uint8Array(ab);
                for (var i = 0; i < bytes.length; i++) {
                    ia[i] = bytes.charCodeAt(i);
                }
     
                return new Blob( [ab] , {type : 'image/png'});
            }
        </script>
     
    </body>
    </html>

    手写签字板   另一个参考用(跟代码无关)

    方法详解

    jSignature 是一个通过捕捉笔画的矢量轮廓输出多种格式数据的jQuery插件,通过该插件我们可以实现绘画板、手写签名等功能。

    使用该插件需要引入jQuery和jSignature.js,首先初始化jSignature:

     var $signature = $("#signature").jSignature();

    接下来即可使用插件提供的一些常见的操作:

    (1)、重置画布

     $signature.jSignature('reset')

    (2)、获取数据并展示

     //获取数据 
     var data = $signature.jSignature('getData', 'default')    
     //图片展示
     var img = new Image()
     img.src = data
     $(img).appendTo($('#signimg'))
     //将数据显示在文本框
     $('#text').val(data)

    (3)、撤销上一步(引入jSignature.UndoButton.js)

    //初始化时传入参数 {'UndoButton':true}
    $("#signature").jSignature({'UndoButton':true});

    (4)、绘画板,例如设置笔触的颜色

    //加入方法setColor
     'setColor' : function(color) {
         // 获取 context 对象
         var context2D = this.find('canvas.'+apinamespace)
                         .add(this.filter('canvas.'+apinamespace))
                         .data(apinamespace+'.this').canvasContext
         //设置阴影的颜色
         context2D.shadowColor = 'transparent' 
         //设置笔触颜色
         context2D.strokeStyle = color
         return 
     }
  • 相关阅读:
    按指定上下限区间进行数据统计的示例.sql
    树形数据层次显示处理示例.sql
    Flexi传授如何说服自己的老板采用Node.js
    sed的用法[转]
    [bash] string operators
    [shell script]脚本实现目录和文件名显示
    Bash快捷键
    [bash] Condition Tests
    整理一下博客
    老爸的工具箱之:根据日期批量重命名照片
  • 原文地址:https://www.cnblogs.com/zywf/p/10483414.html
Copyright © 2011-2022 走看看