本文实例讲述了js绘制圆形和矩形的方法。分享给大家供大家参考。具体如下:
这里使用js来绘制圆形和矩形,支持选择图形的背景颜色,同时可设置圆角矩形、半径、正圆、矩形、正方形这几个选项。或许这些图形你不需要,但重要的是让你学会JavaScript绘制图形的方法,这是要表达的核心。
运行效果如下图所示:

具体代码如下:
立即学习“Java免费学习笔记(深入)”;
zuojiankuohaophpcn!doctype html>
zuojiankuohaophpcnhtml>
zuojiankuohaophpcnhead>
zuojiankuohaophpcntitle>js来绘制圆形和矩形zuojiankuohaophpcn/title>
zuojiankuohaophpcnstyle>
*{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}
zuojiankuohaophpcn/style>
zuojiankuohaophpcnscript>
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;izuojiankuohaophpcnaInputs.length;i++)
{
if(aInputs[i].type=="checkbox")
{
arr.push(aInputs[i]);
}
}
for(var i=0;izuojiankuohaophpcnarr.length;i++)
{
arr[i].onclick=function()
{
if(!this.checked)
{
this.checked=false;
}
else
{
for(var j=0;jzuojiankuohaophpcnarr.length;j++)
{
arr[j].checked=false;
}
this.checked=true;
xz=this.value;
}
}
}
//选择颜色
for(var i=0;izuojiankuohaophpcnaColors.length;i++)
{
aColors[i].onclick=function()
{
color=this.className;
}
}
oCanvas.onmousedown=function(ev)
{
if(oCanvas.setCapture)
{
oCanvas.setCapture();
}
for(var i=0;izuojiankuohaophpcnarr.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(xzuojiankuohaophpcnoCanvas.offsetLeft)
{
x=oCanvas.offsetLeft;
}
else if(x>oCanvas.offsetLeft+oCanvas.offsetWidth)
{
x=oCanvas.offsetLeft+oCanvas.offsetWidth
}
if(yzuojiankuohaophpcnoCanvas.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;
}
}
zuojiankuohaophpcn/script>
zuojiankuohaophpcn/head>
zuojiankuohaophpcnbody>
zuojiankuohaophpcnp class="sel">
zuojiankuohaophpcnspan class="selColor">请选择一种颜色zuojiankuohaophpcn/span>
zuojiankuohaophpcnul id="colors">
zuojiankuohaophpcnli value="red" class="red">zuojiankuohaophpcn/li>
zuojiankuohaophpcnli value="yellow" class="yellow">zuojiankuohaophpcn/li>
zuojiankuohaophpcnli value="blue" class="blue">zuojiankuohaophpcn/li>
zuojiankuohaophpcnli value="pink" class="pink">zuojiankuohaophpcn/li>
zuojiankuohaophpcnli value="black" class="black">zuojiankuohaophpcn/li>
zuojiankuohaophpcnli value="orange" class="orange">zuojiankuohaophpcn/li>
zuojiankuohaophpcnli value="green" class="green">zuojiankuohaophpcn/li>
zuojiankuohaophpcn/ul>
zuojiankuohaophpcnp class="xz">
zuojiankuohaophpcninput type="checkbox" value="roud" id="roud" />圆角矩形
zuojiankuohaophpcnlabel>半径zuojiankuohaophpcn/label>zuojiankuohaophpcninput type="text" value="" id="radius" />
zuojiankuohaophpcninput type="checkbox" id="circle" value="circle" />正圆
zuojiankuohaophpcninput type="checkbox" id="squ" value="squ" />矩形
zuojiankuohaophpcninput type="checkbox" id="square" value="square" />正方形
zuojiankuohaophpcn/p>
zuojiankuohaophpcn/p>
zuojiankuohaophpcnp id="canvas">
zuojiankuohaophpcn/p>
zuojiankuohaophpcn/body>
zuojiankuohaophpcn/html>











