本文实例讲述了原生JS+HTML5实现的可调节写字板功能。分享给大家供大家参考,具体如下:

本文实例讲述了原生JS+HTML5实现的可调节写字板功能。分享给大家供大家参考,具体如下:

前面一篇介绍了《JS+HTML5 Canvas实现简单的写字板功能》,这里再介绍另一种实现方法。首先来看看运行效果:

具体代码如下:

www.jb51.net JS写字板

#cans{

display: block;

margin: 0 auto;

}

#selectColor{

margin: 0 auto;

width: 400px;

/* height: 50px;*/

text-align: center;

margin-top: 10px;

list-style: none;

}

.all{

/*width: 10%;

height: 95%;*/

width: 60px;

height: 50px;

border: 1px solid #CCCCCC;

float: left;

margin-left: 10px;

border-radius:6px ;

cursor: pointer;

}

#red{

background-color: red;

}

#yellow{

background: yellow;

}

#black{

background: black;

}

#green{

background: green;

}

#blue{

background: #0000FF;

}

#clear{

margin-left: 10px;

}

#fontW{

width: 400px;

margin: 0 auto;

}

您的浏览器不支持该功能!

线条粗细:020

//初始化区

var ranges=document.getElementById("ranges");

var cans=document.getElementById("cans");

var clear=document.getElementById("clear");

cans.width=600;

cans.height=600;

var down=false;

var up=false;

var clears1=false;

var lastmousePos={x:0,y:0};

var curmousePos={x:0,y:0};

var lastWidth;

var curWidth=3;

//设置canvas宽高

var CanvasWidth=cans.width;

var CanvasHeight=cans.height;

var half_width=CanvasWidth/2;

var half_height=CanvasHeight/2;

var frameW=10;

var lineW=1;

//改变线条宽度

function changeW(){

curWidth=ranges.value;

}

var drawCol="black";

//改变字体颜色

function changecolor(s){

drawCol=s;

}

var cts=cans.getContext("2d");

//设置米字格子

//开始绘制前设置基本样式

drawcanvs()

function drawcanvs(){

cts.lineCap="round"

cts.lineJoin="round"

cts.lineWidth=frameW;

cts.strokeStyle="red"

cts.beginPath()

cts.moveTo(0,0);

cts.lineTo(CanvasWidth,0);

cts.lineTo(CanvasWidth,CanvasHeight);

cts.lineTo(0,CanvasHeight);

cts.closePath()

cts.stroke()

//画x

cts.lineWidth=lineW;

cts.beginPath()

cts.moveTo(0,0);

cts.lineTo(CanvasWidth,CanvasHeight);

cts.closePath()

cts.stroke()

cts.beginPath()

cts.moveTo(CanvasWidth,0);

cts.lineTo(0,CanvasHeight);

cts.closePath()

cts.stroke()

cts.beginPath()

cts.moveTo(half_width,0);

cts.lineTo(half_width,CanvasHeight);

cts.closePath()

cts.stroke()

cts.beginPath()

cts.moveTo(0,half_height);

cts.lineTo(CanvasWidth,half_height);

cts.closePath()

cts.stroke()

}

cans.οnmοusemοve=function(e){

var e=e||event;

var clx=e.clientX-cans.getBoundingClientRect().left;//将鼠标原点化为画布原点

var cly=e.clientY-cans.getBoundingClientRect().top;

curmousePos={x:clx,y:cly};

if(down){

//开始画

//设置画笔颜色、粗细等

cts.lineCap="round"

cts.lineJoin="round"

cts.lineWidth=curWidth;

cts.strokeStyle=drawCol;

//开始绘画

cts.save();

cts.beginPath();

cts.moveTo(lastmousePos.x,lastmousePos.y);

cts.lineTo(curmousePos.x,curmousePos.y);

cts.closePath();

cts.stroke();

cts.restore();

lastmousePos=curmousePos;

}

if(up){

down=false;

up=false;

}

}

//鼠标按下事件

cans.οnmοusedοwn=function(e){

var e=e||event;

e.preventDefault();

lastmousePos=curmousePos

down=true;

}

//鼠标松开事件

cans.οnmοuseup=function(e){

var e=e||event;

e.preventDefault();

up=true;

}

//计算速度

// function calV(s,t){

// var v=s/t;

// if(v<0.1){

// curWidth=10;

// }else if(v>10){

// curWidth=2;

// }else{

// curWidth=5

// }

// }

function changeBg(){

var all=document.getElementsByClassName("all");

for(var i=0;i

all[i].οnmοuseοver=function(){

this.style.cssText="margin-top:-6px;box-shadow:3px 5px 5px black"

}

all[i].οnmοuseοut=function(){

this.style.cssText="border: 1px solid #CCCCCC;"

}

}

}

changeBg()

//恢复原状

function ss(s){

s.style.cssText="margin-top:0px;box-shadow:none;"

}

//清除方法

clear.οnmοusedοwn=function (){

cts.clearRect(0,0,cans.width,cans.height);

// clears1=true;

}

//清除后重画

clear.οnmοuseup=function(){

drawcanvs();

}

