本文实例讲述了js绘制圆形和矩形的方法。分享给大家供大家参考。具体如下:
这里使用js来绘制圆形和矩形,支持选择图形的背景颜色,同时可设置圆角矩形、半径、正圆、矩形、正方形这几个选项。或许这些图形你不需要,但重要的是让你学会javascript绘制图形的方法,这是要表达的核心。
运行效果如下图所示:
具体代码如下:
<!doctype html>
<html>
<head>
<title>js来绘制圆形和矩形</title>
<style>
*{margin:0; padding:0;}
#p{position:absolute; background:#ccc;}
.sel{ margin:30px auto; width:960px; overflow:hidden}
li{ list-style:none; float:left; width:60px; height:20px;}
#colors{ width:500px; float:left}
.selcolor{ float:left}
#radius{ width:40px; height:20px;}
.red{background:red;}
.yellow{background:yellow;}
.blue{background:blue;}
.pink{background:pink;}
.black{background:black;}
.orange{background:orange;}
.green{ background:green;}
.xz{ width:340px; float:right;}
#canvas{ width:960px; height:500px; border:1px solid #ccc; margin:0 auto}
</style>
<script>
function $id(id)
{
return document.getelementbyid(id);
}
window.onload=function(){
var ocanvas=$id("canvas");
var oroud=$id("roud");
var oradius=$id("radius");
var ocir=$id("circle");
var osqu=$id("squ");
var ocolors=$id("colors");
var acolors=ocolors.getelementsbytagname("li");
var color="red";
var ainputs=document.getelementsbytagname("input");
var xz="roud";
var arr=[];
for(var i=0;i<ainputs.length;i++)
{
if(ainputs[i].type=="checkbox")
{
arr.push(ainputs[i]);
}
}
for(var i=0;i<arr.length;i++)
{
arr[i].onclick=function()
{
if(!this.checked)
{
this.checked=false;
}
else
{
for(var j=0;j<arr.length;j++)
{
arr[j].checked=false;
}
this.checked=true;
xz=this.value;
}
}
}
//选择颜色
for(var i=0;i<acolors.length;i++)
{
acolors[i].onclick=function()
{
color=this.classname;
}
}
ocanvas.onmousedown=function(ev)
{
if(ocanvas.setcapture)
{
ocanvas.setcapture();
}
for(var i=0;i<arr.length;i++)
{
if(arr[i].checked)
{
arr[i].checked=true;
xz= arr[i].value;
}
}
var oev=ev||window.event;
var disx=oev.clientx;
var disy=oev.clienty;
var or=document.createelement("p");
or.id="p";
or.style.top=disy+"px";
or.style.left=disx+"px";
or.style.backgroundcolor=color;
document.body.appendchild(or);
document.onmousemove=function(ev)
{
var oev=ev||window.event;
var x=oev.clientx;
var y=oev.clienty;
if(x<ocanvas.offsetleft)
{
x=ocanvas.offsetleft;
}
else if(x>ocanvas.offsetleft+ocanvas.offsetwidth)
{
x=ocanvas.offsetleft+ocanvas.offsetwidth
}
if(y<ocanvas.offsettop)
{
y=ocanvas.offsettop;
}
else if(y>ocanvas.offsettop+ocanvas.offsetheight)
{
y=ocanvas.offsettop+ocanvas.offsetheight
}
or.style.width=math.abs(x-disx)+"px";
or.style.top=math.min(disy,y)+"px";
or.style.left=math.min(disx,x)+"px";
switch(xz)
{
case "roud":
or.style.height=math.abs(y-disy)+"px";
or.style.borderradius=oradius.value+"px";
break;
case "circle":
or.style.height=math.min(math.abs(x-disx),math.abs(y-disy))+"px";
or.style.width=math.min(math.abs(x-disx),math.abs(y-disy))+"px";
or.style.borderradius=(math.min(math.abs(x-disx),math.abs(y-disy)))/2+"px";
break;
case "squ":
or.style.height=math.abs(y-disy)+"px";
break;
case "square":
or.style.height=math.min(math.abs(x-disx),math.abs(y-disy))+"px";
or.style.width=math.min(math.abs(x-disx),math.abs(y-disy))+"px";
}
}
document.onmouseup=function()
{
document.onmousemove=null;
document.onmouseout=null;
if(ocanvas.releasecapture)
{
ocanvas.releasecapture();
}
}
return false;
}
}
</script>
</head>
<body>
<p class="sel">
<span class="selcolor">请选择一种颜色</span>
<ul id="colors">
<li value="red" class="red"></li>
<li value="yellow" class="yellow"></li>
<li value="blue" class="blue"></li>
<li value="pink" class="pink"></li>
<li value="black" class="black"></li>
<li value="orange" class="orange"></li>
<li value="green" class="green"></li>
</ul>
<p class="xz">
<input type="checkbox" value="roud" id="roud" />圆角矩形
<label>半径</label><input type="text" value="" id="radius" />
<input type="checkbox" id="circle" value="circle" />正圆
<input type="checkbox" id="squ" value="squ" />矩形
<input type="checkbox" id="square" value="square" />正方形
</p>
</p>
<p id="canvas">
</p>
</body>
</html>
以上就是如何使用javascript绘制圆形和矩形的详细内容。