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

主頁 > 知識庫 > canvas學習總結三之繪制路徑-線段

canvas學習總結三之繪制路徑-線段

熱門標簽:高德地圖標注商戶怎么標 ok電銷機器人 如何查看地圖標注 欣鼎電銷機器人 效果 黃石ai電銷機器人呼叫中心 地圖標注軟件打印出來 惡搞電話機器人 電話機器人技術 智能電銷機器人被禁用了么

Canvas繪圖環境中有些屬于立即繪制圖形方法,有些繪圖方法是基于路徑的。

立即繪制圖形方法僅有兩個strokeRect(),fillRect(),雖然strokezText(),fillText()方法也是立即繪制的,但是文本不算是圖形。

基于路徑的繪制系統 

大多數繪制系統,如:SVG(Scalable Verctor Graphics, 可縮放的矢量圖形),Adobe Illustrator等,都是基于路徑的,

使用這些繪制系統時,你需要先定義一個路徑,然后再對其進行描邊或填充,也可以描邊加填充這樣圖形才能顯示出來。

Canvas中的三種繪制方式:

繪制一條線段

Canvas繪圖環境中,線段也是基于路徑繪制的,稱為線性路徑,創建線性路徑的方法:moveTO()與lineTo(),在創建路徑之后調用stroke()方法,才能在Canvas中畫出線段出來。

這就是前面我們所說的基于路徑的繪制方法,必須對其進行描邊或者填充;

通常兩點連一線因此繪制線段非常簡單,通過moveTO()指定線的起點,通過lineTo()移動到另一個點。

function drawLine(){
    cxt.moveTo(50, 50);
    cxt.lineTo(100, 100);
}

然而這樣我們在畫布中是看不見線段的,前面我們說到基于路徑的繪制方法,必須要描邊或者填充。所以要想看到結果,我們必須還要使用stroke()方法。

因此我們把方法修改成下面這樣就會繪制出一條線段

function drawLine(){
    cxt.moveTo(50, 50);
    cxt.lineTo(200, 200);
    cxt.stroke();
}

我們只使用lineTo()也是能在畫布中繪制出線段的,我們把上面的代碼改成如下面所示,效果也是一樣的

function drawLine(){
    cxt.lineTo(50, 50);
    cxt.lineTo(200, 200);
    cxt.stroke();
}

總結下moveTo()與lineTo()的用法

  • moveTo(x,y): 將筆觸移動到指定的坐標x以及y上,向當前路徑中增加一條子路徑,該方法不會清除當前路徑中的任何子路徑。
  • lineTo(x,y): 繪制一條從當前位置到指定x以及y位置的直線,如果當前路徑中沒有子路徑,那么這個方法的行為與moveTo()一樣。如果當前路徑中存在子路徑,此方法會將你所指定的這個點加入子路徑中。

改變線段的樣式

改變線段的寬度

function= 14;
    cxt.lineTo(50, 50);
    cxt.lineTo(200, 200);
    cxt.stroke();
}

改變線段的顏色

function drawLine(){
    cxt.lineWidth = 14;
    cxt.strokeStyle = 'green';
    cxt.lineTo(50, 50);
    cxt.lineTo(200, 200);
    cxt.stroke();
}

 

我們還可以利用CanvasGradient對象或者CanvasPattern對象給線段添加漸變色或圖案

function drawLine(){
    cxt.lineWidth = 14;
    var gradient = cxt.createLinearGradient(0, 0, canvas.width/2, canvas.height/2);
    gradient.addColorStop(0, 'blue');
    gradient.addColorStop(0.5, 'purple');
    gradient.addColorStop(1, 'yellow');
    cxt.strokeStyle = gradient;
    cxt.lineTo(50, 50);
    cxt.lineTo(200, 200);
    cxt.stroke();
}

 beginPath()與closePath()

從上面canvas中的三種繪制方式中我們可以看出,第二行的弧形路徑是開放路徑,最后一行的弧形是封閉路徑。那么封閉的路徑是怎么實現的呢?

下面我們來看看canvas中路徑繪制中兩個比較重要的方法

  • beginPath(): 清除當前所有子路徑,以此來重置當前路徑,重新規劃一條路徑。
  • closePath(): 用于封閉某段開放路徑。不是必需的,如果圖形是已經閉合了的,即當前點為開始點,該函數什么也不做。

先繪制出一條折線