感兴趣的朋友还可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码,亲身体验一下运行效果。

html 写字版插件,原生JS+HTML5实现的可调节写字板功能示例相关推荐

  1. 原生js输出html5,原生JS+HTML5实现的可调节写字板功能示例

    本文实例讲述了原生JS+HTML5实现的可调节写字板功能.分享给大家供大家参考,具体如下: 前面一篇介绍了<JS+HTML5 Canvas实现简单的写字板功能>,这里再介绍另一种实现方法. ...

  2. html 写字版插件,JS+HTML5 Canvas实现简单的写字板功能示例

    本文实例讲述了JS+HTML5 Canvas实现简单的写字板功能.分享给大家供大家参考,具体如下: 先来看运行效果: 具体代码如下: www.jb51.net JS写字板 body,html { pa ...

  3. 写字板能用html语言吗,JS+HTML5 Canvas实现简单的写字板功能示例

    本文实例讲述了JS+HTML5 Canvas实现简单的写字板功能.分享给大家供大家参考,具体如下: 先来看运行效果: 具体代码如下: www.jb51.net JS写字板 body,html { pa ...

  4. php前台限制输入text字符,限制字符输入数功能(jquery版和原生JS版)

    比较常用的限制字符输入数功能(比如热火超天的微博输入框),用jquery和原生JavaScript分别写了一个.原生JavaScript注释中有区分中英文字符的函数, 但个人并不建议这么做. 已知BU ...

  5. 限制字符输入数功能(jQ版和原生JS版)

    限制字符输入数功能(jQ版和原生JS版) 比较常用的限制字符输入数功能(比如热火超天的微博输入框),用jQuery和原生JavaScript分别写了一个.原生JavaScript注释中有区分中英文字符 ...

  6. php写字板代码,JS+HTML5 Canvas实现简单的写字板功能示例

    本文实例讲述了JS+HTML5 Canvas实现简单的写字板功能.分享给大家供大家参考,具体如下: 先来看运行效果: 具体代码如下: www.jb51.net JS写字板 body,html { pa ...

  7. java使用重绘实现拖动_原生JS使用Canvas实现拖拽式绘图功能

    一.实现的功能 1.基于oop思想构建,支持坐标点.线条(由坐标点组成,包含方向).多边形(由多个坐标点组成).圆形(包含圆心坐标点和半径)等实体 2.原生JavaScript实现,不依赖任何第三方j ...

  8. html5支持原生js,HTML5怎么学原生的js?让你对前端有了新的认识

    原标题:HTML5怎么学原生的js?让你对前端有了新的认识 已经学习了HTML5两个月,第一个月主要学习HTML和CSS,第二个月学完了原生的js,学完原生的js后对前端有了新的认识,了解了前端并不是 ...

  9. dw按钮图片滚动js_轮播图--swiper插件/原生js/jQuery

    1.swiper插件: 需要下载该插件到本地,并用link标签引用其swiper-bundle.min.css文件,用script引用其swiper-bundle.min.js文件,下载地址及官方文档 ...

最新文章

  1. P1155 双栈排序(二分图的染色判断+链式前向星)
  2. Vue -- 配合iView实现省市二级联动
  3. openresty开发系列15--lua基础语法4表table和运算符
  4. jxl生成表格(合并单元格,字体,样式)
  5. 来领资料咯!计算机专业教科书礼包
  6. 中科院硕士起诉导师,二审败诉
  7. 《深入浅出DPDK》读书笔记(十一):DPDK虚拟化技术篇(I/O虚拟化、CPU虚拟化、内存虚拟化、VT-d、I/O透传)
  8. 【C#复习总结】细说表达式树
  9. python处理excel表格-如何用python处理excel表格
  10. python办公ppt_最全总结 | 聊聊 Python 办公自动化之 PPT(中)
  11. 黑群晖二合一安装不了套件_黑群晖刷机教程
  12. 实验1 matlab图像处理初步,1.实验一 MatLab数字图像处理初步
  13. 写在博士旅程之前|博士第一年|博士第三年|博士第四年
  14. 设计四位移位寄存器shifter_4
  15. 软件文档的类型有哪些?
  16. 分门别类刷leetcode——栈、队列、堆(C++实现)
  17. Openssh7.4p1更换为8.2
  18. 项目启动报错 Error running ‘xxxApplication‘;Command line is too long,Shoerten command line for........
  19. AVM环视:一.相机标定及原理
  20. Exception in thread main java.lang.NoSuchMethodError: scala.Predef$.ArrowAssoc(Ljava/lang/Object;)

热门文章

  1. 百度云ai-车型识别
  2. go语言后端框架之简单探索
  3. c语言 extern 的使用场景
  4. 幻痛 机器人_合金装备5幻痛那个大机器人怎么样打 | 手游网游页游攻略大全
  5. C++ 之栈内存与堆内存详解
  6. Ubuntu系统安装操作失误,导致开机一直进入grub界面的解决方法
  7. java+mysql 实现实体的映射与翻译
  8. vue-路由的下载安装
  9. matlab 画图 无法分离变量,matlab导热问题实例
  10. Excel 为多个页签快速生成目录及返回目录详细方法