この記事では、お絵かきボード/サインボード機能を実現するためのJSキャンバスの具体的なコードを参考までに共有します。具体的な内容は次のとおりです。 序文 一般的な電子教室の電子黒板。 この記事の特徴: ネイティブJS 最小限のコード例 <!DOCTYPE html> <html lang="ja"> <ヘッド> <メタ文字セット="UTF-8"> <meta http-equiv="X-UA-compatible" content="IE=edge"> <meta name="viewport" content="width=デバイス幅、初期スケール=1.0"> <title>ドキュメント</title> </head> <本文> <キャンバスid="キャンバス"></キャンバス> <スクリプト> c = document.getElementById('canvas'); c.width = ウィンドウの内側の幅; c.height = ウィンドウの内側の高さ; ctx = c.getContext('2d') とします。 // 黒板を1枚描く ctx.fillStyle = "黒"; ctx.fillRect(0,0,600,300); // フラグを押す let onoff = false, 古いx = -10、 古い = -10; // 色を設定します let linecolor = "white"; // 線の幅を設定する let linw = 4; // マウスイベントを追加 // 押す c.addEventListener('mousedown', event => { オンオフ = true; // Position - 10 は位置を修正し、描画をマウス ポインターの上部に配置します。oldx = event.pageX - 10; 古い = イベント.ページY - 10; }、間違い); // 移動 c.addEventListener('mousemove', event => { if(onoff == true){ newx = event.pageX - 10 とします。 newy = イベント.pageY - 10; // 描画 ctx.beginPath(); ctx.moveTo(oldx,oldy); ctx.lineTo(newx,newy); ctx.strokeStyle = 線の色; ctx.lineWidth = linw; ctx.lineCap = "丸い"; ctx.stroke(); // 移動するたびに座標位置を更新します。oldx = newx、 古いもの = 新しいもの; } }、 真実); // ポップアップ c.addEventListener('mouseup', ()=> { オンオフ = false; }、間違い); </スクリプト> </本文> </html> 結果 コードの説明 アイデア 1. マウスを押して描画を開始します。マウスダウンイベント。 コードの説明 全体的な考え方は次のとおりです。マウスを押して移動スイッチをトリガーし、移動後に線の記録を開始します (移動後の座標 - 移動前の座標を使用して線を描画します)。各移動によって古い座標が更新されます。マウスを離した後、移動スイッチを離します。 1. 描画を移動する効果はマウスが押されたときにのみ発動されるため、状態判定を追加する必要があります。 カプセル化モジュール <キャンバスid="キャンバス"></キャンバス> <スクリプト> クラス Board{ コンストラクタ(canvasName = 'canvas', data = new Map([ ["オンオフ", false], ["古いx", -10], ["古い", -10], ["fillStyle", "黒"], ["線の色", "白"], ["線幅", 4], ["lineCap", "round"], ["キャンバス幅", ウィンドウの内側の幅], ["キャンバスの高さ", window.innerHeight] ])){ // this.data = データ; this.c = document.getElementById(キャンバス名); this.ctx = this.c.getContext('2d'); onoff をデータとして取得します。 this.oldx = data.get("oldx"); this.oldy = data.get("oldy"); 行の色を取得します。 行幅を取得します。 行頭文字をデータとして取得します。 this.c.width = data.get("キャンバス幅"); this.c.height = data.get("キャンバス高さ"); this.ctx.fillStyle = data.get("fillStyle"); ctx の塗りつぶし矩形を 0,0,600,300 に設定します。 } イベント操作(){ // マウスイベントを追加 // 押す this.c.addEventListener('mousedown', event => { this.onoff = true; // Position - 10 は位置を修正し、描画をマウス ポインターの上部に配置します。this.oldx = event.pageX - 10; this.oldy = イベント.pageY - 10; }、間違い); // 移動 this.c.addEventListener('mousemove', event => { if(this.onoff == true){ newx = event.pageX - 10 とします。 newy = イベント.pageY - 10; // 描画 this.ctx.beginPath(); this.ctx.moveTo(this.oldx,this.oldy); this.ctx.lineTo(newx,newy); this.ctx.strokeStyle = this.lineColor; this.ctx.lineWidth は、 this.lineWidth の略です。 this.ctx.lineCap = this.lineCap; this.ctx.stroke(); // 移動するたびに座標位置を更新します。this.oldx = newx, this.oldy = newy; } }、 真実); // ポップアップ this.c.addEventListener('mouseup', ()=> { this.onoff = false; }、間違い); } } ボードを新しいボード()にします。 ボードイベント操作(); </スクリプト> 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: MySQLデータベースを誤って削除した後にデータを回復するための手順
>>: テキストまたはJSONを返すようにnginxを設定する方法
DockerイメージからDockerfileを取得する docker 履歴 --format {{....
Win10 のインストール (すでにインストールされている場合はスキップしてください) win10...
目次1. はじめに2. 出力情報の説明3. netstatの共通パラメータ4. netstatネット...
関数を記述できます。主に正規表現を使用して判断を行います。入力文字が空の場合は、「-」を使用して置き...
実験コードは次のとおりです。 </head> <body> <div ...
目次JavaScriptでは、 forループを記述する一般的な方法がいくつかあります。最初の、そして...
プロジェクト ページの作成中に、子要素が親要素の透明度を継承するという問題に遭遇しました。多くのドキ...
みなさんこんにちは。今日は、純粋な CSS を使用して Google マテリアル デザインのテキスト...
Docker イメージのダウンロードが停止したり、遅すぎたりするネットでいろいろな方法を検索しました...
目次エラーメッセージ原因エラーのデモンストレーション回避策方法1方法2方法3エラーメッセージ現在の場...
Oracle、DB2、SQL Server などの他の大規模データベースと比較すると、MySQL に...
jvm.options ファイルを elasticsearch 構成に追加し、スタック サイズを変更...
注意事項1. まず、mysql インストール ディレクトリに次の内容の my.ini ファイルを作成...
目次1. はじめに2. コードの実装2.1 目的分析2.2 実装プロセス2.2.1 エントリーコード...
rm コマンドrm コマンドは、ファイルを削除するときによく使用されるコマンドです。ファイルまたはデ...