function drawLine(){
    cxt.strokeStyle = 'green';
    cxt.lineWidth = 2;
    cxt.moveTo(50, 50);
    cxt.lineTo(50, 150);
    cxt.lineTo(150, 150);
    cxt.stroke();
}

修改上面例子中的代碼在代碼中添加beginPath()與closePath()方法

function drawLine(){
    //描邊三角形
    cxt.strokeStyle = 'green';
    cxt.lineWidth = 2;
    cxt.beginPath();
    cxt.moveTo(50, 50);
    cxt.lineTo(50, 150);
    cxt.stroke();
    cxt.beginPath();
    cxt.lineTo(150, 150);
    cxt.lineTo(150, 250);
    cxt.stroke();
  cxt.closePath();
}

可以看出我們在畫布中繪制了兩條路徑

注意:調用beginPath()之后,或者canvas剛建的時候,第一條路徑構造命令通常被視為是moveTo()。所以我們在繪制圖形的時候一定要先使用beginPath()。

我們繼續修改我們的代碼

function drawLine(){
    //描邊三角形
    cxt.strokeStyle = 'green';
    cxt.lineWidth = 2;
    cxt.beginPath();
    cxt.moveTo(50, 50);
    cxt.lineTo(50, 150);
    cxt.lineTo(150, 150);
    cxt.closePath();
    cxt.stroke();
    //折線
    cxt.translate(150, 0);
    cxt.strokeStyle = 'red';
    cxt.lineWidth = 2;
    cxt.beginPath();
    cxt.moveTo(50, 50);
    cxt.lineTo(50, 150);
    cxt.lineTo(150, 150);
    cxt.stroke();
    cxt.closePath();
    //綠色填充三角形
    cxt.translate(150, 0);
    cxt.fillStyle = 'green';
    cxt.lineWidth = 2;
    cxt.beginPath();
    cxt.moveTo(50, 50);
    cxt.lineTo(50, 150);
    cxt.lineTo(150, 150);
    cxt.fill();
    cxt.closePath();
    //紅色填充三角形
    cxt.translate(150, 0);
    cxt.fillStyle = 'red';
    cxt.lineWidth = 2;
    cxt.beginPath();
    cxt.moveTo(50, 50);
    cxt.lineTo(50, 150);
    cxt.lineTo(150, 150);
    cxt.closePath();
    cxt.fill();
}

從上面的例子我們可以看出closePath()的位置不同,也會影響我們的圖形

注意:當你調用fill()函數時,所有沒有閉合的形狀都會自動閉合,所以此時closePath()函數不是必須的。

但是調用stroke():如果你在stroke()方法之前只用closePath()會形成閉合路徑,如果在stroke()方法之后調用closePath()方法,此時圖形已經繪制完成,當前的繪制路徑已經關閉,所以closePath()方法不起作用。

線段與像素邊界

先來看一個例子

function drawLine(){
    //描邊三角形
    cxt.lineWidth = 1;
    cxt.beginPath();
    cxt.moveTo(50, 50);
    cxt.lineTo(450, 50);
    cxt.stroke();
    cxt.beginPath();
    cxt.moveTo(50.5, 150.5);
    cxt.lineTo(450.5, 150.5);
    cxt.stroke();
}

從圖中我們可以看出,我們將兩條線段的lineWidth都是設置為1像素,但是上面的線段畫出的卻是兩像素。 

如果你在某2個像素的邊界處繪制一條1像素寬的線段,那么該線段實際會占據2個像素的寬度;

因為當你在像素邊界處繪制一條1像素寬度的垂直線段時,canvas的繪圖環境對象會試著將半個像素畫在邊界中線的右邊,將另外半個像素畫在邊界中線的左邊。

然而,在一個整像素的范圍內繪制半個像素寬的線段是不可能的,所以在左右兩個方向上的半個像素都被擴展為1個像素。

另外一方面,繪制在兩個像素之間,這樣的話,中線左右兩端的那半個像素就不會延伸,它們結合起來恰好占據1個像素的寬度。所以說,如果要繪制一條真正1像素寬度的線段,你必須將該線段繪制在某兩個像素之間

網格的繪制

既然我們已經明白了如何繪制真正的1像素的線段,那我們就開始繪制網格

