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

主頁 > 知識庫 > HTML5 繪制圖像(上)之:關于canvas元素引領下一代web頁面的問題

HTML5 繪制圖像(上)之:關于canvas元素引領下一代web頁面的問題

熱門標簽:咸陽穩定外呼系統軟件 怎么做百度地圖標注 四川移動電銷外呼客戶管理系統 小朱地圖標注 400開頭的電話好申請不 地圖標注柱狀圖 百度地圖標注為什么總是封號 臨海地圖標注app 智能芯電話機器人
初識canvas元素

HTML5新增了一個元素canvas,用于繪圖使用,其實它的表現和div比較接近(其實他應該屬于inline-block),而提供了許多接口,從而輕易的繪制矩形框、園三角形等

PS:關于HTML5新增元素
經過最近兩天的學習,和以前對HTML5的認知,我認為HTML5其實還是HTML4,兩者之間沒多大的區別,無非是增加了點新東西。
我認為HTML5為我們帶來的真正意義是:我們可以用javascript做更多的事情了;我們可以用javascript實現更好的產品了。比如HTML5就解決了我們頭疼的跨域問題、實時通信API、與現在的canvas之所以HTML5叫HTML5,我認為他是劃時代的,比如他讓我們用網頁開發游戲變成可能;比如他讓電腦桌面只剩IE不在是傳說(過于夸張)
繪制矩形框

直入正題,我們來繪制一個矩形框看看,這里提供一個顏色選擇器用于方便的選擇顏色,PS:現在不用jquery編程感覺真麻煩。。。

 問題:定義樣式與定義height與width

 一來就遇到了問題,我這里先來截個圖:

復制代碼
代碼如下:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充畫布結束

context.strokeStyle = 'red';
context.fillStyle = 'gray';
context.lineWidth = 1;
context.fillRect(10, 10, 100, 100);
context.strokeRect(10, 10, 100, 100);

context.clearRect(20, 20, 20, 20);
}
</script>
</head>
<body>
<canvas id="canvas" width=300 height="200" style="border: 1px solid black; width: 300px; height: 200px;">
</canvas>


<button onclick="draw();">
繪制矩形</button>
<input type="color" />
</body>
</html>

  各位情況canvas元素,圖一位設置width與height的情況,圖二十用style指定的情況:

可以看到,對于canvas來說,還是老老實實定義高寬的好,別去傻乎乎的用樣式了,當然這個問題需要實際研究才能得出最終結論。

好了,現在我們再來看看繪制矩形這個方法:

PS:其實,使用該方法這么麻煩,完全可以將該函數封裝下下,使用便會簡單許多
1、使用getElementById方法獲取繪制對象2、取得上下文getContext('2d'),這都是固定的寫法3、指定填充的顏色fillStyle和繪制的顏色strokeStyle,即里面的顏色和邊框的顏色4、指定線寬linewidth5、填充/繪制 fillRect/strokeRect 參數為 x,y,width,height6、若是要使其中一塊透明,使用clearRect

至此,繪制矩形框便暫時告一段落。

繪制圓形

現在我們來繪制圓形,這個說起繪制圓形,其實我原來用js好像寫過一個,這里也貼出來看看:

復制代碼
代碼如下:

我是純js畫的圓
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<style type="text/css">
div
{
position: absolute;
width: 1px;
height: 1px;
line-height: 1px;
}
</style>
<script src="http://www.cnblogs.com/jquery-1.7.1.js" type="text/javascript"></script>
<script type="text/javascript">
//x2 + y2 = r2;
$(document).ready(function () {
//先畫x,y
var box = $('#box');
var NUM = 200;
var R = NUM / 2;
var RR = R * R;
for (var i = 0; i <= NUM; i = i + 6) {
//var divX = $('<div style="left:' + i + 'px;top:' + R + 'px;">*</div>')
// var divY = $('<div style="top:' + i + 'px;left:' + R + 'px;">*</div>')

var ti = i;
//sqrt(x)
if (ti > R) {
ti = ti - R;
var ty = Math.sqrt((RR - ti * ti));
var y = $('<div style="left:' + (R - ty) + 'px;top:' + i + 'px;">*</div>')
var y1 = $('<div style="left:' + (R + ty) + 'px;top:' + i + 'px;">*</div>')
box.append(y);
box.append(y1);
} else if (ti < R) {
ti = R - ti;
var ty = Math.sqrt((RR - ti * ti));
var y = $('<div style="left:' + (R - ty) + 'px;top:' + i + 'px;">*</div>')
var y1 = $('<div style="left:' + (R + ty) + 'px;top:' + i + 'px;">*</div>')
box.append(y);
box.append(y1);
}
//box.append(divX);
//box.append(divY);
}

for (var i = 0; i <= NUM; i = i + 6) {
//var divX = $('<div style="left:' + i + 'px;top:' + R + 'px;">*</div>')
// var divY = $('<div style="top:' + i + 'px;left:' + R + 'px;">*</div>')
var ti = i;
//sqrt(x)
if (ti > R) {
ti = ti - R;
var ty = Math.sqrt((RR - ti * ti));
var y = $('<div style="top:' + (R - ty) + 'px;left:' + i + 'px;">*</div>')
var y1 = $('<div style="top:' + (R + ty) + 'px;left:' + i + 'px;">*</div>')
box.append(y);
box.append(y1);
} else if (ti < R) {
ti = R - ti;
var ty = Math.sqrt((RR - ti * ti));
var y = $('<div style="top:' + (R - ty) + 'px;left:' + i + 'px;">*</div>')
var y1 = $('<div style="top:' + (R + ty) + 'px;left:' + i + 'px;">*</div>')
box.append(y);
box.append(y1);
}
}
});

