日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

html5画板功能,JS实现canvas简单小画板功能

發布時間:2023/12/20 javascript 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 html5画板功能,JS实现canvas简单小画板功能 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文實例為大家分享了JS實現canvas簡單小畫板的具體代碼,供大家參考,具體內容如下

Html部分:

Document

CSS部分:

*{

margin: 0;

padding: 0;

list-style: none;

}

.container{

margin: 30px;

}

#cavs{

border: 1px solid red;

box-shadow: 0 2px 8px rgba(0, 0, 0, 0.6);

border-radius: 10px;

}

.container ul{

margin-top: 20px;

width: 700px;

text-align: center;

}

.container ul li{

display: inline-block;

margin-left: 35px;

}

.container ul li input{

padding: 6px 15px;

border-radius: 10px;

border: none;

outline: none;

cursor: pointer;

transition: box-shadow 0.3s cubic-bezier(0.6, -0.28, 0.735, 0.045);

}

.container ul li input:hover{

box-shadow: 0 2px 8px rgba(0, 0, 0, 0.6);

}

JS部分:

var drawingBoard = {

cavs: document.getElementById('cavs'),

ctx: document.getElementById('cavs').getContext('2d'),

ul_node: document.getElementsByTagName('ul')[0],

colorBoard: document.getElementById('color'),

lineRuler: document.getElementById('lineRuler'),

imgArr: [],//存放圖片

init: function () {

this.ctx.lineCap = 'round';

this.ctx.lineJoin = 'round';

this.drawing();//開始畫畫

this.btnsFnAll();

},

drawing: function () {

var self = this;

var left = this.cavs.offsetLeft;

this.cavs.onmousedown = function (e) {

var e_x = e.pageX;//鼠標在畫布上的x點

var e_y = e.pageY;

self.ctx.beginPath();//開始繪制

self.ctx.moveTo(e_x - left, e_y - left);//落筆點,開始點

var imgData = self.ctx.getImageData(0, 0, self.cavs.offsetWidth, self.cavs.offsetHeight);

self.imgArr.push(imgData)

document.onmousemove = function (e) {

self.ctx.lineTo(e.pageX - left, e.pageY - left);//落筆點,開始點

self.ctx.stroke();

}

document.onmouseup = function () {

document.onmousemove = null;

self.ctx.closePath();//閉合當前的路徑 結束繪制

}

this.onpointerleave = function () {

document.onmousemove = null;

}

}

},

btnsFnAll: function () {

var self = this;

this.ul_node.addEventListener('click', function (e) {

console.log(e.target.id);

switch (e.target.id) {

case 'cleanBoard'://清屏

self.ctx.clearRect(0, 0, self.cavs.offsetWidth, self.cavs.offsetHeight)

break;

case 'eraser'://橡皮

self.ctx.strokeStyle = "#ffffff";

break;

case 'save'://保存

let url = self.cavs.toDataURL('image/jpg');

let a = document.createElement('a');

document.body.appendChild(a);

a.href = url;

a.download = '草稿紙';

a.target = '_blank';

a.click()

break;

case 'rescind'://撤銷

console.log(self.imgArr)

if (self.imgArr.length > 0) {

self.ctx.putImageData(self.imgArr.pop(), 0, 0)

}

break;

}

});

this.colorBoard.onchange = function () {

self.ctx.strokeStyle = this.value;

};

this.lineRuler.onchange = function () {

self.ctx.lineWidth = this.value

}

}

}

drawingBoard.init();

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

總結

以上是生活随笔為你收集整理的html5画板功能,JS实现canvas简单小画板功能的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。