function drawLine(stepx, stepy){
    cxt.lineWidth = 0.5;
    cxt.strokeStyle = 'green';
    //繪制豎線
    for(var i= stepx + 0.5; i< cxt.canvas.width; i+= stepx){
        cxt.beginPath();
        cxt.moveTo(i, 0);
        cxt.lineTo(i, cxt.canvas.height);
        cxt.stroke();
    }
    //繪制橫線
    for(var i= stepy + 0.5; i< cxt.canvas.height; i+= stepy){
        cxt.beginPath();
        cxt.moveTo(0, i);
        cxt.lineTo(cxt.canvas.width, i);
        cxt.stroke();
    }
}
drawLine(10, 10);

上面例子中我們將線段繪制在兩個像素之間的像素上,而且繪制出來的線段僅有0.5像素寬,

雖說canvas規范沒有明文規定,不過所有瀏覽器的Canvas實現都使用了“抗鋸齒”技術,以便創建出“亞像素”線段的繪制效果來

總結

本節內容主要講解canvas中路徑中線性路徑的繪制方法,主要是利用 moveTo()定義起點,lineTo()定義終點,stroke()描繪當前路徑。這三個方法繪制線段

canvas中繪制路徑有兩個重要的方法,beginPath()與closePath()。繪制圖形之前先調用beginPath()是繪制多個圖形必要的步驟。

closePath()在使用fill()時是可以省略的,而且還要注意closePath()方法的調用位置。

繪制線段時我們可以使用 lineWidth改變線段的寬度,strokeStyle改變線段的顏色。

弄清楚線段的像素邊界,這樣我們才能繪制出真正的1像素線寬的線段。

對canvas繪制圖形感興趣的同學,請持續關注后續更新,如有不對的地方也請指出并多多交流。

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

標簽:盤錦 阿壩 萍鄉 金昌 中山 赤峰 聊城 綏化

