当前位置:首页 > 编程教程 > javascript技术文章 > javaScript canvas实现(画笔大小 颜色 橡皮的实例)

javaScript canvas实现绘画工具的实例详解

  • 发布时间:
  • 作者:码农之家
  • 点击:99

这篇文章主要知识点是关于canvas、画笔大小、的内容,如果大家想对相关知识点有系统深入的学习,可以参阅以下电子书

你不知道的JavaScript(中卷)
  • 类型:JS大小:7.8 MB格式:PDF作者:辛普森
立即下载

javaScript canvas实现(画笔大小 颜色 橡皮的实例)

实例如下所示:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8" />
 <title></title>
 </head>
 <body>
 <div>
 <div>
 
 <!--<input type="button" id="open" value="open"></input>
 <input type="button" id= "save" value = "save"></input> <input type="button" id= "color" value="color"></input> -->
 <input type="button" value="size"></input>
 <input type="text" id="size" onchange="sizeChange()"></input>
 <input type="button" id="clear" value="clear"></input>
 <input type="button" id="eraser" value="eraser" onclick="doEraser()"></input>
 <select id = "shape" onchange="shapeChange()">
  <option value = "99">shape</option>
  <option value = "1">rectangle</option>
  <option value = "0">circle</option>
  <option value = "2">line</option>
 </select>

 
 <input id="color" type="color"/>
 </div>
 <canvas id="myCanvas"  width="800" height="500"></canvas>
 </div>
 </body>
 <script language="JavaScript">
 var shap = 99; //0 is circle; 1 is rectangle
 var orignalX, orignalY;//the coordinate of mouse down
 var lastX, lastY;//the coordinate of last mouse position
 var isMouseDown = false; // flag of mouse pressing down
 var myCanvas = document.getElementById("myCanvas");
 var context = myCanvas.getContext('2d');
 var width = myCanvas.width, height = myCanvas.height;
 var data;//storing last canvas' content
 context.strokeStyle = "black";
 context.strokeWidth=1;
 context.lineWidth = 1;

 
 document.getElementById('color').onchange = function(){
   context.strokeStyle = this.value
 };
 
 function doEraser(){
 context.strokeStyle = "white";
 shap = 2;
 }
 function sizeChange(){
 
 context.lineWidth = parseInt(document.getElementById('size').value);
 
 }
 
 function shapeChange(){
 context.strokeStyle = "black";
  var myselect = document.getElementById("shape");
 var index=myselect.selectedIndex ; 
 var myvalue = myselect.options[index].value;
 var mytext=myselect.options[index].text; 
 shap = parseInt(myvalue);
 
  }

 

 function myCanvasMouseDown(event) {
 //event.preventDefault();
 
 if(event.button == 0) {
 orignalX = event.offsetX;
 orignalY = event.offsetY;
 context.moveTo(orignalX,orignalY); 
 data = context.getImageData(0, 0, width, height);
 isMouseDown = true;
 
 }
 }

 function myCanvasMouseMove(event) {
 if (isMouseDown){
 //event.preventDefault();
 
 switch(shap){
  case 0:
   context.clearRect(0,0,width,height);
  context.putImageData(data,0,0);
  lastX = event.offsetX;
  lastY = event.offsetY;
  context.beginPath();
  context.arc(orignalX+(lastX-orignalX)/2,orignalY+(lastY-orignalY)/2,Math.abs(lastX-orignalX)/2,0,Math.PI * 2,true);
  context.stroke();
  context.closePath();
  break;
  case 1:
  context.clearRect(0,0,width,height);
  context.putImageData(data,0,0);
  lastX = event.offsetX;
  lastY = event.offsetY;
  context.strokeRect(orignalX, orignalY, lastX-orignalX, lastY-orignalY);
  break;
  case 2:
   lastX = event.offsetX;
   lastY = event.offsetY;
   context.lineTo(lastX, lastY); //根据鼠标路径绘画 
   context.stroke(); //立即渲染 
   break;
  
 }
 }
 }

 function myCanvasMouseUp(event) {
 if (isMouseDown){
 //event.preventDefault();
 
 context.clearRect(0,0,width,height);
 context.putImageData(data,0,0);
 lastX = event.offsetX;
 lastY = event.offsetY;
 switch(shap){
  case 0:
  context.beginPath();
  context.arc(orignalX+(lastX-orignalX)/2,orignalY+(lastY-orignalY)/2,Math.abs(lastX-orignalX)/2,0,Math.PI * 2,true);
  context.stroke();
  context.closePath();
  break;
  case 1:
  context.beginPath();
  context.strokeRect(orignalX, orignalY, lastX-orignalX, lastY-orignalY);
  context.closePath();
  break;
  case 2:
  
  context.lineTo(lastX, lastY); //根据鼠标路径绘画 
   context.stroke(); //立即渲染 
  
  break;
 }
 isMouseDown = false;
 lastX = null;
 lastY = null;
 orignalX = null;
 orignalY = null;
 data = context.getImageData(0, 0, width, height);
 context.beginPath();
 context.clearRect(0,0,width,height);
 context.putImageData(data,0,0);
 context.closePath();
 }
 } 
 myCanvas.addEventListener("mousedown", myCanvasMouseDown, false);
 myCanvas.addEventListener("mousemove", myCanvasMouseMove, false);
 myCanvas.addEventListener("mouseup", myCanvasMouseUp, false);
 </script>
 
