canvas

Tip1.HTML

<canvas id="canvas" width="300" height="300"></canvas>
<button id="eraser">橡皮擦</button>

Tip2.获取canvas 与绘画上下文

var canvasP=document.getElementById('canvas'); //获取html中的canvas(id)
var context=canvasP.getContext('2d');  //获取上下文

Tip2.2获取屏幕高宽

pageHW()
function pageHW(){
  var pageWidth=document.docuementElement.clientWidth
  var pageHeight=document.docuementElement.clientHeight
  context.width=pageWidth
  context.width=pageHight
}

window.onresize =function(){  //当页面宽高 变动 在执行一次pageHW()
pageHW()
}

Tip2.3 橡皮擦

var usingEraser=flase
eraser.onclick=function(){
  usingEraser=!usingEraser    //取反  如果传进来的值为true    usingEraser就等于flase
}

Tip3.画一个圆

创建一个圆的函数
function drawCircle(x,y,radius){
context.beginPath();  
context.arc(x,y,radius,0,Math.PI*2) ;
context.fill(); 
}

Tip4.鼠标事件

var using=false //
context.onmousedown=function(a){
  using=true
  var x=a.clientX //获取鼠标按下 x的值
  var y=a.clientY    //获取鼠标按下Y的值
  driawCircle(x,y,5) //值带入画圆的函数
}
context.onmousemove=function(a){   //移动的时候画圈
  if(using){   //如果painting为true
    var x=a.clientX //获取鼠标按下 x的值
    var y=a.clientY    //获取鼠标按下Y的值
    driawCircle(x,y,5) //值带入画圆的函数
    }
}
context.onmouseup=function(a){
using=false;
}

Tip5.连接鼠标移动中 点的连线

function drawLine(x1,y1,x2,y2){ // x1,y1  与x2,y2 分别为鼠标之前的点与现在的点的坐标
context.beginPath();
context.moveTo(x1,y1);
context.lineWidth=5;
context.lineTo(x2,y2);
context.stroke();
context.closePath();
}

Tip6.完善第4步

var using=false //
var lastPoint={x:undefind,y:undefind}  //记录之前的点
context.onmousedown=function(a){
  using=true
  var x=a.clientX //获取鼠标按下 x的值
  var y=a.clientY    //获取鼠标按下Y的值
  lostPoint={x:x,y:y}
  driawCircle(x,y,5) //值带入画圆的函数
}
context.onmousemove=function(a){   //移动的时候画圈
  if(using){   //如果painting为true
    var x=a.clientX //获取鼠标按下 x的值
    var y=a.clientY    //获取鼠标按下Y的值
    var newPoint={x:x,y:y}
    driawCircle(x,y,5) //值带入画圆的函数
    driawLine(lastPoint.x, lastPoint.y, newPoint.x, newPoint.y) //数据带入 driawLine函数
    lastPoint=newPoint   //每次将新点赋值给之前的点
}else{

}
}
context.onmouseup=function(a){
using=false;
}

Tip7完善第6步

var usting=false //
var lastPoint={x:undefind,y:undefind}  //记录之前的点
context.onmousedown=function(a){
  
  var x=a.clientX //获取鼠标按下 x的值
  var y=a.clientY    //获取鼠标按下Y的值
  if(eraserEnable){
  context.clearRect(x-5,y-5,10,10)
}else{
  painting=true
  lostPoint={x:x,y:y}
  driawCircle(x,y,5) //值带入画圆的函数
}
}
context.onmousemove=function(a){   //移动的时候画圈
    var x=a.clientX //获取鼠标按下 x的值
    var y=a.clientY    //获取鼠标按下Y的值
if(eraserEnable){
    if(using){
      context.clearRect(x-5,y-5,10,10)
    }
}else{
    if(using){   //如果painting为true
    var newPoint={x:x,y:y}
    driawCircle(x,y,5) //值带入画圆的函数
    driawLine(lastPoint.x, lastPoint.y, newPoint.x, newPoint.y) //数据带入 driawLine函数
    lastPoint=newPoint   //每次将新点赋值给之前的点
    }
  }
}
context.onmouseup=function(a){
painting=false;
}


var eraserEnable=false //默认关闭橡皮擦
earser.onclick=function(){
eraserEnable=!eraserEnable
}

Title.常用API

描边

context.strokeStyle='green'  描边颜色
context.strokeRect(0,0,100,100) //描边坐标

绘制一个矩形

context.fillStyle='red';  //绘制图形的颜色
context.fillRect(0,0,100,100) ;   //0,0左上角坐标 100,100 右下角坐
fillStyle  fillRect 有先后顺序

绘制一个三角形

context.fillStyle='red' //填充颜色
context.beginPath();  //开始
context.moveTo(240,240) //移动到一个#点# (X,Y)
context.lineTo(300,240) //  连接一个点
context.lineTo(300,300)    //连接一个点
//context.lineWidth=5  线宽
context.fill()     //填充
context.closePath() //结束

橡皮擦

context.clearRect(50,50,10,10) //清楚坐标50,50    大小10,10  

绘制一个圆

context.beginPath();  //开始
context.arc(150,150,20,0,Math.PI*2)  //150,150 圆心 20 半径 0 0度 Math.PI*2 一周 (π)

鼠标事件 按下 移动 弹起

document.onmousedown=function(x){      //鼠标按下
console.log(x)             //事件相关信息
}
document.onmousemove=function(y){      //鼠标移动
console.log(y)
}
document.onmouseup=function(z){          //鼠标抬起
console.log('抬起')
}
控制台-事件信息

获取屏幕高宽

var pagewidth=document.documentElement.clientWidth
var pageHeight=document.documentElement.clientHeight
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容