使用canvas制作在线画板
canvas绘图的强大功能,让人前仆后继的去研究它。代码全部加起来不足百行。还用到了h5中的<input type="color"/>和<input type="range"/>
使得页面更加简洁。
本文只用了鼠标的三个事件 onmousedown onmousemove onmouseup就轻松实现了网页画板的制作。
上代码:
- <!DOCTYPE html>
- <html>
- <head lang="en">
- <meta charset="UTF-8">
- <title></title>
- <style type="text/css">
- #canvas{
- border: 1px solid #333;
- display: block;
- margin:20px auto;
- }
- #color{
- width:100px;
- height:32px;
- position:absolute;
- right:115px;
- top:200px;
- }
- #range{
- width:100px;
- height:32px;
- position:absolute;
- right:115px;
- top:125px;
- }
- #demo{
- background:black;
- width:100px;
- height:5px;
- position:absolute;
- right:115px;
- top:100px;
- }
- </style>
- </head>
- <body background-color="rgba(0,0,0,0.5)">
- <div class="box">
- <h3 align="center">CANVAS制作简单在线画板</h3>
- <canvas id="canvas" width="800" height="600"></canvas>
- <input type="color" id="color"/>
- <div id="demo"></div>
- <input type="range" id="range" min="1" max="10"/>
- </div>
- <script type="text/javascript">
- var canvas=document.getElementById("canvas");
- var cxt=canvas.getContext("2d");
- var color=document.getElementById("color");
- var size=document.getElementById("range");
- var demo=document.getElementById("demo");
- //根据size的变化来使得size上面的线条演示画笔粗细。
- size.onchange=function(){
- demo.style.height=size.value+"px";
- }
- //使得color的颜色与演示线条的颜色一致
- color.onchange=function(){
- demo.style.background=color.value;
- }
- var flag=false;
- //鼠标按下
- canvas.onmousedown= function (e) {
- var mouseX= e.pageX-this.offsetLeft;
- var mouseY= e.pageY-this.offsetTop;
- flag=true;
- cxt.beginPath();
- cxt.lineWidth=size.value;
- cxt.strokeStyle=color.value;
- cxt.moveTo(mouseX,mouseY);
- };
- //鼠标移动
- canvas.onmousemove= function (e) {
- var mouseX= e.pageX-this.offsetLeft;
- var mouseY= e.pageY-this.offsetTop;
- if(flag){
- cxt.lineTo(mouseX,mouseY);
- cxt.stroke();
- }
- }
- //鼠标松开
- canvas.onmouseup= function (e) {
- flag=false;
- }
- </script>
- </body>
- </html>
大家做成后的木模样
使用canvas制作在线画板的更多相关文章
- html --- canvas --- javascript --- 在线画板
canvas功能十分强大,制作一个简易画板易如反掌,主要涉及canvas的画线能力,javascript鼠标点击事件 如有问题请参考:http://www.html5party.com/857.htm ...
- H5中canvas标签制作在线画板
1.介绍 左键点击下移动开始画图.放开鼠标不在画图. 2.重要使用理论 query的使用: 鼠标的按下mousedown 鼠标的移动mousemove 鼠标的放开 mouseup 3.程序 <! ...
- canvas画画板,canvas画五角星,canvas制作钟表、Konva写钟表
制作一个画画板,有清屏有橡皮擦有画笔可以换颜色 style样式 <head> <meta charset="UTF-8"> <title>画画板 ...
- 使用canvas制作一个移动端画板
概述 使用canvas做一个画板,代码里涵盖了一些canvas绘图的基本思想,各种工具的类也可以分别提出来用 详细 代码下载:http://www.demodashi.com/demo/10503.h ...
- 如何使用 HTML5 Canvas 制作水波纹效果
今天,我们继续分享 JavaScript 实现的效果例子,这篇文章会介绍使用 JavaScript 实现水波纹效果.水波效果以图片为背景,点击图片任意位置都会触发.有时候,我们使用普通的 Javasc ...
- 基于HTML5 Canvas的网页画板实现教程
HTML5的功能非常强大,尤其是Canvas的应用更加广泛,Canvas画布上面不仅可以绘制任意的图形,而且可以实现多种多样的动画,甚至是一些交互式的应用,比如网页网版.这次我们要来看的就是一款基于H ...
- 小强的HTML5移动开发之路(10)——在线画板
来自:http://blog.csdn.net/dawanganban/article/details/18094557 在这一篇文章中我们用html5来实现一个在线的画板,玩过你画我猜的朋友今天也可 ...
- Canvas制作的下雨动画
简介 在codepen上看到一个Canvas做的下雨效果动画,感觉蛮有意思的.就研究了下,这里来分享下,实现技巧.效果可以见下面的链接. 霓虹雨: http://codepen.io/natewile ...
- 用Canvas制作简单的画图工具
今天用Canvas制作了一个画图工具,非常简单,功能也不是很多,主要有背景网格,画线,画圆,画矩形和画圆角矩形,也用到了canvas的一些基本知识,在这里一一列举. 1.线段的绘制: 如何绘制真正的1 ...
随机推荐
- ☀【Node】处理文件上传
Node入门 √http://www.nodebeginner.org/index-zh-cn.html Node.js中所用的fs.renameSync出错:Error: EXDEV, cross- ...
- asp.net mvc ChildActionOnly 和ActionName的用法
ChildActionOnly的目的主要就是让这个Action不通过直接在地址栏输入地址来访问,而是需要通过RenderAction来调用它. <a href="javascript: ...
- [POJ2234]Matches Game
Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9297 Accepted: 5365 Description Here ...
- cygwin设置中文
cygwin\home\username\.bashrc # 让ls和dir命令显示中文和颜色 alias ls='ls --show-control-chars --color' alias dir ...
- Java读取文件夹大小的6种方法及代码
(一)单线程递归方式 package com.taobao.test; import java.io.File; public class TotalFileSizeSequential { publ ...
- post方法
CookieContainer cookie = new CookieContainer(); private string HttpPost(string Url, string postDataS ...
- HBase 学习笔记---守护进程及内存调优
1.HMaster HMaster的任务前面已经说过了,两个大方向:一.管理Hbase Table的 DDL操作 二.region的分配工作,任务不是很艰巨,但是如果采用默认自动s ...
- C#Winform窗口特效源码(1)
本文基于.Net开发,使用C#作为开发语言,分别包含以下效果: 移动无边框窗口.窗口移动限制(限制在屏幕内).桌面贴边自动隐藏(仿QQ隐藏窗口) 1.移动无边框窗口 采用了消息的方式,可以实现通过窗口 ...
- python学习(3)
Python学习(3)切片(Slice):根据索引范围取出字符串里面的内容,比如: l=range(100) l[:8] [0, 1, 2, 3, 4, 5, 6, 7] ...
- Dublin Core
DC(Dublin Core) 是数字图书馆中使用的一组简单的包括15个“核心元素”的元数据元素集合,主要用于描述数字对象.馆藏管理和元数据交换. 这15项元数据不仅适用于电子文献目录,也适用于各类电 ...