</script>
</head>
<body>
<div id="box" style="width: 504px; height: 504px; position: relative; top: 20px;
left: 300px; border: 0px solid black;">
</div>
</body>
</html>

話說,他還是比較圓的說。。。

進入正題

說起畫圓、正弦圖等肯定會經過一定計算的,所以稍稍復雜點:

① 創建路徑

② 創建圖形路徑

③ 路徑創建完成后關閉路徑

④ 設定繪制樣式調用方法繪制之

復制代碼
代碼如下:

我是一個圓
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充畫布結束
for (var i = 0; i < 5; i++) {
context.beginPath();
context.arc(i * 25, i * 25, i * 10, 0, Math.PI * 2, true);
context.closePath();
context.strokeStyle = 'red';
context.fill();
}
}
</script>
</head>
<body>
<canvas id="canvas" width="300" height="200" >
</canvas>

<button onclick="draw();">
繪制圓</button>
<input type="color" />
</body>
</html>

我們來看看繪制圓過程中其它地方都沒有問題,但是創建圓路徑這塊值得考慮:

arc方法參數很多,依次是:xy半徑開始弧度(我們一般喜歡角度,所以要轉換)結束弧度順時針或者逆時針true為順時針
其它都好說,主要這個開始角度和結束角度我們來研究下,因為開始我沒搞懂,但后來我發現他其實很簡單了。。。就是開始的角度和結束的角度嘛,和我們高中學的知識一樣的,只不過單位換算Math.PI/180為一度。。。。
反正還是沒說清楚,對了,記得我們高中畫圓的除了圓規和一個計量三角形角度的半圓直尺了嗎,我要說的角度就是那個。。。太坑爹了!
好像最右邊是0度,垂直是90度,水平是180度,既然如此,我們再來看看

復制代碼
代碼如下:

正時針逆時針
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 400, 300); //填充畫布結束

context.beginPath();
context.arc(80, 80, 50, 0, 180 * Math.PI / 180, true);
context.closePath();
context.fillStyle = 'gray';
context.fill();

context.beginPath();
context.arc(180, 180, 50, 0, 180 * Math.PI / 180, false);
context.closePath();
context.fillStyle = 'gray';
context.fill();


}
</script>
</head>
<body>
<canvas id="canvas" width="400" height="300">
</canvas>

<button onclick="draw();">
繪制圓</button>
<input type="color" />
</body>
</html>

我們發現正時針與逆時針還是有所不同的,

 context.arc(180, 180, 50, 90 * Math.PI / 180, 290 * Math.PI / 180, true);

原諒我這里居然思考了半個小時,我甚至搜索了高中的資料。。。。

于是我好像明白了點什么。。。。。。

moveTo與lineTo

現上實驗結果:

復制代碼
代碼如下:

兩次moveto
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充畫布結束

context.beginPath();
context.fillStyle = 'gray';
context.strokeStyle = 'black';

context.moveTo(10, 10);
context.lineTo(150, 150);

context.moveTo(10, 10);
context.lineTo(10, 150);

context.closePath();
context.fill();
context.stroke();

}
</script>
</head>
<body>
<canvas id="canvas" width="300" height="200">
</canvas>

<button onclick="draw();">
繪制</button>
<input type="color" />
</body>
</html>


復制代碼
代碼如下:

