亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

HTML5 繪制圖像(上)之-關于canvas元素引領下一代w

2020-03-24 19:15:11
字體:
來源:轉載
供稿:網友
初識canvas元素HTML5新增了一個元素canvas,用于繪圖使用,其實它的表現和div比較接近(其實他應該屬于inline-block),而提供了許多接口,從而輕易的繪制矩形框、園三角形等PS:關于HTML5新增元素經過最近兩天的學習,和以前對HTML5的認知,我認為HTML5其實還是HTML4,兩者之間沒多大的區別,無非是增加了點新東西。
我認為HTML5為我們帶來的真正意義是:我們可以用javascript做更多的事情了;我們可以用javascript實現更好的產品了。比如HTML5就解決了我們頭疼的跨域問題、實時通信API、與現在的canvas之所以HTML5叫HTML5,我認為他是劃時代的,比如他讓我們用網頁開發游戲變成可能;比如他讓html' target='_blank'>電腦桌面只剩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"
/canvas


button
繪制矩形 /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 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
繪制圓 /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
繪制圓 /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
繪制 /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
繪制 /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
繪制 /button
input type="color" /
/body
/html

以上代碼幾乎一樣,但是他產生的結果卻不同:
我認為,使用moveto后相當于新開一起點,之前的一筆勾銷,若是只使用lineto的話,他會將幾個點連成線,若是可以組成圖形便會擁有中間色彩html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美高清视频| 欧美日本黄视频| 亚洲免费伊人电影在线观看av| 国产亚洲精品一区二555| 日韩中文第一页| 亚洲国产成人精品女人久久久| 欧美一级免费视频| 亚洲性线免费观看视频成熟| 色噜噜国产精品视频一区二区| 国产精品美女主播在线观看纯欲| 成人黄色av网| 日韩一级黄色av| 国产精品视频不卡| 亚洲成人激情在线观看| 亚洲国产私拍精品国模在线观看| 亚洲a成v人在线观看| 欧美在线激情网| 亚洲最大福利视频| 亚洲美女福利视频网站| 最新国产成人av网站网址麻豆| 日韩欧美国产黄色| 精品久久国产精品| 亚洲欧洲高清在线| 亚洲欧美日韩一区二区三区在线| 国外色69视频在线观看| 欧美成人在线免费| 91av在线看| 91系列在线播放| 久久精品国产欧美亚洲人人爽| 国产日韩欧美夫妻视频在线观看| 国产女人精品视频| 欧美性受xxxx黑人猛交| 亚洲色图15p| 在线亚洲午夜片av大片| 久久久久久午夜| 欧美老女人在线视频| 国产免费一区二区三区在线能观看| 日本三级韩国三级久久| 亚洲激情视频网| 国产精品色午夜在线观看| 青青久久av北条麻妃海外网| 最近的2019中文字幕免费一页| 日韩中文在线观看| 日韩黄在线观看| 日韩在线观看免费| 亚洲精品电影久久久| 黄色精品在线看| 欧美午夜片欧美片在线观看| 亚洲第一精品自拍| 色www亚洲国产张柏芝| 欧美亚洲日本网站| 欧美成人精品激情在线观看| 国精产品一区一区三区有限在线| 国产成人亚洲综合91精品| 亚洲成人网久久久| 91av在线看| 日本精品一区二区三区在线播放视频| 岛国视频午夜一区免费在线观看| 国产精品香蕉在线观看| 国产精品黄视频| 美女视频黄免费的亚洲男人天堂| 国精产品一区一区三区有限在线| 亚洲日本aⅴ片在线观看香蕉| 深夜福利日韩在线看| 国产99久久精品一区二区 夜夜躁日日躁| 久久久成人av| 97免费中文视频在线观看| 91禁国产网站| 欧美特黄级在线| 国产成人亚洲综合青青| 最新国产成人av网站网址麻豆| 国产日韩换脸av一区在线观看| 啪一啪鲁一鲁2019在线视频| 最近中文字幕日韩精品| 久久999免费视频| 欧美久久精品一级黑人c片| 久久影院免费观看| 国产成人激情视频| 91免费的视频在线播放| 亚洲老板91色精品久久| 国产精品精品一区二区三区午夜版| 中文字幕在线视频日韩| 成人免费观看网址| 日韩视频免费大全中文字幕| 成人在线视频福利| 国产福利视频一区二区| 热久久99这里有精品| 久久精品91久久久久久再现| 性色av一区二区三区免费| 久久久噜噜噜久久中文字免| 国产精品主播视频| 亚洲成人久久久久| 2021国产精品视频| 日韩的一区二区| 国产激情久久久久| 懂色aⅴ精品一区二区三区蜜月| 国产精品人成电影在线观看| 亚洲精品v欧美精品v日韩精品| 日韩成人xxxx| 国产精品夜色7777狼人| 久久久女人电视剧免费播放下载| 日本精品视频在线观看| 国产视频久久久久| 亚洲男人天天操| 欧亚精品中文字幕| 日韩成人中文字幕在线观看| 国产日韩欧美91| 精品久久久久久久久国产字幕| 中文字幕综合一区| 亚洲欧洲视频在线| 亚洲精品99999| 亚洲精品色婷婷福利天堂| 欧美性生交xxxxxdddd| 91tv亚洲精品香蕉国产一区7ujn| 日韩精品福利网站| 亚洲欧美成人一区二区在线电影| yw.139尤物在线精品视频| 黑人与娇小精品av专区| 日韩中文字幕在线播放| 欧洲美女免费图片一区| 57pao成人国产永久免费| 欧美极品在线播放| 中文精品99久久国产香蕉| 欧美综合国产精品久久丁香| 亚洲 日韩 国产第一| 亚洲图片欧洲图片av| 亚洲精品乱码久久久久久金桔影视| 国产丝袜精品第一页| 97超级碰碰人国产在线观看| 国产精品免费电影| 午夜精品久久久久久99热软件| 亚洲精品免费av| 成人xvideos免费视频| 色与欲影视天天看综合网| 国产精品444| 欧美日韩亚洲国产一区| 国产99久久精品一区二区 夜夜躁日日躁| 精品久久中文字幕久久av| 欧美成人性生活| 国产精品永久免费视频| 91深夜福利视频| 欧美日韩在线免费| 欧美性jizz18性欧美| 国产97在线播放| 亚洲精品欧美一区二区三区| 欧美国产欧美亚洲国产日韩mv天天看完整| 日本老师69xxx| 91在线视频一区| 92看片淫黄大片看国产片| 97在线视频一区| 日韩精品在线第一页| 亚洲精品综合久久中文字幕| 久久久久久久香蕉网| 日韩欧美一区二区三区久久| 欧美日本高清视频| 精品国产福利在线| 亚洲欧洲日产国产网站| 欧美性猛xxx| 亚洲第一男人天堂| 在线播放精品一区二区三区| 亚洲影院在线看| 中文字幕综合在线| 欧美激情网站在线观看| 国产精品视频地址|