当前位置: 首页 > Web前端 > HTML5

H5基于canvas实现电子签名并生成PDF文档

时间:2023-04-05 01:19:40 HTML5

鍓嶈█鐢靛瓙绛惧悕涓€鑸槸鎸囬€氳繃鎶€鏈墜娈靛湪鐢靛瓙鏂囨。涓婂姞涓婄數瀛愮鍚嶏紝鍏朵綔鐢ㄧ被浼间簬鍦ㄧ焊璐ㄥ悎鍚屼笂鎵嬪啓绛惧悕鎴栧姞鐩栧叕绔犮€傚敖绠$數瀛愮鍚嶇殑鍚堟硶鎬у骞存潵涓€鐩村鍙楄川鐤戯紝浣嗗叾骞挎硾搴旂敤浜庝紒涓氬伐浣滄祦瀹℃壒銆侀個璇峰嚱銆佹枃浠朵繚瀛樼瓑鍦烘櫙銆傛渶杩戝仛椤圭洰锛岄渶瑕佽繖鏍风殑鎵嬪啓绛惧悕锛岀敓鎴怭DF鏂囦欢銆傚疄鐜版€濊矾浣跨敤canvas瀹炵幇鎵嬪啓绛惧悕鐨勫姛鑳斤紝鐒跺悗灏哻anvas杞垚鍥剧墖绮樿创鍦ㄧ鍚嶇殑浣嶇疆锛涗娇鐢╤tml2canvas鎻掍欢灏嗛渶瑕佺敓鎴愭枃妗g殑鏁翠釜dom鍖哄煙杞崲涓哄ぇ鍥撅紱浣跨敤JsPDF鎻掍欢灏嗕笂鍥剧敓鎴怭DF鏂囨。锛涘湪鏂囦欢鍐呭杈冨鐨勬儏鍐典笅锛岄渶瑕佸悎鐞嗛€夋嫨椤甸潰浣嶇疆锛涚敓鎴愮鍚?.鍦╰sx涓畾涔塩anvas娉ㄦ剰锛欳anvas鐨勫楂樺繀椤讳娇鐢╥nline鏉ュ畾涔夋牱寮忥紝鍥犱负Canvas鏍囩鏈夎嚜宸辩殑榛樿瀹藉害鍜岄珮搴?00px脳150px銆傚畠鐨勫唴鑱旀牱寮忓畾涔夌殑瀹介珮鏄粯鍥惧尯锛堢敾甯冿級鐨勫疄闄呭楂橈紝缁樺埗鐨勫浘褰㈤兘鍦ㄨ繖涓婇潰銆傚鏋滄牱寮忓閾炬枃浠朵腑瀹氫箟浜嗗楂橈紝閭d箞瀹介珮灏辨槸娴忚鍣ㄤ腑娓叉煋鐨凜anvas鐨勯珮瀹姐€傚鏋滄病鏈夊湪Canvas涓洿鎺ュ畾涔夊楂樻垨鑰呮暟鍊间笉姝g‘锛屽垯浼氳缃负榛樿鍊納width:300px,height:150px}銆傚洜姝わ紝濡傛灉浣犺缃甤anvas{width:200px;height:200px;}鍦ㄥ閮ㄩ摼鎺ユ枃浠朵腑鐨勬牱寮忎腑锛屼絾鏄笉鐩存帴鍦ㄧ敾甯冧笂瀹氫箟鐢诲竷瀹介珮锛岄偅涔堜綘姝ゆ椂杈撳嚭鐨刢anvas.height鍊艰繕鏄?50锛宑anvas.width鍊艰繕鏄?00锛屼篃灏辨槸鍦?00脳200鐨勫尯鍩熸覆鏌撲竴涓?50脳300鐨勭敾甯冿紝鎵€浠ュ浘鐗囦細琚媺浼稿彉褰€?.瀹氫箟绛惧悕鍑芥暟const鍐欐硶=(beginX:number,beginY:number,stopX:number,stopY:number,ctx:any,)=>{ctx.beginPath();//寮€鍚柊璺緞ctx.globalAlpha=1;//璁剧疆鍥剧墖鐨勯€忔槑搴tx.lineWidth=3;//璁剧疆绾垮ctx.strokeStyle='red';//璁剧疆璺緞棰滆壊ctx.moveTo(beginX,beginY);//浠?beginX,beginY)杩欎釜鍧愭爣鐐瑰紑濮嬬粯鍒禼tx.lineTo(stopX,stopY);//瀹氫箟浠?beginX,beginY)鍒?stopX,stopY)鐨勭嚎锛堟鏂规硶涓嶄細鍒涘缓绾匡級ctx.closePath();//鍒涘缓璺緞ctx.stroke();//瀹為檯缁樺埗鐢眒oveTo()鍜宭ineTo()鏂规硶瀹氫箟鐨勮矾寰勩€傞粯璁ら鑹蹭负榛戣壊銆倉;3銆傛敞鍐岀洃鍚簨浠秎etbeginX:number,beginY:number;甯搁噺鐢诲竷锛欻TMLCanvasElement=canvasDom.current锛沜onstctx=canvas.getContext('2d');ctx.fillStyle='#fff';ctx.fillRect(0,0,canvas.width,canvas.height);canvas.addEventListener('touchstart',function(event:any){event.preventDefault();//鍦ㄧ敾甯冧笂绛惧悕鏃堕槻姝㈤〉闈㈡粴鍔╞eginX=event.touches[0].clientX-this.offsetLeft;beginY=event.touches[0].pageY-this.offsetTop;});canvas.addEventListener('touchmove',(event:any)=>{event.preventDefault();//鍦ㄧ敾甯冧笂绛惧悕鏃堕槻姝㈤〉闈㈡粴鍔╡vent=event.touches[0];letstopX=event.clientX-canvas.offsetLeft;letstopY=event.pageY-canvas.offsetTop;writing(beginX,beginY,stopX,stopY,ctx);beginX=stopX;//杩欎竴姝ュ緢鍏抽敭锛岃捣鐐归渶瑕佷笉鏂洿鏂帮紝鍚﹀垯缁樺埗灏勭嚎绨嘼eginY=stopY;});娉ㄦ剰锛氭敞鍐屸€渢ouchstart鈥濆拰鈥渢ouchmove鈥濅簨浠讹紝闇€瑕侀樆姝㈤粯璁や簨浠讹紝鍚﹀垯椤甸潰浼氶殢鐫€鎵嬪娍涓婁笅婊戝姩銆傜Щ鍔ㄧ粓绔笂鐨勬瘡涓Е鎽镐簨浠跺璞¢兘鍖呭惈灞炴€ouches锛岀敤浜庢弿杩板睆骞曚笂鎵€鏈夋墜鎸囩殑鍒楄〃銆傝幏鍙栧綋鍓嶄簨浠跺璞★紝鎴戜滑涔犳儻浣跨敤event=event.touches[0]锛岃€屽湪PC绔垯涓嶉渶瑕佽繖鏍峰仛銆俹ffsetLeft鍊煎拰offsetTop鍊间笌鐖跺厓绱犳棤鍏筹紝鑰屾槸涓庡叾涓婂眰瀹氫綅鍏冪礌鏈夊叧锛堥櫎position:static澶栫殑鎵€鏈夊畾浣嶏紝濡俧ixed銆乺elative銆乤bsolute鍏冪礌锛夈€傚鏋滀笂灞傚畾浣嶅厓绱犻櫎浜唒osition:staice娌℃湁鍏朵粬瀹氫綅锛屽亸绉婚噺鏄浉瀵逛簬body鐨勩€傞渶瑕佹槑纭竴涓嬬Щ鍔ㄧ浜嬩欢瀵硅薄鐨勫嚑涓睘鎬э紝鈴琧lientX/clientY锛氳Е鎽镐綅缃窛绂诲綋鍓峛ody鍙鍖哄煙鐨剎,y鍧愭爣锛沺ageX/pageY锛氬浜庢暣涓〉闈紝瑙︽懜浣嶇疆璺濈body宸︿笂瑙掔殑x锛寉鍧愭爣锛寉鍧愭爣锛屽寘鎷瑂crollTop鍜宻crollLeft鐨勫€硷紱screenX/screenY锛氳Е鎽镐綅缃笌鏄剧ず灞忓乏渚у拰椤堕儴涔嬮棿鐨剎銆亂璺濈銆傛墍浠ュ湪鑾峰彇缁堢偣鍧愭爣鐨勬椂鍊欙紝濡傛灉褰撳墠椤甸潰娌℃湁婊氬姩鏉★紝鐢╟lientY鍜宲ageY鏉ヨ绠楀尯鍒笉澶с€傚鏋滈〉闈㈡瘮杈冮暱锛屾湁婊氬姩鏉★紝閭d箞灏卞繀椤荤敤pageY鏉ヨ绠椼€俢lientX涔熸槸涓€鏍凤紝浣嗘槸绉诲姩绔í鍚戞粴鍔ㄧ殑鍦烘櫙閫氬父涓嶅锛屽彲浠ョ敤clientX鏉ヨ绠椼€傚湪绛惧悕锛坱ouchmove锛夌殑杩囩▼涓紝鎴戜滑闇€瑕佷笉鏂殑鏇存柊璧风偣浣嶇疆锛屽惁鍒欑敾鍑烘潵浼氭槸杩欐牱鐨勬妸绾挎鎯宠薄鎴愪竴鏉$煭灏忕殑绾挎棣栧熬鐩告帴銆傛墍浠ユ垜涓€鐩磋涓虹紪绋嬪綊鏍圭粨搴曟槸鑰冮獙涓€涓汉鐨勬暟瀛﹁兘鍔涳紝鑰屾暟瀛﹀彲浠ュ湪浜や笌骞躲€侀€昏緫鎬濈淮銆佺畻娉曚腑鐪嬪埌銆傛渶鍚庣敓鎴愮鍚嶅涓嬶細鐢熸垚PDF鏂囨。html2canvas鏄竴涓皢HTML浠g爜杞垚Canvas鐨勬彃浠讹紝鎵€浠ラ渶瑕佺敤div鍖呰9瑕佹墦鍗扮殑鍐呭鍖哄煙锛岃幏鍙杁om鑺傜偣銆俬tml2Canvas(dom,{allowTaint:true,width:dom.offsetWidth,//璁剧疆鑾峰彇鐨勭敾甯冨搴eight:dom.offsetHeight,//璁剧疆鑾峰彇鐨勭敾甯冮珮搴:0,//椤甸潰姘村钩鏂瑰悜婊氬姩鐨勮窛绂粂:0,//椤甸潰鍦ㄥ瀭鐩存柟鍚戞粴鍔ㄧ殑璺濈})娉ㄦ剰锛氳繖閲岄渶瑕佽缃畐idth,height鍜寈,y锛屽惁鍒欏綋椤甸潰鍐呭鍙湁涓€椤垫椂娌℃湁闂锛屼絾鏄鏋滈〉闈㈠唴瀹规湁寰堝椤碉紝浼氬嚭鐜扮敓鎴愮殑鍥剧墖鍙湁涓€灏忛儴鍒嗘湁鍐呭鐨勭幇璞°€傞棶棰樺嚭鍦ㄨ繖涓厤缃弬鏁颁笂銆傚鏋滀笉璁剧疆瀹介珮锛屽垯榛樿鍙彇褰撳墠瑙嗗彛鐨勫唴瀹癸紝瓒呭嚭褰撳墠瑙嗗彛鐨勫叾浠栧唴瀹瑰皢琚涪寮冦€傝缃墦鍗板弬鏁帮細constprint=()=>{letdom:HTMLElement=pdfDom.current;html2Canvas(dom,{allowTaint:true,width:dom.offsetWidth,//璁剧疆鑾峰彇鐨勭敾甯冨搴eight:dom.offsetHeight,//璁剧疆鑾峰彇鐨勭敾甯冮珮搴:0,//椤甸潰姘村钩鏂瑰悜y婊氬姩璺濈:0,//椤甸潰鍨傜洿鏂瑰悜婊氬姩璺濈}).then((canvas:HTMLCanvasElement)=>{letcanvasWidth=canvas.width;letcanvasHeight=canvas.height;letpageHeight=(canvasWidth/592.28)*841.89;//涓€椤礎4pdf鍙互鏄剧ず鐨勭敾甯冮珮搴etimgWidth=595.28;//璁剧疆鍥剧墖鐨勫搴︾瓑浜嶢4绾哥殑瀹藉害letimgHeight=(592.28/canvasWidth)*canvasHeight;//绛夋瘮渚嬭浆鎹负A4绾哥殑楂樺害lettotalHeight=imgHeight;//寰呮墦鍗板浘鐗囨€婚珮搴︼紝鍒濆鐘舵€佺瓑浜庡浘鐗囬珮搴etpageData=canvas.toDataURL('image/png',1.0);letPDF=newJsPDF('p','pt','a4',true);if(totalHeight0){PDF.addImage(pageData,'JPEG',0,top,imgWidth,imgHeight);//浠庡浘鍍忛《閮ㄥ紑濮嬫墦鍗板埌椤堕儴浣嶇疆totalHeight-=pageHeight;椤堕儴-=841.89锛沬f(totalHeight>0){PDF.addPage();}}}PDF.save('test.pdf');});};閫夋嫨鍒嗛〉浣嶇疆鎸夌収涓婇潰鐨勬楠ょ敓鎴愪竴涓狿DF鏂囨。锛屼絾鏄綋PDF鐨勯〉闈㈠緢澶氱殑鏃跺€欙紝灏变細鍑虹幇杩欐牱鐨勯棶棰樷彫鍙互鐪嬪埌锛屽垎椤电殑鏃跺€欐枃鏈鎳掓儼鎴柇浜嗐€傝繖鏄剧劧涓嶆槸鎴戜滑鎯宠鐪嬪埌鐨勬晥鏋溿€傚浣曡В鍐宠繖涓棶棰樺憿锛燄煠斿鏋淧DF鏂囨。鐨勯〉鏁拌緝灏戯紝鍙互鍦ㄥ紑鍙戞祴璇曠殑鏃跺€欏湪鍒嗛〉鐨勫湴鏂归鍏堟彃鍏ヤ竴涓猵adding锛屼篃灏辨槸鎻愬墠棰勭暀鍒嗛〉鐨勪綅缃€侾DF鏂囨。涓殑椤垫暟寰堝ぇ銆傚湪杩欑鎯呭喌涓嬶紝浣滆€呭皾璇曢亶鍘嗚鎵撳嵃鐨刣om鑺傜偣瀛愯妭鐐癸紝灏嗘瘡椤靛彲浠ユ墦鍗扮殑dom鑺傜偣鐨勯珮搴﹀姞璧锋潵锛屽鏋滆秴杩囬〉闈㈠彲浠ユ壙杞界殑鏈€澶ч珮搴︼紝鍒欏湪鏈€鍚庢坊鍔爌adding鑺傜偣锛屾墦鍗板悗鎭㈠鏍峰紡銆傝繖绉嶆柟寮忔槸闈炲父鑰楁€ц兘鐨勶紝鍥犱负闇€瑕佽绠楁瘡涓猟om鑺傜偣鐨勯珮搴︼紝杩橀渶瑕侀〉闈笂鐨刣om鍏冪礌鐨勭矑搴︽洿缁嗐€備笉鐒朵竴椤典細鍑虹幇涓€澶х墖绌虹櫧锛屽畬鍏ㄦ棤娉曟ā鎷焪ord鐢熸垚pdf鐨勬晥鏋溿€傛墍浠ヤ笉鍐嶈璁恒€傚鏋滄湁璇昏€呮湁鏇村ソ鐨勮В鏀炬柟妗堬紝杩樿涓嶅悵璧愭暀锛岃阿璋鉂わ笍