canvas-線的樣式

線的樣式在canvas中分為輪廓顏色、以及線型的樣式

一困介、輪廓顏色

strokeStyle = color; // 設(shè)置描邊輪廓的顏色

二顶滩、線型樣式

1敛滋、線的寬度

lineWidth = number;

2、線帽的樣式

ctx.lineCap = 'butt'; // 默認(rèn) 正常
屬性值:
round: 多出半圓
square: 多出方形

ctx.lineWidth = 20;
ctx.strokeStyle = 'red';
// 線帽: 線的兩端的樣式
// butt
ctx.beginPath();
ctx.lineCap = 'butt'; // 默認(rèn)
ctx.moveTo(50, 100);
ctx.lineTo(50, 400);
ctx.stroke();

// round:會(huì)多出半圓
ctx.beginPath();
ctx.lineCap = 'round'; 
ctx.moveTo(150, 100);
ctx.lineTo(150, 400);
ctx.stroke();

// square: 會(huì)多出方形
ctx.beginPath();
ctx.lineCap = 'square'; 
ctx.moveTo(250, 100);
ctx.lineTo(250, 400);
ctx.stroke();


// 黃色的線
ctx.lineWidth = 2;
ctx.strokeStyle = 'yellow';
ctx.beginPath();

ctx.moveTo(0, 100);
ctx.lineTo(400, 100);

ctx.moveTo(0, 400);
ctx.lineTo(400, 400);
ctx.stroke();

線帽效果圖:


image.png

利用多出一點(diǎn)點(diǎn)的特性我們可以看看在閉合路徑時(shí)可以做點(diǎn)什么

栗子: 來(lái)個(gè)箭頭

// 箭頭

ctx.beginPath();
ctx.lineWidth = 6;
ctx.strokeStyle = 'blue';
線帽使用的是***
ctx.lineCap = 'square'; 
// 起始點(diǎn)
ctx.moveTo(100, 200);

ctx.lineTo(250, 200);
ctx.lineTo(250, 150);

// 角>
ctx.lineTo(350, 250);

ctx.lineTo(250, 350);
ctx.lineTo(250, 300);

// 結(jié)束點(diǎn)
ctx.lineTo(100, 300);

ctx.stroke();

當(dāng)前效果:


image.png

問(wèn)題來(lái)了: 箭頭為什么沒(méi)有閉合路徑替废,如何閉合路徑

// 第一種 添加最后一個(gè)結(jié)束點(diǎn)
ctx.lineTo(100, 200);
ctx.stroke();

// 第二種  閉合路徑
ctx.closePath();
ctx.stroke();

此時(shí)我們使用的線帽為square:以上兩種方法箍铭,閉合路徑后完美連接在一起


image.png

如果是默認(rèn)線帽butt呢?
1、在使用closePath()方式閉合是完美連接在一起的(我就不貼圖了)
2椎镣、使用lineTo()诈火,出現(xiàn)了問(wèn)題:缺了一小塊

image.png

看過(guò)效果之后,不想自己驗(yàn)證一下嗎状答?

三冷守、線的交點(diǎn)

ctx.lineJoin = 'miter '; // 默認(rèn) 尖角
設(shè)置內(nèi)角與外角距離
ctx.miterLimit = 10; 默認(rèn)值(
當(dāng)使用miter作為線條的連接時(shí),所產(chǎn)生的內(nèi)角與外角最大的默認(rèn)值惊科,一旦超過(guò)默認(rèn)值拍摇,就會(huì)變成bevel
圖片來(lái)源于: 菜鳥(niǎo)教程

內(nèi)角與外角的距離

內(nèi)角與外角距離超過(guò)默認(rèn)值,變成bevel

image.png

ctx.lineJoin = 'bevel'; // 斜接

image.png

ctx.lineJoin = 'round'; // 圓角

image.png

canvas-簡(jiǎn)版畫(huà)板

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末馆截,一起剝皮案震驚了整個(gè)濱河市授翻,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌孙咪,老刑警劉巖堪唐,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異翎蹈,居然都是意外死亡淮菠,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)荤堪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)合陵,“玉大人枢赔,你說(shuō)我怎么就攤上這事∮抵” “怎么了踏拜?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)低剔。 經(jīng)常有香客問(wèn)我速梗,道長(zhǎng),這世上最難降的妖魔是什么襟齿? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任姻锁,我火速辦了婚禮,結(jié)果婚禮上猜欺,老公的妹妹穿的比我還像新娘位隶。我一直安慰自己,他們只是感情好开皿,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布涧黄。 她就那樣靜靜地躺著,像睡著了一般赋荆。 火紅的嫁衣襯著肌膚如雪弓熏。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,457評(píng)論 1 311
  • 那天糠睡,我揣著相機(jī)與錄音挽鞠,去河邊找鬼。 笑死狈孔,一個(gè)胖子當(dāng)著我的面吹牛信认,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播均抽,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼嫁赏,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了油挥?” 一聲冷哼從身側(cè)響起潦蝇,我...
    開(kāi)封第一講書(shū)人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎深寥,沒(méi)想到半個(gè)月后攘乒,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡惋鹅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年则酝,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片闰集。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡沽讹,死狀恐怖般卑,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情爽雄,我是刑警寧澤蝠检,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站挚瘟,受9級(jí)特大地震影響叹谁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜刽沾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望排拷。 院中可真熱鬧侧漓,春花似錦、人聲如沸监氢。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)浪腐。三九已至纵揍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間议街,已是汗流浹背泽谨。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留特漩,地道東北人吧雹。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像涂身,于是被迫代替她去往敵國(guó)和親雄卷。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容

  • 使用樣式和顏色 色彩 colors 如果想要給圖形上色蛤售,有兩個(gè)重要的屬性可以做到:fillStyle 和 stro...
    閑不住的李先森閱讀 1,565評(píng)論 0 0
  • 啥是canvas悴能? HTML5 標(biāo)簽用于繪制圖像(通過(guò)腳本揣钦,通常是 JavaScript)。不過(guò)漠酿, 元素本身...
    kiaizi閱讀 774評(píng)論 0 4
  • 一拂盯、canvas簡(jiǎn)介 1.1 什么是canvas?(了解) 是HTML5提供的一種新標(biāo)簽 Canvas是一個(gè)矩形區(qū)...
    J_L_L閱讀 1,520評(píng)論 0 4
  • 線條樣式 繪制直線记靡,第五章知識(shí)簡(jiǎn)單回顧 lineWidth 設(shè)置或返回當(dāng)前的線條寬度谈竿,單位為像素 lineCap ...
    Zd_silent閱讀 478評(píng)論 0 0