C#结合JavaScript实现手写板签名效果.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 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)

135****5541 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档