欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS canvas實現(xiàn)畫板和簽字板功能

 更新時間:2021年02月23日 12:05:23   作者:莫兮是我  
這篇文章主要為大家詳細(xì)介紹了JS canvas實現(xiàn)畫板和簽字板功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了JS canvas實現(xiàn)畫板/簽字板功能的具體代碼,供大家參考,具體內(nèi)容如下

前言

常見的電子教室里的電子黑板。

本文特點(diǎn):

原生JS
封裝好的模塊

最簡代碼樣例

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta http-equiv="X-UA-Compatible" content="IE=edge">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>Document</title>
</head>
<body>
 <canvas id="canvas"></canvas>
 <script>
 let c = document.getElementById('canvas');
 c.width = window.innerWidth;
 c.height = window.innerHeight;
 let ctx = c.getContext('2d');

 // draw one black board
 ctx.fillStyle = "black";
 ctx.fillRect(0,0,600,300);

 // 按下標(biāo)記
 let onoff = false,
  oldx = -10,
  oldy = -10;

 // 設(shè)置顏色
 let linecolor = "white";

 // 設(shè)置線寬
 let linw = 4;

 // 添加鼠標(biāo)事件
 // 按下
 c.addEventListener('mousedown', event => {
  onoff = true;
  // 位置 - 10是為了矯正位置,把繪圖放在鼠標(biāo)指針的頂端
  oldx = event.pageX - 10;
  oldy = event.pageY - 10;
 },false);
 // 移動
 c.addEventListener('mousemove', event => {
  if(onoff == true){
  let newx = event.pageX - 10,
   newy = event.pageY - 10;

  // 繪圖
  ctx.beginPath();
  ctx.moveTo(oldx,oldy);
  ctx.lineTo(newx,newy);
  ctx.strokeStyle = linecolor;
  ctx.lineWidth = linw;
  ctx.lineCap = "round";
  ctx.stroke();
  // 每次移動都要更新坐標(biāo)位置
  oldx = newx,
  oldy = newy;
  }
 }, true);
 // 彈起
 c.addEventListener('mouseup', ()=> {
  onoff = false;
 },false);
 </script>
</body>
</html>

結(jié)果展示

代碼講解

思路

1、鼠標(biāo)按下,開始描畫。鼠標(biāo)按下事件。
2、鼠標(biāo)彈起,結(jié)束描畫。鼠標(biāo)彈起事件。
3、鼠標(biāo)按下移動,路徑畫線。鼠標(biāo)移動事件。

代碼講解

整體思路:按下鼠標(biāo),觸發(fā)移動的開關(guān),移動后開始記錄線條(用移動后的坐標(biāo)-移動前的坐標(biāo),然后繪線),每次移動都會更新舊坐標(biāo)。松開鼠標(biāo)后,釋放移動開關(guān)。

1、只有在鼠標(biāo)按下,才會觸發(fā)移動繪圖的效果,所以需要增加一個狀態(tài)判斷。
2、因為鼠標(biāo)指針和實際位置有一個偏移量,所以在坐標(biāo)定位的時候,需要增加pagex-10從而使坐標(biāo)位于指針的尖端處。
3、每次移動都要更新坐標(biāo)位置,用小段的線段來模擬不規(guī)則的線。

封裝模塊

<canvas id="canvas"></canvas>
<script>
 class Board{
 constructor(canvasName = 'canvas', data = new Map([
  ["onoff", false],
  ["oldx", -10],
  ["oldy", -10],
  ["fillStyle", "black"],
  ["lineColor", "white"],
  ["lineWidth", 4],
  ["lineCap", "round"],
  ["canvasWidth", window.innerWidth],
  ["canvasHeight", window.innerHeight]
 ])){
  // this.data = data;
  this.c = document.getElementById(canvasName);
  this.ctx = this.c.getContext('2d');
  this.onoff = data.get("onoff");
  this.oldx = data.get("oldx");
  this.oldy = data.get("oldy");
  this.lineColor = data.get("lineColor");
  this.lineWidth = data.get("lineWidth");
  this.lineCap = data.get("lineCap");

  this.c.width = data.get("canvasWidth");
  this.c.height = data.get("canvasHeight");

  this.ctx.fillStyle = data.get("fillStyle");
  this.ctx.fillRect(0,0,600,300);
 }

 eventOperation(){
  // 添加鼠標(biāo)事件
  // 按下
  this.c.addEventListener('mousedown', event => {
  this.onoff = true;
  // 位置 - 10是為了矯正位置,把繪圖放在鼠標(biāo)指針的頂端
  this.oldx = event.pageX - 10;
  this.oldy = event.pageY - 10;
  },false);
  // 移動
  this.c.addEventListener('mousemove', event => {
  if(this.onoff == true){
   let newx = event.pageX - 10,
   newy = event.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();
   // 每次移動都要更新坐標(biāo)位置
   this.oldx = newx,
   this.oldy = newy;
  }
  }, true);
  // 彈起
  this.c.addEventListener('mouseup', ()=> {
  this.onoff = false;
  },false);
 }

 }

 let board = new Board();
 board.eventOperation();
