Ionic

ionic3实现签名,并上传数据库

2019-05-31  本文已影响0人  竹子_331a

1.下载组件
npm install angular2-signaturepad --save
2.app.module.ts中引入插件:
在所需的页面的module.ts文件引入组件(如下图),


image.png

3、在要使用签名功能的页面使用:
在signature.html中:

<ion-header>

  <ion-navbar color="primary">
    <ion-title>
      手写意见/签名
    </ion-title>
  </ion-navbar>

</ion-header>


<ion-content>
  <div class="normal-page">
    <div class="footer">
      <div class="right-sign">
        <span style="margin-left: 10px;">签名:</span><span style="float:right;margin-right: 10px;color:blue;" (click)='drawClear()'>清除</span>
        <signature-pad [options]="signaturePadOptions" id="signatureCanvas"></signature-pad>
      </div>
      <button ion-button icon-left [disabled]="startButtonStatus" [block]="true" color="primary" block
              (click)="signBack()">
        <ion-icon name="arrow-dropright"></ion-icon>提交
      </button>
    </div>
  </div>
</ion-content>

在signature.module.ts中引入:

import { NgModule } from '@angular/core';
import { IonicPageModule } from 'ionic-angular';
import { SignaturePage } from './signature';
import {SignaturePadModule} from 'angular2-signaturepad';

@NgModule({
  declarations: [
    SignaturePage,
  ],
  imports: [
    SignaturePadModule,
    IonicPageModule.forChild(SignaturePage),
  ],
})
export class SignaturePageModule {}

在signature.scss中
···
page-signature {
signature-pad {
canvas {
border: dashed 1px #cccccc;
width: 100%;
height: 120px;
}
}
}
···
在signature.ts中

import { Component, ViewChild } from '@angular/core';
import { IonicPage, NavController, NavParams } from 'ionic-angular';
import { SignaturePad } from 'angular2-signaturepad/signature-pad';//引入手写板

@IonicPage()
@Component({
  selector: 'page-signature',
  templateUrl: 'signature.html',
})
export class SignaturePage {

  @ViewChild(SignaturePad) public signaturePad: SignaturePad; //第二视图
  signatureImage: string; //定义类型
  signaturePadOptions: Object = {
    'minWidth': 2,
    'canvasWidth': 220,
    'canvasHeight': 120
  };
  constructor(public navCtrl: NavController, public navParams: NavParams) {
    console.log(this.navParams)
  }

  ionViewDidLoad() {
    console.log('ionViewDidLoad QuestionnairePage');
  }
  ngAfterViewInit() {
    this.signaturePad.clear();
    this.canvasResize();
  }
  // 清除模板
  drawClear() {
    this.signaturePad.clear();
  }
  canvasResize() {
    let canvas = document.querySelector('canvas');
    this.signaturePad.set('minWidth', 2);
    this.signaturePad.set('canvasWidth', canvas.offsetWidth);
    this.signaturePad.set('canvasHeight', canvas.offsetHeight);
  }

  // 完成生成图片
  /*drawComplete(sign) {
    this.signatureImage = this.signaturePad.toDataURL();
    console.log(this.signatureImage);
  }*/
  signBack(){
    let result=[];
    result.push({
      url:this.signatureImage = this.signaturePad.toDataURL("image/png")
    })
    this.navCtrl.pop().then(() => {
      this.navParams.get('callback2')(result);
    });
  }
}

4、这个界面专门签名的界面,还要上传,上传我在另外一个页面,关键代码如下

 let picUrl = that.signUrl.replace(/^data:image\/(png|jpg);base64,/, "")   //传递的BASE64图片必须把头去掉
            //console.log(that.signUrl);
            let params = new HttpParams()
              .set('processTodoDealwithMan',that.processDealwithMan)
              .set('mySuggestion',that.mySuggestion)
              .set('nextActivityJsonInfo',nextActivityInfo)
              .set('signPic',encodeURIComponent(picUrl))
              .set('loginFrom', 'app');
            let url=GlobalVariable.BASE_URL + 'pad.do?method=completeTask';
            let loading = this.loadingCtrl.create({
              content: '正在保存……'
            });
            loading.present();
            that.appService.POST(url,params,(res, error) => {
              if(res){
                loading.dismiss();
                let result=res['msg'];
                if(result=='Y'){
                  this.appService.alert("流程已成功处理!");
                  that.navCtrl.pop().then(() => {
                    let msg="Y";
                    this.navParams.get('callback')(msg);
                  });
                }else{
                  this.appService.alert("流程数据异常,请在电脑端处理!")
                }
              }
              if(error){
                loading.dismiss();
                console.log("PUT call in error");
              }
            });

关键代码解析:
1、let picUrl = that.signUrl.replace(/^, "") //传递的BASE64图片必须把头去掉,因为我们要将base64的图片转成文件进行存储
2、 .set('signPic',encodeURIComponent(picUrl))
base64里面有一些特殊字符,比如+,必须encode掉,否则系统默认会将+变成空格。还有一种办法是,在后端replace空格成+号,不过不是很推荐。

下面是后台代码:

   //base64字符串转化成图片  
    public static boolean GenerateImage(String imgStr, String serverPath,String fileName)  
    {   //对字节数组字符串进行Base64解码并生成图片  
        if (imgStr == null) //图像数据为空  
            return false;  
        BASE64Decoder decoder = new BASE64Decoder();  
        try   
        {  
            //Base64解码  
            byte[] b = decoder.decodeBuffer(imgStr);  
            for(int i=0;i<b.length;++i)  
            {  
                if(b[i]<0)  
                {//调整异常数据  
                    b[i]+=256;  
                }  
            }  
            //生成图片  
            String imgFilePath = serverPath+fileName; //新生成的图片  
            OutputStream out = new FileOutputStream(imgFilePath);      
            out.write(b);  
            out.flush();  
            out.close();  
            return true;  
        }   
        catch (Exception e)   
        {  
            return false;  
        }  
    } 
if(StringUtils.isNotBlank(signPic)){
            signPic=java.net.URLDecoder.decode(signPic,"UTF-8");
            System.out.println(signPic);
            String path = "attachment/ProcessAttachment/signImg/";
            String uuid = UUID.randomUUID().toString().replace("-", "").toLowerCase();
            Boolean hasUploadImg=AttachmentHelper.GenerateImage(signPic, serverPath,uuid+".png");
            if(hasUploadImg){
                processSuggest.setSuggest(path+uuid+".png");
                processSuggest.setSignType("2"); //代表签名
            }
            
        }else{
            processSuggest.setSuggest(mySuggestion);
            processSuggest.setSignType("1"); //代表输入
        }

OK,到此为止就行了,有问题下面提出来!

上一篇 下一篇

猜你喜欢

热点阅读