一次moveto
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充畫布結束

context.beginPath();
context.fillStyle = 'gray';
context.strokeStyle = 'black';

context.moveTo(10, 10);
context.lineTo(150, 150);

// context.moveTo(10, 10);
context.lineTo(10, 150);

context.closePath();
context.fill();
context.stroke();

}
</script>
</head>
<body>
<canvas id="canvas" width="300" height="200">
</canvas>

<button onclick="draw();">
繪制</button>
<input type="color" />
</body>
</html>


復制代碼
代碼如下:

三次moveto
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
function draw() {
//獲取canvas對象
var canvas = document.getElementById('canvas');
if (canvas == null) {
return false;
}
var context = canvas.getContext('2d');
context.fillStyle = '#99d9ea';
context.fillRect(0, 0, 300, 200); //填充畫布結束

context.beginPath();
context.fillStyle = 'gray';
context.strokeStyle = 'black';

context.moveTo(10, 10);
context.lineTo(150, 150);

context.moveTo(10, 10);
context.lineTo(10, 150);

context.moveTo(10, 150);
context.lineTo(150, 150);

context.closePath();
context.fill();
context.stroke();

}
</script>
</head>
<body>
<canvas id="canvas" width="300" height="200">
</canvas>

<button onclick="draw();">
繪制</button>
<input type="color" />
</body>
</html>

以上代碼幾乎一樣,但是他產生的結果卻不同:

我認為,使用moveto后相當于新開一起點,之前的一筆勾銷,若是只使用lineto的話,他會將幾個點連成線,若是可以組成圖形便會擁有中間色彩

標簽:平涼 平頂山 黃石 公主嶺 南平 山南 黃石 陜西

