SVG イメージをラスター イメージに変換しようとしています。形式は問題ありませんが、png または jpg が適しています。
私はjSignatureを使用してこれを達成しようとしています。jSignature の API はクリックしませんが、署名を描画して<img src="data:" />
タグに投稿できるようになりました。
私はこの問題について議論しているSOの他のスレッドを読んでいて、このアプローチを試みてきました。ただし、コンソールから「オブジェクト [オブジェクト オブジェクト] にはメソッド 'getContext' がありません」というエラーが表示され続けます。
これを PHP を使用してデータベースに渡します。
<!DOCTYPE html>
<html>
<head>
<title></title>
<link rel="stylesheet" type="text/css" href="sigStyle.css">
<script type="text/javascript" src="jquery-1.7.2.min.js"></script>
<script type="text/javascript" src="jSignature.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
var sigdiv = $("#signature").jSignature({'UndoButton':true});
$("#lock").click(function(){
//Lock the canvas, stop user input
});
$("#save").click(function(){
var datapair = sigdiv.jSignature("getData", "svgbase64");
var i = new Image();
i.src = "data:" + datapair[0] + "," + datapair[1];
$(i).appendTo($("#outputSvg"));
});
$("#clear").click(function(){
sigdiv.jSignature("reset");
$("#outputSvg, #outputRaster").empty();
});
$("#raster").click(function(){
var canvas = $("canvas").getContext("2d");
var img = canvas.toDataURL("image/png");
$("#outputRaster").append('<img src="'+img+'"/>');
});
})
</script>
</head>
<body>
<div id="signature"></div>
<br />
<button id="lock">Lock</button>
<button id="save">Save</button>
<button id="clear">Clear</button>
<button id="raster">Raster</button>
<br /><br />
<fieldset id="outputSvg" style="float:left">
<legend>SVG</legend>
</fieldset>
<fieldset id="outputRaster" style="float:left">
<legend>Raster</legend>
</fieldset>
</body>
</html>
ヘルプ、アドバイス、ヒントをいただければ幸いです。ありがとう!