- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
第
C#结合JavaScript实现手写板签名效果
mousePressed=true;
Draw(event.pageX-this.offsetLeft,event.pageY-this.offsetTop,false);
c.onmousemove=function(event){
if(mousePressed){
Draw(event.pageX-this.offsetLeft,event.pageY-this.offsetTop,true);
c.onmouseup=function(event){
mousePressed=false;
functionDraw(x,y,isDown){
if(isDown){
ctx.beginPath();
ctx.strokeStyle=selected2;
ctx.lineWidth=selected1;
ctx.lineJoin=round;
ctx.moveTo(lastX,lastY);
ctx.lineTo(x,y);
ctx.closePath();
ctx.stroke();
lastX=x;lastY=y;
functionclearArea(){
ctx.setTransform(1,0,0,1,0,0);
ctx.clearRect(0,0,ctx.canvas.width,ctx.canvas.height);
//清除签名图片
if(saveimgs.getElementsByTagName(span).length=1){
varclearImg=saveimgs.getElementsByTagName(span)[0];
saveimgs.removeChild(clearImg);
/script
/html
该页面需要引用jquery-3.3.1.min.js
前端引用
前端页面除嵌入手写功能页面外,iframe的父窗口需要放置两个元素,一个用于存储手写提交后的Base64数据的Asp.net服务器按钮文本框元素,另一个是用于模拟调用服务器事件的Asp.net服务器按钮元素。
引用代码如下:
div
iframewidth=520height=350id=hwrunat=serverscrolling=noframeborder=0src=/cc/module/hw/hw.aspx/iframe
asp:TextBoxID=pbase64TextMode=MultiLinerunat=server/asp:TextBox
asp:buttonID=phwOnClientClick=waittip()text=后台处理runat=server/
/div
后端处理
手写功能中的提交执行代码将调用如下:
window.parent.document.getElementById(pbase64).value=image;
window.parent.document.getElementById(phw).click();
其中pbase64和phw控件为服务器控件,可直接模拟调用phw按钮的服务器click,在这之前其还可以自动处理OnClientClick事件以显示等待界面。请注意waittip()执行了一段javascript脚本,如下:
functionwaittip(){
layer.open({type:2,shadeClose:false,content:正在分析,请稍候...});
这其中引入了Layer弹出层技术,关于Layer弹层组件请参照我的文章《改造layer弹层移动版组件》
这是调用服务器Click的事件处理代码,将上传的Base64图片转为两种格式的图片文件(PNG和JPEG)。代码如下:
protectedvoidphw_Click(objectsender,EventArgse)
stringmtfilename=d:\\hw_+System.Guid.NewGuid().ToString()+.png;
stringmtfilename2=d:\\hw_+S
文档评论(0)