版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、Canvas實現(xiàn)畫圖、虛線、輔助線、線條顏色、線條寬度,整合加強版使用Canvas實現(xiàn)畫圖程序。本次更新主要實現(xiàn)了一下功能:虛線實線的選擇、輔助線、線條顏色選擇、線條寬度選擇進一步整理了下代碼,發(fā)現(xiàn)了不少很有用的寫法,具體看下面。效果截圖:源代碼:HTML代碼html view plaincopy1. <!docutype html> 2. <!-date 2014-12-28-> 3. <html> 4. <
2、head> 5. <meta http-equiv="content-type" content="text/html; charset=utf-8" /> 6. <style type="text/css"> &
3、#160;7. canvas 8. background-color: rgb(247, 247, 247); 9.
4、 margin-top: 10px; 10. 11. </style> 12. </head>
5、; 13. <body> 14. <div class="controls"> 15. 線條類型<select id="lineTypeSelectBox"
6、> 16. <option value="solid">實線</option> 17. <option value="dashed">虛線</option>
7、; 18. </select> 19. 線條顏色<select id="strokeColorSelectBox"> 20.
8、60; <option value="black">black</option> 21. <option
9、0;value="red">red</option> 22. <option value="blue">blue</option> 23.
10、 </select> 24. 線條寬度<select id="lineWidthSelectBox"> 25.
11、0; <option value="1">1</option> 26. <option value="2">2</option> 27.
12、 <option value="4">4</option> 28. </select>
13、0; 29. 網(wǎng)格線<input id="gridCheckBox" type="checkbox" checked="checked" > 30.
14、60; 坐標軸<input id="axesCheckBox" type="checkbox" checked="checked" > 31. 輔助線<input id="guideWiresCheck
15、Box" type="checkbox" checked="checked" > 32. <input type="button" value="清除畫布" id="eraseAllButton"> 33.
16、160; </div> 34. <!-canvas默認大小300*150-> 35. <canvas id="canvas" width="800" height="500"
17、> 36. </canvas> 37. </body> 38. <!-導入繪制坐標、網(wǎng)格的js文件-> 39. <script&
18、#160;type = "text/javascript" src ="mikuCanvasAxes.js"></script> 40. <!-導入繪制虛線的js文件-> 41. <script type = &quo
19、t;text/javascript" src ="mikuCanvasLine.js"></script> 42. <!-導入主要繪圖js文件-> 43. <!- 44.
20、 全局變量定義 45. 函數(shù):窗口坐標轉(zhuǎn)換為Canvas坐標、保存還原當前繪圖表面數(shù)據(jù)、橡皮筋法相關(guān)函數(shù)、繪制輔助線相關(guān)函數(shù)、初始化函數(shù) 46. 事件處理:鼠標down,move,up事件、按鈕點擊事件、單選框
21、變化事件 47. -> 48. <script type = "text/javascript" src ="mikuCanvasPaintAppMain.js"></script> 49. </html>
22、160; 繪制坐標軸與網(wǎng)格html view plaincopy1. <!docutype html> 2. <!-date 2014-12-28-> 3. <html> 4. <head> 5. <meta http-equiv="content-ty
23、pe" content="text/html; charset=utf-8" /> 6. <style type="text/css"> 7. canvas 8.
24、; 9. 10. </style> 11.
25、0; <script type = "text/javascript" src ="mikuCanvasAxes.js"></script> 12. </head> 13. <body> 14.
26、; <div class="controls"> 15. 網(wǎng)格線<input id="gridCheckBox" type="checkbox" checked="checked" > 16.
27、60; 坐標軸<input id="axesCheckBox" type="checkbox" checked="checked" > 17. <input type="button&quo
28、t; value="清除畫布" id="eraseAllButton"> 18. </div> 19. <!-canvas默認大小300*150-> 20.
29、;<canvas id="canvas" width="800" height="500"> 21. </canvas> 22. </body> 23. <script type="text
30、/javascript"> 24. /Vars- 25. var canvas =document.getElementById("canvas"), 26.
31、60; context =canvas.getContext("2d"), 27. /正在繪制的繪圖表面變量 28. drawingSurfaceImageData, 29.
32、60; /鼠標按下相關(guān)對象 30. mousedown = , 31. /橡皮筋矩形對象 32.
33、; rubberbandRect = , 33. /拖動標識變量 34. dragging = false;&
34、#160; 35. /控制對象 36. var eraseAllButton = document.getElementById("eraseAllButton"), 37.
35、0; axesCheckBox = document.getElementById("axesCheckBox"), 38. /檢測axesCheckBox是否被選中 39. haveAxes =
36、axesCheckBox.checked; 40. var gridCheckBox = document.getElementById("gridCheckBox"); 41. var haveGrid = gridCheckBox.checked; 42.
37、 /Functions- 43. /將窗口坐標轉(zhuǎn)換為Canvas坐標 44. /傳入?yún)?shù):窗口坐標(x,y) 45. function win
38、dowToCanvas(x,y) 46. /獲取canvas元素的邊距對象 47. var bbox = canvas.getBoundingClientRect(); 48. &
39、#160; /返回一個坐標對象 49. /類似json的一種寫法 50. return 51.
40、0; x : x - bbox.left*(canvas.width/bbox.width), 52. y&
41、#160;: y - bbox.top*(canvas.height/bbox.height) 53. 54. 55.
42、0;/保存當前繪圖表面數(shù)據(jù) 56. function saveDrawingSurface() 57. /從上下文中獲取繪圖表面數(shù)據(jù) 58. drawingSurfaceImageData
43、 = context.getImageData(0,0,canvas.width,canvas.height); 59. 60. /還原當前繪圖表面 61. function restoreDrawingSurfa
44、ce() 62. /將繪圖表面數(shù)據(jù)還原給上下文 63. context.putImageData(drawingSurfaceImageData,0,0); 64. 65.
45、 /橡皮筋相關(guān)函數(shù) 66. 67. /更新橡皮筋矩形+對角線 68. /傳入?yún)?shù):坐標對象loc 69.
46、; function updateRubberband(loc) 70. updateRubberbandRectangle(loc); 71. drawRubberbandShape(l
47、oc); 72. 73. /更新橡皮筋矩形 74. /傳入?yún)?shù):坐標對象loc 75. function updat
48、eRubberbandRectangle(loc) 76. /獲得矩形的寬 77. rubberbandRect.width = Math.abs(loc.x - mousedown.x); 78.
49、60; /獲得矩形的高 79. rubberbandRect.height = Math.abs(loc.y - mousedown.y); 80.
50、0; /獲得矩形頂點的位置(left,top) 81. /如果鼠標按下的點(起點)在當前點的的左側(cè) 82. /這里畫一下圖就懂了 83. &
51、#160; if(loc.x > mousedown.x) 84. rubberbandRect.left = mousedown.x; 85.
52、60; else 86. rubberbandRect.left = loc.x; 87. 88.
53、60; if(loc.y > mousedown.y) 89. rubberbandRect.top = mousedown.y; 90.
54、 else 91. rubberbandRect.top = loc.y; 92. 93. &
55、#160; 94. /繪制橡皮筋矩形的對角線 95. /傳入?yún)?shù):坐標對象loc 96. function drawRubberbandShape(loc)
56、0;97. /alert("draw"); 98. context.beginPath(); 99. c
57、ontext.moveTo(mousedown.x,mousedown.y); 100. context.lineTo(loc.x,loc.y); 101. context.stroke(); 102.
58、60; 103. /事件處理- 104. canvas.onmousedown = function(e) 105. var loc
59、 =windowToCanvas(e.clientX,e.clientY); 106. e.preventDefault(); 107. saveDrawingSurface(); 108.
60、0; mousedown.x = loc.x; 109. mousedown.y = loc.y; 110. dragging = true; 111.
61、 112. 113. canvas.onmousemove = function(e) 114.
62、160; var loc; 115. if(dragging) 116. e.preventDefault(); 117.
63、60; loc = windowToCanvas(e.clientX,e.clientY); 118. restoreDrawingSurface(); 119. &
64、#160; updateRubberband(loc); 120. 121. 122.
65、 canvas.onmouseup = function(e) 123. loc = windowToCanvas(e.clientX,e.clientY); 124. restoreDrawingSurf
66、ace(); 125. updateRubberband(loc); 126. dragging = false; 127.
67、160; 128. eraseAllButton.onclick = function(e) 129. context.clearRect(0,0,canvas.width,canvas.height); 130.
68、; initialization(); 131. saveDrawingSurface(); 132. 133. axesCh
69、eckBox.onchange = function(e) 134. haveAxes = axesCheckBox.checked; 135. initialization(); 136. &
70、#160; 137. gridCheckBox.onchange = function(e) 138. haveGrid = gridCheckBox.checked; 139. &
71、#160; initialization(); 140. 141. /Initialization- 142. f
72、unction initialization() 143. /清除畫布 144. context.clearRect(0,0,canvas.width,canvas.height); 145.
73、60; if(haveAxes) 146. drawAxes(context,40); 147. 148.
74、60; if(haveGrid) 149. drawGrid(context,10,10); 150.
75、; 151. 152. /入口 153. initialization(); 154. </script> 155. </html&g
76、t; 繪制網(wǎng)格與坐標軸的js文件javascript view plaincopy1. /Classes- 2. function mikuLoc(locX,locY) 3. this.x = locX; 4. this.y = locY; 5. 6. /Contents- 7. var
77、 GRID_STYLE = "lightgray", 8. GRID_LINE_WIDTH = 0.5; 9. 10. var AXES_STYLE = "#a2a2a2", 11. AXES_LINE_WIDTH = 1, 1
78、2. VERTICAL_TICK_SPACING = 10, 13. HORIZONTAL_TIKE_SPACING = 10, 14. TICK_WIDTH = 10; 15. /Function- 16. /繪制網(wǎng)格 17. /傳入?yún)?shù)為:繪圖環(huán)境,x軸間隔,y軸間隔 &
79、#160;18. function drawGrid(context,stepx,stepy) 19. context.save(); 20. context.strokeStyle = GRID_STYLE; 21. /設(shè)置線寬為0.5 22. context.lineWidth
80、0; = GRID_LINE_WIDTH; 23. /繪制x軸網(wǎng)格 24. /注意:canvas在兩個像素的邊界處畫線 25. /由于定位機制,1px的線會變成2px 26. /于是要+0.5 27. for(var&
81、#160;i=stepx+0.5;i<context.canvas.width;i=i+stepx) 28. /開啟路徑 29. context.beginPath(); 30. context.moveTo(i,0);
82、0;31. context.lineTo(i,context.canvas.height); 32. context.stroke(); 33. 34.
83、60;/繪制y軸網(wǎng)格 35. for(var i=stepy+0.5;i<context.canvas.height;i=i+stepy) 36. context.beginPath(); 37. context.moveTo(0,i); 38.
84、0; context.lineTo(context.canvas.width,i); 39. context.stroke(); 40. 41. context.restore(); 42
85、. ; 43. /Function- 44. /繪制坐標軸 45. /傳入?yún)?shù)為:繪圖環(huán)境,坐標軸邊距 46. function drawAxes(context,axesMargin) 47. /保存樣式 48. context.save(); 49. var originLoc
86、 = new mikuLoc(axesMargin, context.canvas.height-axesMargin); 50. var axesW = context.canvas.width - (axesMargin*2), 51. axesH = context.canvas.h
87、eight - (axesMargin*2); 52. /設(shè)置坐標繪圖樣式繪圖樣式 53. context.strokeStyle = AXES_STYLE; 54. context.lineWidth = AXES_LINE_WIDTH; 55.
88、 /繪制x,y軸 56. drawHorizontalAxis(); 57. drawVerticalAxis(); 58. drawVerticalAxisTicks(); 59. drawHorizontalAxisTicks(); 60.
89、160; /恢復樣式 61. context.restore(); 62. 63. /繪制x軸 64. function drawHorizontalAxis() 65.
90、0; context.beginPath(); 66. context.moveTo(originLoc.x, originLoc.y); 67. context.lineTo(originLoc.x + axesW, originLoc.y); 68.
91、 context.stroke(); 69. 70. /繪制y軸 71. function drawVerticalAxis() 72. context.beginPath();
92、73. context.moveTo(originLoc.x, originLoc.y); 74. context.lineTo(originLoc.x, originLoc.y - axesH); 75. context.st
93、roke(); 76. 77. /繪制垂直軸小標標 78. function drawVerticalAxisTicks() 79. var deltaX; 80. &
94、#160; /當前垂直tick的y軸坐標 81. var nowTickY =originLoc.y-VERTICAL_TICK_SPACING; 82. for(var i=1;i<=(axesH/VERTICAL_TICK_SPACING);i+) 83.
95、; if(i%5 = 0) 84. deltaX=TICK_WIDTH; 85.
96、else 86. deltaX=TICK_WIDTH/2; 87. 88.
97、 context.beginPath(); 89. /移動到當前的tick起點 90. context.moveTo(originLoc.x-deltaX,nowTickY);
98、;91. context.lineTo(originLoc.x+deltaX,nowTickY); 92. context.stroke(); 93.
99、0; nowTickY=nowTickY-VERTICAL_TICK_SPACING; 94. 95. 96. /繪制水平軸小標標 97. function drawHorizontalAxisTicks() 98
100、. var deltaY; 99. var nowTickX = originLoc.x+HORIZONTAL_TIKE_SPACING; 100. for(var i=1;i<=(axesW/HOR
101、IZONTAL_TIKE_SPACING);i+) 101. if(i%5 = 0) 102. deltaY = TICK_WIDTH; 103.
102、; else 104. deltaY = TICK_WIDTH/2; 105. &
103、#160; 106. context.beginPath(); 107. context.moveTo(nowTickX,originLoc.y+deltaY); 108.
104、 context.lineTo(nowTickX,originLoc.y-deltaY); 109. context.stroke(); 110. nowTick
105、X = nowTickX + HORIZONTAL_TIKE_SPACING; 111. 112. 113. ; 繪制虛線javascript view plaincopy1. /繪制虛線 2. /傳入?yún)?shù):上下文,起點,終點,虛線間隔 3. function
106、;drawDashedLine(context,x1,y1,x2,y2,dashLength) 4. /運用三元表達式實現(xiàn)默認參數(shù) 5. dashLength = dashLength=undefined ? 5 : dashLength; 6.
107、; /水平長度 7. var deltaX = x2 - x1; 8. /垂直長度 9. var deltaY =
108、160;y2 - y1; 10. /虛線數(shù)量 11. var numDashed = Math.floor( 12. Math.sqrt(delta
109、X*deltaX+deltaY*deltaY)/dashLength 13. ); 14. /開始繪制 15. context.beginPath(); 16. &
110、#160; for(var i=0; i<numDashed;i+) 17. /這種寫法太強大了 18. /(deltaX/numDashed)是指虛線的長度 19.
111、60; contexti%2=0 ? "moveTo":"lineTo"(x1+(deltaX/numDashed)*i,y1+(deltaY/numDashed)*i); 20. 21.
112、60; /要記得描線啊 22. context.stroke(); 23. /結(jié)束繪制 24. context.closePath(); 25. 主要繪圖代碼java
113、script view plaincopy1. /Vars- 2. var canvas =document.getElementById("canvas"), 3. context =canvas.getContext("2d"),&
114、#160; 4. /正在繪制的繪圖表面變量 5. drawingSurfaceImageData, 6. /鼠標按
115、下相關(guān)對象 7. mousedown = , 8. /橡皮筋矩形對象 9. rub
116、berbandRect = , 10. /拖動標識變量 11. dragging = false; 12. &
117、#160; 13. /控件 14. /擦除畫布的控制 15. var eraseAllButton = document.getElementById("eraseAllButton");
118、0;16. /坐標軸的控制 17. var axesCheckBox = document.getElementById("axesCheckBox"); 18. /網(wǎng)格線的控制 19.
119、0; var gridCheckBox = document.getElementById("gridCheckBox"); 20. /輔助線的控制 21. var guideWiresCheckBox =
120、60;document.getElementById("guideWiresCheckBox"); 22. /線條顏色的控制 23. var strokeColorSelectBox =document.getElementById("strokeColorSelectBox");
121、; 24. /線條樣式的控制 25. var lineTypeSelectBox = document.getElementById("lineTypeSelectBox"); 26. /線條寬度的控制
122、60; 27. var lineWidthSelectBox = document.getElementById("lineWidthSelectBox"); 28. /Functions- 29. /將窗口坐標轉(zhuǎn)換為Canvas坐標 30. &
123、#160; /傳入?yún)?shù):窗口坐標(x,y) 31. function windowToCanvas(x,y) 32. /獲取canvas元素的邊距對象 33.
124、60; var bbox = canvas.getBoundingClientRect(); 34. /返回一個坐標對象 35. /類似json的一種寫法 3
125、6. return 37. x : x - bbox.left*(canvas.width/bbox.width), 3
126、8. y : y - bbox.top*(canvas.height/bbox.height) 39. &
127、#160; 40. 41. /保存當前繪圖表面數(shù)據(jù) 42. function saveDrawingSurface() 43.
128、 /從上下文中獲取繪圖表面數(shù)據(jù) 44. drawingSurfaceImageData = context.getImageData(0,0,canvas.width,canvas.height); 45. 46.
129、; /還原當前繪圖表面 47. function restoreDrawingSurface() 48. /將繪圖表面數(shù)據(jù)還原給上下文 49. conte
130、xt.putImageData(drawingSurfaceImageData,0,0); 50. 51. /橡皮筋相關(guān)函數(shù) 52. 53.
131、60; /更新橡皮筋矩形+對角線 54. /傳入?yún)?shù):坐標對象loc 55. function updateRubberband(loc) 56. updateRubberban
132、dRectangle(loc); 57. drawRubberbandShape(loc); 58. 59. /更新橡皮筋矩形 60. &
133、#160; /傳入?yún)?shù):坐標對象loc 61. function updateRubberbandRectangle(loc) 62. /獲得矩形的寬 63.
134、60; rubberbandRect.width = Math.abs(loc.x - mousedown.x); 64. /獲得矩形的高 65. rubberbandR
135、ect.height = Math.abs(loc.y - mousedown.y); 66. /獲得矩形頂點的位置(left,top) 67. /如果鼠標按下的點(起點)在當前點的的左側(cè) 68.
136、0; /這里畫一下圖就懂了 69. if(loc.x > mousedown.x) 70.
137、0; rubberbandRect.left = mousedown.x; 71. else 72. rubberbandRect.left = loc.x;
138、 73. 74. if(loc.y > mousedown.y) 75.
139、 rubberbandRect.top = mousedown.y; 76. else 77. rubberbandRect.top =
140、0;loc.y; 78. 79. 80. /繪制橡皮筋矩形的對角線 81.
141、/傳入?yún)?shù):坐標對象loc 82. function drawRubberbandShape(loc) 83. /獲取當前線條類型 84.
142、var lineType = lineTypeSelectBox.value; 85. /獲取當前線條顏色 86. var lineColor = strokeColorSelectBox.value;
143、60; 87. /獲取當前線條寬度 88. var lineWidth = lineWidthSelectBox.value; 89.
144、0; /有改變context畫筆屬性就要做畫筆保護 90. context.save(); 91. context.strokeStyle = lineColor; 92.
145、60; context.lineWidth = lineWidth; 93. if(lineType = "solid") 94.
146、60; /alert("draw"); 95. /注意重新開始路徑 96. context.beginPath(); 97.
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度農(nóng)村住房光伏發(fā)電設(shè)施租賃合同
- 2025年度農(nóng)村個人房屋買賣合同附宅基地使用權(quán)變更合同3篇
- 2025年度公司對賭協(xié)議合同-技術(shù)研發(fā)與創(chuàng)新成果轉(zhuǎn)化3篇
- 2025年農(nóng)村公路養(yǎng)護與智慧交通系統(tǒng)合作合同2篇
- 2025年度特色養(yǎng)殖場土地租賃及合作開發(fā)合同3篇
- 二零二五年度農(nóng)村房屋買賣與能源供應合同
- 二零二五年度公司員工勞動合同簽訂與解除管理補充協(xié)議3篇
- 二零二五年度網(wǎng)絡信息安全分攤保障合同3篇
- 二零二五年度農(nóng)村房屋贈與合同附農(nóng)業(yè)資源循環(huán)利用合同
- 2025年度養(yǎng)豬場養(yǎng)殖廢棄物處理設(shè)施升級改造轉(zhuǎn)讓合同3篇
- 船舶安全停靠協(xié)議書
- 幼師課例分析報告總結(jié)與反思
- 醫(yī)院門診醫(yī)療費用管理制度
- 2024年回遷房買賣合同樣本(5篇)
- 《大數(shù)據(jù)技術(shù)原理與應用(第3版)》期末復習題庫(含答案)
- 項目15-1 蛋黃中免疫球蛋白的提取
- MOOC 中國哲學經(jīng)典著作導讀-西安交通大學 中國大學慕課答案
- 醫(yī)院培訓課件:《痞滿(少陽太陰合病)患者中醫(yī)個案護理》
- 泌尿外科抗菌藥物臨床應用規(guī)范
- JJG 633-2024 氣體容積式流量計
- 2023年河北中煙工業(yè)有限責任公司筆試試題及答案
評論
0/150
提交評論