巨人網絡通訊聲明:本文標題《HTML5 繪制圖像(上)之:關于canvas元素引領下一代web頁面的問題》,本文關鍵詞  HTML5,繪制,圖像,上,之,關于,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML5 繪制圖像(上)之:關于canvas元素引領下一代web頁面的問題》相關的同類信息!
  • 本頁收集關于HTML5 繪制圖像(上)之:關于canvas元素引領下一代web頁面的問題的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产91在线|亚洲| 亚洲欧洲精品一区二区精品久久久| 中文字幕一区二区三区在线不卡| 欧美精品99久久久**| 懂色av一区二区三区免费观看| 亚洲va欧美va人人爽午夜| 中文在线一区二区| 久久精品欧美一区二区三区麻豆| 9191久久久久久久久久久| 91小视频在线| 91在线精品一区二区| 成人黄色软件下载| 丁香一区二区三区| 国产一区欧美二区| 麻豆精品蜜桃视频网站| 日韩精品一级中文字幕精品视频免费观看 | 精品福利av导航| 欧美精品三级日韩久久| 欧美三区在线观看| 欧美亚洲国产bt| 欧美午夜精品理论片a级按摩| 日本电影亚洲天堂一区| 91亚洲国产成人精品一区二区三 | 成人天堂资源www在线| 国产乱码精品一区二区三区忘忧草| 日韩激情视频网站| 麻豆成人综合网| 国模冰冰炮一区二区| 国产福利一区二区三区| 成人激情综合网站| 日本高清免费不卡视频| 欧美人伦禁忌dvd放荡欲情| 91精品国产入口| 日韩美女主播在线视频一区二区三区| 欧美一区二区三区白人| 精品国产百合女同互慰| 国产日韩精品一区二区三区| 国产精品久久影院| 亚洲欧美影音先锋| 亚洲一区二区三区在线播放| 天堂va蜜桃一区二区三区 | 亚洲女爱视频在线| 亚洲高清一区二区三区| 免费成人在线观看视频| 国产成人亚洲精品狼色在线 | 欧美一个色资源| 久久久久97国产精华液好用吗| 国产精品久久久久久一区二区三区| ...av二区三区久久精品| 午夜欧美2019年伦理| 国模无码大尺度一区二区三区| 成人av网在线| 欧美大肚乱孕交hd孕妇| 综合激情网...| 久久国产精品第一页| 91丨九色丨蝌蚪富婆spa| 亚洲品质自拍视频网站| 青青草97国产精品免费观看无弹窗版| 国产成人在线视频免费播放| 色老头久久综合| 国产午夜精品久久久久久久| 亚洲午夜电影在线| 成人一区二区三区中文字幕| 欧美一区二区三区爱爱| 亚洲欧美日韩一区二区| 精品一区二区三区久久久| 色激情天天射综合网| 久久免费电影网| 日本在线不卡视频一二三区| 99久久精品免费看国产免费软件| 日韩欧美资源站| 亚洲国产精品久久人人爱| 丁香天五香天堂综合| 日韩欧美不卡一区| 亚洲第一精品在线| 色噜噜狠狠成人网p站| 国产精品人人做人人爽人人添| 日韩精彩视频在线观看| 欧美午夜电影在线播放| 国产精品福利av| 国产成人免费网站| 欧美精品一区二区三区久久久| 丝袜亚洲另类欧美| 欧美性生交片4| 一二三四区精品视频| 波多野结衣一区二区三区| 欧美精品一区二区三区高清aⅴ | 亚洲成人免费电影| 一本大道综合伊人精品热热 | 制服丝袜国产精品| 亚洲不卡av一区二区三区| 日本韩国精品一区二区在线观看| 日韩一区有码在线| av一二三不卡影片| 一区在线观看免费| 成人av影院在线| 中文字幕一区二区三区在线观看| 成人动漫av在线| 亚洲欧美日韩系列| 欧美日韩一区二区三区视频| 一区二区三区免费看视频| 91网站最新网址| 亚洲与欧洲av电影| 欧美日韩国产高清一区二区三区| 亚洲一区二区三区在线播放| 欧美影院一区二区三区| 91亚洲永久精品| 亚洲三级久久久| 在线观看欧美日本| 午夜久久久久久| 精品国内二区三区| 国产成人h网站| 亚洲男人的天堂在线aⅴ视频| 日本电影欧美片| 日本aⅴ精品一区二区三区| 欧美大胆人体bbbb| 国产成人精品三级| 亚洲三级视频在线观看| 欧美三级乱人伦电影| 麻豆传媒一区二区三区| 国产精品情趣视频| 欧美日韩在线免费视频| 久久99久久精品欧美| 亚洲同性同志一二三专区| 欧洲人成人精品| 奇米精品一区二区三区四区| 久久久精品2019中文字幕之3| www.激情成人| 天天影视色香欲综合网老头| 久久久天堂av| 欧美亚洲动漫精品| 国产成人亚洲综合色影视| 亚洲午夜久久久久| 国产午夜精品理论片a级大结局 | 亚洲另类色综合网站| 制服丝袜亚洲色图| 91视视频在线观看入口直接观看www | 国产黑丝在线一区二区三区| 亚洲激情图片一区| 欧美精品一区二区三区蜜臀| 色香蕉久久蜜桃| 国产揄拍国内精品对白| 国产精品盗摄一区二区三区| 777a∨成人精品桃花网| av网站一区二区三区| 免费在线观看一区二区三区| 成人免费小视频| 日韩写真欧美这视频| a亚洲天堂av| 国产在线麻豆精品观看| 亚洲成人自拍一区| 国产不卡在线视频| 亚洲高清免费观看高清完整版在线观看 | 久久久久久久久久看片| 欧美日韩亚洲国产综合| 成人性生交大片免费看中文网站| 男人操女人的视频在线观看欧美| 一区二区三区在线免费播放 | 一区二区欧美在线观看| 久久久久久久久伊人| 日韩一级在线观看| 欧美麻豆精品久久久久久| 色综合天天综合狠狠| 成人毛片在线观看| 国产乱码精品一区二区三区忘忧草 | 日韩精品亚洲一区二区三区免费| 亚洲精品中文在线影院| 中文字幕一区二| 国产精品色婷婷| 日本一区二区三区高清不卡| 精品乱人伦小说| 日韩色在线观看| 日韩欧美国产综合一区| 欧美军同video69gay| 欧美日韩你懂得| 欧美群妇大交群中文字幕| 色欧美乱欧美15图片| 丰满亚洲少妇av| 99久久精品免费精品国产| 99久久精品免费观看| 99久久99精品久久久久久| 99re这里只有精品首页| 99久久精品久久久久久清纯| 91麻豆自制传媒国产之光| 色综合网色综合| 色综合久久天天综合网| 91丝袜美女网| 欧美亚洲一区三区| 欧美精品乱人伦久久久久久| 91精品一区二区三区久久久久久| 欧美精品 日韩| 91精品中文字幕一区二区三区| 日韩免费观看高清完整版| 久久精品日产第一区二区三区高清版| 亚洲国产高清在线观看视频| 最新日韩av在线| 日韩黄色免费电影| 国产精品69久久久久水密桃| 91小宝寻花一区二区三区| 欧美乱熟臀69xxxxxx|