佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > JavaScript+Canvas實(shí)現(xiàn)自定義畫(huà)板的示例代碼

JavaScript+Canvas實(shí)現(xiàn)自定義畫(huà)板的示例代碼

熱門(mén)標(biāo)簽:檢查注冊(cè)表項(xiàng) 使用U盤(pán)裝系統(tǒng) 硅谷的囚徒呼叫中心 美圖手機(jī) 百度競(jìng)價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 網(wǎng)站建設(shè) 阿里云 智能手機(jī)

最近研究了HTML5一些新的元素屬性,發(fā)現(xiàn)確實(shí)好用,特別是里面的Canvas這個(gè)新的標(biāo)簽元素。官方介紹:Canvas API(畫(huà)布)是在HTML5中新增的標(biāo)簽用于在網(wǎng)頁(yè)實(shí)時(shí)生成圖像,并且可以操作圖像內(nèi)容,基本上它是一個(gè)可以用JavaScript操作的位圖(bitmap)。以下使用JavaScript結(jié)合Canvas實(shí)現(xiàn)一個(gè)畫(huà)板功能

效果演示圖:

代碼部分(直接復(fù)制便可使用)

<!DOCTYPE HTML>
<html>
<head>  
<meta charset="utf-8" />  
<title>JavaScript+Canvas實(shí)現(xiàn)自定義畫(huà)板</title>
</head>
<body>
<canvas id="canvas"  width="600" height="300"></canvas>
<script type="text/javascript">   
  var canvas = document.getElementById("canvas");   
  var ctx = canvas.getContext("2d");   
  //畫(huà)一個(gè)黑色矩形   
  ctx.fillStyle="black";   
  ctx.fillRect(0,0,600,300);   
  //按下標(biāo)記   
  var onoff = false;  
  //變量oldx跟oldy代表鼠標(biāo)移動(dòng)前的坐標(biāo)  
  var oldx = -10;   
  var oldy = -10;   
  //設(shè)置顏色  
  var linecolor = "white";   
  //設(shè)置線寬   
  var linw = 4;   
  //添加鼠標(biāo)移動(dòng)事件   
  canvas.addEventListener("mousemove",draw,true);  //第三個(gè)參數(shù)主要跟捕獲或者冒泡有關(guān)   
  //添加鼠標(biāo)按下事件   
  canvas.addEventListener("mousedown",down,false);   
  //添加鼠標(biāo)彈起事件   
  canvas.addEventListener("mouseup",up,false);   
  function down(event){     
   onoff = true;     
   oldx = event.pageX-10;      
   oldy = event.pageY-10;  
   //console.log(event.pageX+'..............000.............'+event.pageY);
  //event.pageX跟event.pageY相對(duì)于整個(gè)頁(yè)面鼠標(biāo)的位置 包括溢出的部分(就是滾動(dòng)條)   
  }   
  function up(){     
   onoff = false;   
 }  
 function draw(event){    
  if(onoff == true){        
   var newx = event.pageX-10;        
   var newy = event.pageY-10;        
   ctx.beginPath();//beginPath() 丟棄任何當(dāng)前定義的路徑并且開(kāi)始一條新的路徑。它把當(dāng)前的點(diǎn)設(shè)置為 (0,0)。       
   ctx.moveTo(oldx,oldy);   //移動(dòng)到點(diǎn)擊時(shí)候的坐標(biāo),以那個(gè)坐標(biāo)為原點(diǎn)      
   ctx.lineTo(newx,newy);   //繪制新的路徑       
   ctx.strokeStyle=linecolor;       
   ctx.lineWidth=linw;       
   ctx.lineCap="round";       
   ctx.stroke();//stroke() 方法會(huì)實(shí)際地繪制出通過(guò) moveTo() 和 lineTo() 方法定義的路徑。默認(rèn)顏色是黑色。    
//將新的鼠標(biāo)位置賦給下一次開(kāi)始繪制的起始坐標(biāo)      
   oldx = newx;      
   oldy = newy;   
  };
 };
</script>
</body>
</html>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:懷化 煙臺(tái) 湖北 山南 湘潭 通遼 黃山 賀州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《JavaScript+Canvas實(shí)現(xiàn)自定義畫(huà)板的示例代碼》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    通州区| 双峰县| 敦化市| 库尔勒市| 宝兴县| 南陵县| 依兰县| 斗六市| 蒙阴县| 教育| 阳东县| 黔西| 青冈县| 云浮市| 横山县| 响水县| 连江县| 兴安盟| 阳朔县| 宜都市| 金川县| 小金县| 揭阳市| 东兰县| 云安县| 无为县| 铁力市| 浪卡子县| 安化县| 东台市| 安岳县| 铜鼓县| 乐亭县| 连州市| 隆化县| 来宾市| 高雄县| 元朗区| 仙游县| 泰州市| 江津市|