您好:我正在使用 signaturePad [ http://thomasjbradley.ca/lab/signature-pad/
] 并在 codeIgniter 2 中创建了一个简短的 Web 表单,位于此处:[ http://gentest.lfwebz.com/crd/open_form3
],需要用户实际签署表单。我还安装了 mPDF 和 domPDF,我让它们工作,有点,但不是我想要的方式。
我想要的功能是:用户使用上面提到的 signPad 打开 Web 表单,填写,签名。然后我想单击一个按钮,该按钮运行 mPDF/domPDF 并捕获页面,当然还有嵌入的签名。
当我运行 mpdf/domPDF 并将包含表单的视图传递给它时,我想我已经发现它只是获取了一个新视图,一个没有签名的视图,但是缺少表单的几个部分。所以在四处挖掘之后,我想我已经确定我必须使用 signaturePad 的图像转换 - 这就是我卡住的地方。我有代码,使用这里的参考:签名板和 dompdf,但它不起作用。
如果您在此处访问我的页面:http://gentest.lfwebz.com/crd/open_form3
,请在页面上签名,然后单击“我接受”按钮
这是我的看法
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" type="text/css" href="../assets/jquery.signaturepad.css" media="screen">
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.1/jquery.min.js"></script>
<script type="text/javascript" src="../jquery.signaturepad.min.js"></script>
</head>
<body>
<?php echo base_url(); ?>
<form method="post" action="<?php echo base_url(); ?>pdf.php" class="sigPad">
<label for="name">Print your name</label>
<input type="text" name="name" id="name" class="name">
<p class="typeItDesc">Review your signature</p>
<p class="drawItDesc">Draw your signature</p>
<ul class="sigNav">
<li class="typeIt"><a href="#type-it" class="current">Type It</a></li>
<li class="drawIt"><a href="#draw-it">Draw It</a></li>
<li class="clearButton"><a href="#clear">Clear</a></li>
</ul>
<div class="sig sigWrapper">
<div class="typed"></div>
<canvas class="pad" width="198" height="55"></canvas>
<input type="text" name="output" class="output">
<input type="text" name="imgOutput" class="imgOutput">
</div>
<br /><br /><br />
<button type="submit">I accept the terms of this agreement.</button>
</form>
<script>
var sig;
$( document ).ready( function ( ) {
sig = $('.sigPad').signaturePad({defaultAction:'drawIt'});
} );
$( '.sigPad' ).submit( function ( evt ) {
$( '.imgOutput' ).val( sig.getSignatureImage( ) );
} );
</script>
</body>
</html>
这是上面提到的控制器或pdf.php:
<?php
if(isset($_POST['imgOutput'])){$img_output = $_POST['imgOutput'];}
echo "position 1";
$bse = preg_replace('#^data:image/[^;]+;base64,#', '', $img_output );
echo "position 2";
echo $bse;
if ( base64_encode( base64_decode( $bse) ) === $bse ) {
require_once 'dompdf/dompdf_config.inc.php';
$html = '<!DOCTYPE html><html><head></head><body><p>Your signature:</p><br /><img src="'. $img_output .'"></body></html>';
$dompdf = new DOMPDF;
$dompdf->load_html( $html );
$dompdf->render( );
$dompdf->stream("test.pdf");
}
else{
echo ("ERROR !");
}
?>
我在这里想念什么?请有人能指出我正确的方向吗?
如果您需要更多信息,请告诉我。
先感谢您。