巨人網絡通訊聲明:本文標題《canvas學習總結三之繪制路徑-線段》,本文關鍵詞  canvas,學習,總結,三之,繪制,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas學習總結三之繪制路徑-線段》相關的同類信息!
  • 本頁收集關于canvas學習總結三之繪制路徑-線段的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产网红主播福利一区二区| 国产视频一区在线播放| 国产精品伦理一区二区| 成人aa视频在线观看| 亚洲视频香蕉人妖| 欧美日韩三级在线| 国模大尺度一区二区三区| 国产精品视频第一区| 在线精品视频小说1| 日本va欧美va瓶| 国产清纯美女被跳蛋高潮一区二区久久w| 成人精品免费网站| 亚洲国产精品精华液网站| 欧美一级片在线看| 波多野结衣在线aⅴ中文字幕不卡| 亚洲欧美日韩国产另类专区| 日韩一区和二区| 成人高清免费在线播放| 视频一区二区三区在线| 国产精品天干天干在观线| 精品视频1区2区| 成人app软件下载大全免费| 日韩高清一区二区| 中文字幕五月欧美| 欧美不卡在线视频| 一本久久a久久免费精品不卡| 久久9热精品视频| 亚洲成人av福利| 久久精品欧美日韩精品| 欧美午夜精品一区| 成人午夜伦理影院| 美女被吸乳得到大胸91| 亚洲精品成a人| 自拍偷拍欧美精品| 久久久久久久久97黄色工厂| 91精品在线免费观看| 色偷偷久久一区二区三区| 国产成人午夜精品影院观看视频 | 夜夜精品视频一区二区| 欧美大胆一级视频| 欧美精品一二三四| 欧美综合在线视频| 色综合天天综合| 成人免费视频视频| 国产麻豆成人传媒免费观看| 午夜精品福利视频网站| 亚洲综合精品自拍| 亚洲精品日日夜夜| 亚洲欧美视频在线观看视频| 国产精品卡一卡二| 国产精品网站在线观看| 国产欧美一二三区| 国产午夜精品理论片a级大结局| 欧美成人a在线| 精品欧美一区二区在线观看| 日韩精品最新网址| 欧美一区二区精品久久911| 欧美日韩欧美一区二区| 欧美性猛交xxxxxxxx| 欧美午夜一区二区三区免费大片| 色噜噜狠狠成人中文综合| 色悠悠久久综合| 色婷婷av一区二区三区软件| 91视频xxxx| 色老汉一区二区三区| 欧日韩精品视频| 欧美性做爰猛烈叫床潮| 欧美精选午夜久久久乱码6080| 欧美日韩一本到| 欧美一区二区三级| 精品剧情在线观看| 久久精品视频一区二区三区| 久久精品人人做| 中文字幕制服丝袜成人av | 9191成人精品久久| 波多野洁衣一区| 久久久久久久av麻豆果冻| 色综合网色综合| 国产电影一区在线| 精品无码三级在线观看视频| 五月激情六月综合| 一区二区三区四区中文字幕| 国产日韩欧美高清在线| 欧美videos大乳护士334| 欧美精品丝袜中出| 欧美性猛交xxxxxx富婆| 色呦呦日韩精品| 色天使色偷偷av一区二区| 精品视频在线看| 精品国产乱子伦一区| 国产精品天美传媒| 依依成人综合视频| 日本不卡一二三区黄网| 国产盗摄一区二区| 色屁屁一区二区| 日韩免费性生活视频播放| 亚洲国产精品成人综合色在线婷婷| 国产精品国产三级国产aⅴ入口 | 欧美日韩二区三区| 欧美日韩一区二区三区四区五区| 欧美日韩中文精品| 精品成人私密视频| 中文字幕日韩一区二区| 五月综合激情日本mⅴ| 国产精品一区在线观看你懂的| 99久久婷婷国产| 欧美日韩高清在线播放| 久久综合九色综合97婷婷女人| 中文字幕一区二区在线播放| 亚洲国产成人tv| 国产高清视频一区| 欧美日韩视频在线一区二区| 久久亚洲欧美国产精品乐播| 一区二区三区日韩精品视频| 精品伊人久久久久7777人| 99国产精品久久久久久久久久久| 欧美高清你懂得| 亚洲欧洲三级电影| 美女mm1313爽爽久久久蜜臀| 欧美丰满高潮xxxx喷水动漫| 奇米影视7777精品一区二区| www.亚洲人| 精品久久人人做人人爰| 亚洲精品中文字幕乱码三区| 美国毛片一区二区| 99视频精品在线| 精品国产91亚洲一区二区三区婷婷| 国产精品免费视频网站| 蜜臀av性久久久久蜜臀av麻豆| 成人免费va视频| 日韩一区二区免费电影| 亚洲日本在线视频观看| 精品一区二区免费视频| 精品视频1区2区| 亚洲视频一区二区在线| 国产成人在线观看| 欧美一区二区三区视频| 亚洲综合免费观看高清在线观看| 懂色av中文字幕一区二区三区| 欧美xxxx在线观看| 偷拍亚洲欧洲综合| 欧美亚州韩日在线看免费版国语版| 亚洲国产精品精华液2区45| 久久成人av少妇免费| 欧美精品久久久久久久久老牛影院| 亚洲欧美自拍偷拍色图| 成人网男人的天堂| 国产亚洲污的网站| 久久不见久久见免费视频7| 欧美日韩www| 亚洲小说春色综合另类电影| 91麻豆国产在线观看| 国产精品每日更新在线播放网址| 国内精品嫩模私拍在线| 日韩三级伦理片妻子的秘密按摩| 日韩和欧美一区二区| 欧美日韩电影一区| 午夜亚洲国产au精品一区二区| 91黄色免费看| 亚洲在线免费播放| 欧美性xxxxxx少妇| 亚洲二区视频在线| 欧美日韩大陆一区二区| 日韩成人免费电影| 日韩一区二区不卡| 久久99精品一区二区三区| 欧美日韩和欧美的一区二区| 欧美一级日韩不卡播放免费| 偷拍亚洲欧洲综合| 欧美精品久久99久久在免费线 | 日韩一区中文字幕| 91亚洲精品乱码久久久久久蜜桃| 国产精品伦一区| 99精品偷自拍| 一区二区三区精品视频| 在线区一区二视频| 亚洲一区二区三区视频在线 | 久久超碰97中文字幕| 日韩欧美国产一区二区在线播放| 久久精品国产精品亚洲精品| 精品国产乱码久久久久久免费| 国产一区二区三区香蕉| 国产精品午夜在线观看| 99re这里只有精品6| 一区二区三区在线看| 欧美色综合影院| 美日韩黄色大片| 国产日韩欧美电影| 色婷婷av一区二区三区之一色屋| 亚洲成人av福利| 精品国偷自产国产一区| 成人黄色av电影| 亚洲一区二区在线播放相泽| 在线成人小视频| 国产成a人无v码亚洲福利| 一区二区三区在线免费播放| 日韩午夜激情免费电影| 国产精品一区二区果冻传媒| 亚洲欧美日韩国产手机在线| 91精品国产综合久久国产大片|