A electronic signature component by Vue.js
name type default description sigOptionw,h need units,like 100px or 100%
Object
{penColor:"rgb(0, 0, 0)", backgroundColor:"rgb(255,255,255)"} penColor, backgroundColor w String
"100%" parent container width h String
"100%" parent container height clearOnResize Boolean
false Canvas is cleared on window resize waterMark Object
{} check Usage addWaterMark disabled Boolean
false disabled defaultUrl String
"" you want show image by default name params description save ()/("image/jpeg")/("image/svg+xml") save image as PNG/JPEG/SVG clear clear canvas isEmpty Returns true if canvas is empty, otherwise returns false undo remove the last dot or line addWaterMark {} // check Usage addWaterMark addWaterMark fromDataURL (url) Draws signature image from data URL.
The components emits the following events:
beginStroke
- Triggered before stroke begins.
endStroke
- Triggered after stroke ends.
beforeUpdateStroke
- Triggered before stroke update.
afterUpdateStroke
- Triggered after stroke update.
npm install vue-signature
A.vue
<template> <div id="app"> <vueSignature ref="signature" :sigOption="option" :w="'800px'" :h="'400px'" :disabled="disabled" :defaultUrl="dataUrl" ></vueSignature> <vueSignature ref="signature1" :sigOption="option"></vueSignature> <button @click="save">Save</button> <button @click="clear">Clear</button> <button @click="undo">Undo</button> <button @click="addWaterMark">addWaterMark</button> <button @click="handleDisabled">disabled</button> </div> </template> <script> import vueSignature from "vue-signature"; export default { name: "app", components: { vueSignature, }, data() { return { option: { penColor: "rgb(0, 0, 0)", backgroundColor: "rgb(255,255,255)", }, disabled: false, dataUrl: "https://avatars2.githubusercontent.com/u/17644818?s=460&v=4", }; }, methods: { save() { var _this = this; var png = _this.$refs.signature.save(); var jpeg = _this.$refs.signature.save("image/jpeg"); var svg = _this.$refs.signature.save("image/svg+xml"); console.log(png); console.log(jpeg); console.log(svg); }, clear() { var _this = this; _this.$refs.signature.clear(); }, undo() { var _this = this; _this.$refs.signature.undo(); }, addWaterMark() { var _this = this; _this.$refs.signature.addWaterMark({ text: "mark text", // watermark text, > default '' font: "20px Arial", // mark font, > default '20px sans-serif' style: "all", // fillText and strokeText, 'all'/'stroke'/'fill', > default 'fill fillStyle: "red", // fillcolor, > default '#333' strokeStyle: "blue", // strokecolor, > default '#333' x: 100, // fill positionX, > default 20 y: 200, // fill positionY, > default 20 sx: 100, // stroke positionX, > default 40 sy: 200, // stroke positionY, > default 40 }); }, fromDataURL(url) { var _this = this; _this.$refs.signature.fromDataURL("..."); }, handleDisabled() { var _this = this; _this.disabled = !_this.disabled; }, }, }; </script>
Released under the MIT License.
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4