婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > html5 canvas實現跟隨鼠標旋轉的箭頭

html5 canvas實現跟隨鼠標旋轉的箭頭

熱門標簽:中紳電銷智能機器人 濟南辦理400電話 跟電銷機器人做同事 威海營銷外呼系統招商 農村住宅地圖標注 鄭州電銷外呼系統違法嗎 ai電銷機器人連接網關 鶴壁手機自動外呼系統怎么安裝 漳州人工外呼系統排名

本文實例為大家分享了

XML/HTML Code復制內容到剪貼板
  1. <!DOCTYPE html>  
  2. <html>  
  3.  <head>    
  4.   <meta charset="utf-8" />    
  5.   <meta http-equiv="X-UA-Compatible" content="IE=edge" />    
  6.   <title>canvas實現跟隨鼠標旋轉的箭頭</title>    
  7.   <style>  
  8.     *{padding: 0;margin: 0}   
  9.     </style>    
  10.  </head>    
  11.  <body>    
  12.   <canvas width="500" height="500" style="border: 1px solid #555; display: block;margin: 0 auto;"></canvas>    
  13.   <script>  
  14.         var arrow=function () {   
  15.             this.x=0;    
  16.             this.y=0;   
  17.             this.color="#f90"  
  18.             this.rolation=0;   
  19.         }    
  20.         var canvas=document.querySelector('canvas')   
  21.         var ctx=canvas.getContext('2d');   
  22.         arrow.prototype.draw=function (ctx) {   
  23.             ctx.save();   
  24.             ctx.translate(this.x,this.y);   
  25.             ctx.rotate(this.rolation)   
  26.             ctx.fillStyle=this.color;   
  27.             ctx.beginPath();   
  28.             ctx.moveTo(0, 15);   
  29.             ctx.lineTo(-50, 15);   
  30.             ctx.lineTo(-50, -15);   
  31.             ctx.lineTo(0,-15);   
  32.             ctx.lineTo(0,-35);   
  33.             ctx.lineTo(50,0);   
  34.             ctx.lineTo(0,35);   
  35.             ctx.closePath()   
  36.             ctx.fill();   
  37.             ctx.restore();   
  38.         }   
  39.         var Arrow=new arrow();   
  40.         Arrow.x=canvas.width/2;   
  41.         Arrow.y=canvas.height/2;   
  42.            
  43.         var c_x,c_y; //相對于canvas坐標的位置;   
  44.         var isMouseDown=false;   
  45.         Arrow.draw(ctx)   
  46.         canvas.addEventListener('mousedown',function(e) {   
  47.             isMouseDown=true;   
  48.         },false)   
  49.         canvas.addEventListener('mousemove',function(e) {   
  50.             if(isMouseDown==true){   
  51.                 c_x=getPos(e).x-canvas.offsetLeft;   
  52.                 c_y=getPos(e).y-canvas.offsetTop;   
  53.                 //setInterval(drawFram,1000/60)   
  54.                 requestAnimationFrame(drawFram)   
  55.             }   
  56.         },false)   
  57.         canvas.addEventListener('mouseup',function(e) {   
  58.             isMouseDown=false;   
  59.         },false)   
  60.         function drawFram(){   
  61.             var dx=c_x-Arrow.x;   
  62.             var dy=c_y-Arrow.y;   
  63.             Arrow.rolation=Math.atan2(dy,dx);   
  64.             ctx.clearRect(0,0,canvas.width,canvas.height);   
  65.             Arrow.draw(ctx)   
  66.         }   
  67.         function getPos(e) {   
  68.             var mouse={x:0,y:0}   
  69.             var ee=e||event;   
  70.         
  71.             if(e.pageX||e.pageY){   
  72.                 mouse.x=e.pageX;   
  73.                 mouse.y=e.pageY;   
  74.             }else{   
  75.                 mouse.x=e.pageX+document.body.scrollLeft+document.document.documentElement.scrollLeft;   
  76.                 mouse.y=e.pageY+document.body.scrollTop+document.document.documentElement.scrollTop;   
  77.             }   
  78.             return mouse;   
  79.         }   
  80.     </script>     
  81.  </body>  
  82. </html>  

DEMO地址:http://codepen.io/jonechen/pen/eZpgWd

不廢話,直接上DEMO了,這個效果實現起來并不復雜,但是麻雀隨小,五臟俱全,主要涉及到的知識點有:

1、canvas的基本繪圖;
2、js各個事件的監聽;
3、js動畫;
4、三角函數結合js在canvas中的基本應用;

以上就是本文的全部內容,希望對大家的學習有所幫助。

原文:http://www.cnblogs.com/jone-chen/p/5243439.html

標簽:蘇州 紅河 咸陽 萍鄉 惠州 營口 文山 甘南

巨人網絡通訊聲明:本文標題《html5 canvas實現跟隨鼠標旋轉的箭頭》,本文關鍵詞  html5,canvas,實現,跟隨,鼠標,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《html5 canvas實現跟隨鼠標旋轉的箭頭》相關的同類信息!
  • 本頁收集關于html5 canvas實現跟隨鼠標旋轉的箭頭的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 津南区| 遵义市| 高要市| 临澧县| 大荔县| 昌平区| 宁都县| 阿尔山市| 于都县| 文山县| 泸水县| 沙湾县| 阳泉市| 西乌珠穆沁旗| 洮南市| 浦江县| 永登县| 阳原县| 天津市| 秀山| 获嘉县| 化德县| 南澳县| 长治县| 河南省| 金坛市| 朝阳县| 行唐县| 凤台县| 银川市| 桃园县| 高碑店市| 文水县| 昌乐县| 娱乐| 尖扎县| 平江县| 库车县| 乌兰浩特市| 太原市| 比如县|