</html>

以上这篇javaScript canvas实现(画笔大小 颜色 橡皮的实例)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。

以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。

您可能感兴趣的文章:

  • 微信小程序canvas绘制圆角base64图片的方法浅析
  • canvas轨迹回放功能的实现代码和方法
  • canvas实现知乎登录页背景效果代码实例
  • 详解使用canvas实现围绕旋转动画
  • js canvas如何实现图片放大镜功能
  • 详解Js利用Canvas实现图片压缩功能
  • canvas实现图片根据滑块放大缩小的代码
  • JavaScript Canvas绘制圆形时钟效果代码实例
  • HTML5+Canvas调用手机拍照功能并实现上传
  • 相关电子书
    学习笔记
    网友NO.424976

    JavaScript之Canvas_动力节点Java学院整理

    Canvas是HTML5新增的组件,它就像一块幕布,可以用JavaScript在上面绘制各种图表、动画等。 没有Canvas的年代,绘图只能借助Flash插件实现,页面不得不用JavaScript和Flash进行交互。有了Canvas,我们就再也不需要Flash了,直接使用JavaScript完成绘制。 一个Canvas定义了一个指定尺寸的矩形框,在这个范围内我们可以随意绘制: canvas id="test-canvas" width="300" height="200"/canvas 由于浏览器对HTML5标准支持不一致,所以,通常在 canvas 内部添加一些说明性HTML代码,如果浏览器支持Canvas,它将忽略 canvas 内部的HTML,如果浏览器不支持Canvas,它将显示 canvas 内部的HTML: canvas id="test-stock" width="300" height="200" pCurrent Price: 25.51/p/canvas 在使用Canvas前,用 canvas.getContext 来测试浏览器是否支持Canvas: !-- HTML代码 --canvas id="test-canvas" width="200" heigth="100" p你的浏览器不支持Canvas/p/canvas 'use st……

    网友NO.533746

    JavaScript Canvas实现验证码

    在通常的登录界面我们都可以看到验证码,验证码的作用是检测是不是人在操作,防止机器等非人操作,防止数据库被轻而易举的攻破。 验证码一般用PHP和java等后端语言编写。 但是在前端,用canva或者SVG也可以绘制验证码。 绘制验证码不能是简单的随机字符串,而应该在绘制界面有一些干扰项: 如: 干扰线段、干扰圆点、背景等等。 这里的这个demo的canvas验证码干扰项比较简单。 可以在图示中看到本例中的干扰项。 canvas验证码展示效果: 点击实现改变(重绘)验证码: 在控制台运行函数输出返回值(验证码): 源码 : !DOCTYPE htmlhtml lang="en"head meta charset="UTF-8" meta name="viewport" content="width=device-width, initial-scale=1.0" meta http-equiv="X-UA-Compatible" content="ie=edge" titlecanvas验证码/title/headbody canvas width="200" height="60" id="check" 您的浏览器不支持canvas标签!/canvas script v……

    网友NO.710123

    JavaScript+HTML5 canvas实现放大镜效果完整示例

    本文实例讲述了JavaScript+HTML5 canvas实现放大镜效果。分享给大家供大家参考,具体如下: 效果: !DOCTYPE htmlhtmlhead lang="en" meta charset="UTF-8" titlewww.jb51.net canvas放大镜/title style #copycanvas { border: 1px solid #000; display: none; } #square { width: 90px; height: 90px; background-color: #cc3; border: 1px solid #f00; opacity: 0.5; position: absolute; z-index: 999; display: none; cursor: crosshair; } /style/headbodycanvas id="canvas" width="450" height="676"/canvascanvas id="copycanvas" width="300" height="300"/canvasdiv id="square"/divscript var canvas = document.getElementById('canvas'), //获取canvas对象 context = canvas.getContext('2d'), //获取上下文 copycanvas = document.getElementById('copycanvas'), //获取copycanvas copycontext = copycanvas.getContext('2d'), square = document.getElementById('square'), //获取透明框 squaredata = {}, //用来保存选择框数据 box = canvas.getBoundingClientRect(); //getBoundingClientRec……

    <
    1
    >

    Copyright 2018-2020 www.xz577.com 码农之家

    投诉 / 推广 / 赞助:QQ:520161757