国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js繪制圓形和矩形的方法

2019-11-20 11:54:51
字體:
來源:轉載
供稿:網友

本文實例講述了js繪制圓形和矩形的方法。分享給大家供大家參考。具體如下:

這里使用js來繪制圓形和矩形,支持選擇圖形的背景顏色,同時可設置圓角矩形、半徑、正圓、矩形、正方形這幾個選項。或許這些圖形你不需要,但重要的是讓你學會JavaScript繪制圖形的方法,這是要表達的核心。

運行效果如下圖所示:

具體代碼如下:

<!doctype html><html><head><title>js來繪制圓形和矩形</title><style> *{margin:0; padding:0;} #div{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('div');   oR.id="div";   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> <div 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> </div> <div id="canvas"> </div></body></html>

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 弥渡县| 连江县| 博湖县| 革吉县| 石屏县| 丰顺县| 江源县| 育儿| 武夷山市| 马尔康县| 扶沟县| 阿合奇县| 北川| 玉林市| 内黄县| 阳西县| 小金县| 江达县| 平原县| 陆川县| 华安县| 庄浪县| 长宁县| 桓台县| 江北区| 新龙县| 全椒县| 四子王旗| 象山县| 寿光市| 富源县| 东乡县| 陆川县| 洛扎县| 清远市| 麟游县| 邓州市| 稻城县| 昌图县| 博野县| 名山县|