</script>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • PHP中使用微秒計算腳本執(zhí)行時間例子

    PHP中使用微秒計算腳本執(zhí)行時間例子

    這篇文章主要介紹了PHP中使用微秒計算腳本執(zhí)行時間例子,本文先是講解了microtime函數(shù)的一些知識,然后給出了一個計算腳本運(yùn)行時間的類,需要的朋友可以參考下
    2014-11-11
  • JavaScript實現(xiàn)數(shù)組對象轉(zhuǎn)換為鍵值對的四種方式

    JavaScript實現(xiàn)數(shù)組對象轉(zhuǎn)換為鍵值對的四種方式

    本文探討了將包含 {icon: "abc", url: "123"} 形式對象的數(shù)組轉(zhuǎn)換為鍵值對形式的四種方法,并從實現(xiàn)方式的簡潔性、可讀性和性能角度進(jìn)行了分析比較,感興趣的朋友可以參考下
    2024-02-02
  • 老生常談JavaScript 函數(shù)表達(dá)式

    老生常談JavaScript 函數(shù)表達(dá)式

    下面小編就為大家?guī)硪黄仙U凧avaScript 函數(shù)表達(dá)式。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • JS值當(dāng)前DIV的ID值的代碼

    JS值當(dāng)前DIV的ID值的代碼

    JS值當(dāng)前DIV的ID值的代碼...
    2007-05-05
  • 一文帶你深入理解JavaScript中的時間處理

    一文帶你深入理解JavaScript中的時間處理

    在JavaScript中,處理時間和日期是常見任務(wù)之一,涉及到從用戶界面的日期選擇器到服務(wù)器上的時間戳,再到時間間隔的計算,本文將深入探討JavaScript中的時間處理,需要的朋友可以參考下
    2023-09-09
  • 在vs2010中調(diào)試javascript代碼方法

    在vs2010中調(diào)試javascript代碼方法

    只在IE瀏覽器中測試成功了,在谷歌瀏覽中沒有測試成功,其他瀏覽器沒有測試。
    2011-02-02
  • JavaScript實現(xiàn)簡單的倒計時效果

    JavaScript實現(xiàn)簡單的倒計時效果

    這篇文章主要為大家詳細(xì)介紹了JavaScript實現(xiàn)簡單的倒計時效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • js給table賦值的實例代碼

    js給table賦值的實例代碼

    下面小編就為大家?guī)硪黄猨s給table賦值的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • 利用Javascript實現(xiàn)簡單的轉(zhuǎn)盤抽獎

    利用Javascript實現(xiàn)簡單的轉(zhuǎn)盤抽獎

    這篇文章主要介紹了利用Javascript實現(xiàn)的簡單的轉(zhuǎn)盤抽獎,文中分享了兩種抽獎效果,一種是默認(rèn)轉(zhuǎn)動,一種是需要點(diǎn)擊開始轉(zhuǎn)動的,并給出了晚上的示例代碼,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • 小程序按鈕避免多次調(diào)用接口和點(diǎn)擊方案實現(xiàn)(不用showLoading)

    小程序按鈕避免多次調(diào)用接口和點(diǎn)擊方案實現(xiàn)(不用showLoading)

    這篇文章主要介紹了小程序按鈕避免多次調(diào)用接口和點(diǎn)擊方案實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04

最新評論