您好,欢迎访问一九零五行业门户网

如何使用JavaScript绘制圆形和矩形

本文实例讲述了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绘制圆形和矩形的详细内容。
其它类似信息

推荐信息