Flash の線描画機能については、以前にも Flash の action スクリプトを使用して作成したことがあると思いますが、Flash はすでに古い技術であることを考慮して、
html5 の action スクリプトの使用方法を紹介します。 canvasタグと
javascriptを組み合わせて描画ボード機能を実装しています。
<script src="http://www.php.cn/static/home/js/jquery.min.js"></script> <canvas id="paintcanvas" width="600" height="700"></canvas> <script> var paint; var clickX=[]; var clickY=[]; var clickDrag=[]; function addClick(x,y,dragging) { clickX.push(x); clickY.push(y); clickDrag.push(dragging); } function redraw() { paintcanvas.strokeStyle = "#df4b26"; paintcanvas.lineJoin = "round"; paintcanvas.lineWidth = 5; for(var i=0; i < clickX.length; i++) { paintcanvas.beginPath(); if(clickDrag[i] && i){//当是拖动而且i!=0时,从上一个点开始画线。 paintcanvas.moveTo(clickX[i-1], clickY[i-1]); }else{ paintcanvas.moveTo(clickX[i]-1, clickY[i]); } paintcanvas.lineTo(clickX[i], clickY[i]); paintcanvas.closePath(); paintcanvas.stroke(); } } paintcanvas=$('#paintcanvas')[0].getContext("2d"); $('#paintcanvas').mousedown(function(e){ var mouseX=e.pageX-this.offsetLeft; var mouseY=e.pageY-this.offsetTop; paint=true; addClick(e.pageX-this.offsetLeft,e.pageY-this.offsetTop); redraw(); }); $('#paintcanvas').mousemove(function(e){ if(paint){ addClick(e.pageX-this.offsetLeft,e.pageY-this.offsetTop,true); redraw(); } }); $('#paintcanvas').mouseup(function(e){ paint = false; }); $('#paintcanvas').mouseleave(function(e){ paint = false; }); </script>
このうち、mousedown、mousemove、mouseup、mouseleaveなどにより線描画機能が実装されています。 jsイベント。
この記事はphp中国語ウェブサイトから提供されています
元のアドレス: http://www.php.cn/js-tutorial-374130.html
転載しないでください~~~~
以上がjsはキャンバスを介してブラシ関数のメモを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。