html5+canvas實現(xiàn)支持觸屏的簽名插件教程
前言
大家在日常開發(fā)中使用該jQuery插件來制作在線簽名,用戶繪制的東西以圖片的形式保存下來,非常方便實用。下面將實現(xiàn)支持的方法分享給大家,供大家參考學(xué)習(xí),下面來一起看看詳細(xì)的介紹吧。
方法如下:
使用該簽名插件要引入jQuery和jq-signature.js文件。
<script src="jquery/1.11.0/jquery.min.js"></script> <script src="jq-signature.js"></script>
HTML結(jié)構(gòu)
<!-- 創(chuàng)建一個簽名區(qū)域,使用HTML5的data-option來傳遞一些參數(shù) --> <div class="js-signature" data-width="600" data-height="200" data-border="1px solid #1ABC9C" data-background="#16A085" data-line-color="#fff" data-auto-fit="true"> </div> <!-- 創(chuàng)建兩個操作按鈕,分別用于清空畫板和保存簽名 --> <button id="clearBtn" onclick="clearCanvas();">Clear Canvas</button> <button id="saveBtn" onclick="saveSignature();" disabled>Save Signature</button> <!-- 可以使用一個空的<div>來顯示保存的簽名圖片 --> <div id="signature"></div>
初始化插件
//頁面加載完畢之后使用下面的方法來初始化該簽名插件 $(document).on('ready', function() { $('.js-signature').jqSignature(); }); function clearCanvas() { $('#signature').html('<p><em>Your signature will appear here when you click "Save Signature"</em></p>'); $('.js-signature').jqSignature('clearCanvas'); $('#saveBtn').attr('disabled', true); } function saveSignature() { $('#signature').empty(); var dataUrl = $('.js-signature').jqSignature('getDataURL'); var img = $('<img>').attr('src', dataUrl); $('#signature').append($('<p>').text("Here's your signature:")); $('#signature').append(img); } $('.js-signature').on('jq.signature.changed', function() { $('#saveBtn').attr('disabled', false); });
配置參數(shù)
下面是該簽名插件的一些可用參數(shù),這些參數(shù)可以同時在data-attributes上使用:
參數(shù) | 描述 | Data Attribute | 示例 |
Width | 簽名canvas的寬度,單位像素,默認(rèn)值300 | data-width="600" | $().jqSignature({width: 600}); |
Height | 簽名canvas的高度,單位像素,默認(rèn)值100 | data-height="200" | $().jqSignature({height: 200}); |
Border | 簽名canvas的邊框CSS樣式。默認(rèn)為'1px solid #AAAAAA' | data-border="1px solid red" | $().jqSignature({border: '1px solid red'}); |
Background | 簽名canvas的背景顏色,默認(rèn)值為'#FFFFFF' | data-background="#EEEEEE" | $().jqSignature({background: '#EEEEEE'}); |
Line Color | 簽名的顏色。默認(rèn)值為#222222' | data-line-color="#ABCDEF" | $().jqSignature({lineColor: '#ABCDEF'}); |
Line Width | 簽名的線寬,單位像素,默認(rèn)值為1 | data-line-width="2" | $().jqSignature({lineWidth: 2}); |
Auto Fit | 使canvas占滿父元素的寬度,默認(rèn)值false | data-auto-fit="true" | $().jqSignature({autoFit: true}); |
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
JS中的hasOwnProperty()和isPrototypeOf()屬性實例詳解
hasOwnProperty()和isPrototypeOf()這兩個屬性都是Object.prototype所提供:Object.prototype.hasOwnProperty()和Object.prototype.isPropertyOf(),下面給大家介紹這兩個屬性的方法和使用,一起看下吧2016-08-08詳解將微信小程序接口Promise化并使用async函數(shù)
這篇文章主要介紹了詳解將微信小程序接口Promise化并使用async函數(shù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08如何在JavaScript實現(xiàn)Blob文件流下載
在JavaScript中可以使用瀏覽器提供的Blob對象和URL.createObjectURL()方法來實現(xiàn)文件流下載,這篇文章主要給大家介紹了關(guān)于如何在JavaScript實現(xiàn)Blob文件流下載的相關(guān)資料,需要的朋友可以參考下2024-05-05