html 写字版插件,原生JS+HTML5实现的可调节写字板功能示例
本文实例讲述了原生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实现的可调节写字板功能示例相关推荐
- 原生js输出html5,原生JS+HTML5实现的可调节写字板功能示例
本文实例讲述了原生JS+HTML5实现的可调节写字板功能.分享给大家供大家参考,具体如下: 前面一篇介绍了<JS+HTML5 Canvas实现简单的写字板功能>,这里再介绍另一种实现方法. ...
- html 写字版插件,JS+HTML5 Canvas实现简单的写字板功能示例
本文实例讲述了JS+HTML5 Canvas实现简单的写字板功能.分享给大家供大家参考,具体如下: 先来看运行效果: 具体代码如下: www.jb51.net JS写字板 body,html { pa ...
- 写字板能用html语言吗,JS+HTML5 Canvas实现简单的写字板功能示例
本文实例讲述了JS+HTML5 Canvas实现简单的写字板功能.分享给大家供大家参考,具体如下: 先来看运行效果: 具体代码如下: www.jb51.net JS写字板 body,html { pa ...
- php前台限制输入text字符,限制字符输入数功能(jquery版和原生JS版)
比较常用的限制字符输入数功能(比如热火超天的微博输入框),用jquery和原生JavaScript分别写了一个.原生JavaScript注释中有区分中英文字符的函数, 但个人并不建议这么做. 已知BU ...
- 限制字符输入数功能(jQ版和原生JS版)
限制字符输入数功能(jQ版和原生JS版) 比较常用的限制字符输入数功能(比如热火超天的微博输入框),用jQuery和原生JavaScript分别写了一个.原生JavaScript注释中有区分中英文字符 ...
- php写字板代码,JS+HTML5 Canvas实现简单的写字板功能示例
本文实例讲述了JS+HTML5 Canvas实现简单的写字板功能.分享给大家供大家参考,具体如下: 先来看运行效果: 具体代码如下: www.jb51.net JS写字板 body,html { pa ...
- java使用重绘实现拖动_原生JS使用Canvas实现拖拽式绘图功能
一.实现的功能 1.基于oop思想构建,支持坐标点.线条(由坐标点组成,包含方向).多边形(由多个坐标点组成).圆形(包含圆心坐标点和半径)等实体 2.原生JavaScript实现,不依赖任何第三方j ...
- html5支持原生js,HTML5怎么学原生的js?让你对前端有了新的认识
原标题:HTML5怎么学原生的js?让你对前端有了新的认识 已经学习了HTML5两个月,第一个月主要学习HTML和CSS,第二个月学完了原生的js,学完原生的js后对前端有了新的认识,了解了前端并不是 ...
- dw按钮图片滚动js_轮播图--swiper插件/原生js/jQuery
1.swiper插件: 需要下载该插件到本地,并用link标签引用其swiper-bundle.min.css文件,用script引用其swiper-bundle.min.js文件,下载地址及官方文档 ...
最新文章
- P1155 双栈排序(二分图的染色判断+链式前向星)
- Vue -- 配合iView实现省市二级联动
- openresty开发系列15--lua基础语法4表table和运算符
- jxl生成表格(合并单元格,字体,样式)
- 来领资料咯!计算机专业教科书礼包
- 中科院硕士起诉导师,二审败诉
- 《深入浅出DPDK》读书笔记(十一):DPDK虚拟化技术篇(I/O虚拟化、CPU虚拟化、内存虚拟化、VT-d、I/O透传)
- 【C#复习总结】细说表达式树
- python处理excel表格-如何用python处理excel表格
- python办公ppt_最全总结 | 聊聊 Python 办公自动化之 PPT(中)
- 黑群晖二合一安装不了套件_黑群晖刷机教程
- 实验1 matlab图像处理初步,1.实验一 MatLab数字图像处理初步
- 写在博士旅程之前|博士第一年|博士第三年|博士第四年
- 设计四位移位寄存器shifter_4
- 软件文档的类型有哪些?
- 分门别类刷leetcode——栈、队列、堆(C++实现)
- Openssh7.4p1更换为8.2
- 项目启动报错 Error running ‘xxxApplication‘;Command line is too long,Shoerten command line for........
- AVM环视:一.相机标定及原理
- Exception in thread main java.lang.NoSuchMethodError: scala.Predef$.ArrowAssoc(Ljava/lang/Object;)