亚洲国产精品人久久,亚洲va国产日韩欧美精品色婷婷,久久久久88色偷偷,免费人成黄页在线观看国际

17站長網

17站長網 首頁 編程教程 Html5教程 查看內容

HTML5 Canvas 繪制文本

html5 Canvas 可以使用各種字體,大小和顏色在html5畫布上繪制文本,文本的外觀由這些2D Context font屬性控制,要繪制文本,請使用fillText()或strokeText()功能。

在線示例

可以使用各種字體,大小和顏色在HTML5畫布上繪制文本。
文本的外觀由這些2D Context font屬性控制。此外,您需要根據要繪制填充文本還是描邊文本來設置fillStyle或strokeStyle2D Context屬性。
要繪制文本,請使用fillText()或strokeText()功能
這是一個簡單的代碼示例:

<canvas id="ex1" width="500" height="100" style="border: 1px solid #cccccc;">
    HTML5 Canvas not supported
</canvas>
<script>
   var canvas  = document.getElementById("ex1");
   var context = canvas.getContext("2d");
   context.font = "36px Verdana";
   context.fillStyle = "#000000";
   context.fillText("HTML5 Canvas Text", 50, 50);
 
   context.font        = "normal 36px Arial";
   context.strokeStyle = "#000000";
   context.strokeText("HTML5 Canvas Text", 90);
 </script>

這是在畫布上繪制時的結果:

HTML5 Canvas 繪制文本

字體和樣式

在HTML5畫布上繪制文本時,必須設置要使用的字體。這是通過設置2D上下文font屬性的值來完成的。此屬性是具有css兼容值的字符串,其格式為:

[font style][font weight][font size][font face]

例如

context.font = "normal normal 20px Verdana";

您可以為字體字符串的每個部分設置以下值:

font stylenormal
italic
oblique
inherit
font weightnormal
bold
bolder
lighter
auto
inherit
100
200
300
400
500
600
700
800
900
font size以像素為單位的大小,例如12px,20px等
font face字體,e.g. verdana, arial, serif, sans-serif, cursive, fantasy, monospace etc.

請注意,并非每個瀏覽器都支持所有值。在依賴它們之前,您將必須測試計劃使用的值。
這是另一個示例:

"italic bold 36px Arial"

繪圖文字

如前所述,在HTML5畫布上繪制文本時,您可以繪制填充文本或輪廓文本。您可以使用2D上下文函數fillText()和進行操作strokeText()。這些函數的定義如下:

fillText   (textString, x, y [,maxWidth]);
strokeText (textString,maxWidth]);

該textString參數是繪制文本。
在x和y代表在文字中得出的位置。該x 參數是文本開始的地方。該y參數是文本垂直放置的位置,但是確切的表示方式取決于文本基線。文本基線將在后面的部分中介紹。
該maxWidth文本被覆蓋在下面的部分。
這是一個代碼示例:

context.font      = "36px Verdana";
context.fillStyle = "#000000";
context.fillText("HTML5 Canvas Text", 50);

文字最大寬度

可選maxWidth參數告訴畫布,文本在水平方向上不能比給定參數值占用更多空間。如果文字太寬而無法容納 maxWidth,則文字的寬度將被壓縮。它沒有被切斷。這是一個使用和不使用繪制相同文本的代碼示例maxWidth:

context.font      = "36px Verdana";
context.fillStyle = "#000000";
context.fillText("HTML5 Canvas Text", 50);
context.fillText("HTML5 Canvas Text", 100, 200);

這是在HTML5畫布上繪制時這兩個文本的外觀:

HTML5 Canvas 繪制文本

如您所見,第二個文本的寬度被壓縮以適合maxWidth 200個像素.

文字顏色

像其他任何形狀一樣,使用2D上下文 的fillStyle和 strokeStyle屬性設置填充或描邊文本的顏色。在這里,我不會更詳細地介紹這些屬性。

測量文字寬度

2D上下文對象具有可以測量文本像素寬度的功能。它無法測量高度。該函數稱為measureText()。這是一個代碼示例:

var textMetrics = context.measureText("measure this");
 
var width = textMetrics.width;

測量文本的寬度可用于計算文本字符串是否適合特定空間等。

文字基線

文本基線確定如何解釋和 的y參數。換句話說,垂直放置文本的位置以及該位置的解釋方式。請注意,瀏覽器在解釋此屬性的方式上也可能會有細微的差異。 fillText()strokeText()
使用textBaseline2D上下文的屬性設置文本基線。以下是它可以采用的值及其含義:

top文本根據文本中最高字形的頂部對齊
hanging文本根據似乎懸掛的行對齊。這幾乎與top相同,并且在許多情況下您看不到差異。
middle文本根據文本的中間對齊。
alphabetic垂直定向字形的底部,例如拉丁字母等西方字母
ideographic水平定向字形的底部。
bottom文本是根據文本中字形的底部對齊的,該字形在文本中向下延伸最低。

這是一個示例,該示例y對所有文本使用相同的值(75)繪制文本,但對所繪制的每個文本使用不同的基線。將畫一條線y=75,向您顯示如何圍繞該y值設置文本基線。

HTML5 Canvas 繪制文本

下面是生成上述圖形的代碼:

context.stokeStyle = "#000000";
context.linewidth  = 1;
context.beginPath();
context.moveto(  0, 75);
context.lineto(500, 75);
context.stroke();
context.closePath();
 
context.font      = "16px Verdana";
context.fillStyle = "#000000";
 
context.textBaseline = "top";
context.fillText("top", 0, 75);
 
context.textBaseline = "hanging";
context.fillText("hanging", 40, 75);
 
context.textBaseline = "middle";
context.fillText("middle", 120, 75);
 
context.textBaseline = "alphabetic";
context.fillText("alphabetic", 200, 75);
 
context.textBaseline = "ideographic";
context.fillText("ideographic", 300, 75);
 
context.textBaseline = "bottom";
context.fillText("bottom-glyph", 400, 75);

文字對齊

2D上下文textAlign屬性定義了繪制時文本如何水平對齊。換句話說,該textAlign屬性定義了x繪制文本時的坐標.

start緊隨該x位置之后繪制文本
left緊隨x位置之后才繪制文本,例如start。
center文本的中心位于一個x位置。
end文本的結尾位于x位置。
right文本的右邊緣位于x位置,例如end。

以下是一些示例,顯示了該textAlign屬性的工作方式。垂直線在處繪制x = 250。所有文本也都繪制有x = 250,但是textAlign屬性的值不同。

這是圖形的代碼示例:

<canvas id="ex4" width="500" height="120" style="border: 1px solid #cccccc;">
    HTML5 Canvas not supported
</canvas>
<script>
var canvas  = document.getElementById("ex4");
var context = canvas.getContext("2d");
 
context.stokeStyle = "#000000";
context.linewidth  = 1;
context.beginPath();
context.moveto( 250, 0);
context.lineto( 250, 250);
context.stroke();
context.closePath();
 
context.font      = "16px Verdana";
context.fillStyle = "#000000";
 
context.textAlign = "center";
context.fillText("center", 250, 20);
 
context.textAlign = "start";
context.fillText("start", 40);
 
context.textAlign = "end";
context.fillText("end", 60);
 
context.textAlign = "left";
context.fillText("left", 80);
 
context.textAlign = "right";
context.fillText("right", 100);
</script>

代碼運行結果如下:  

HTML5 Canvas 繪制文本

返回頂部
亚洲国产精品人久久,亚洲va国产日韩欧美精品色婷婷,久久久久88色偷偷,免费人成黄页在线观看国际
亚洲一区二区三区视频在线播放 | 国产激情精品久久久第一区二区| 国产精品福利电影一区二区三区四区| 欧美一级淫片007| 五月综合激情日本mⅴ| 日韩亚洲欧美一区| 最新欧美精品一区二区三区| 婷婷国产在线综合| 日韩一级免费一区| 欧美人狂配大交3d怪物一区 | 一级女性全黄久久生活片免费| 国产精品白丝jk黑袜喷水| 日韩电影免费在线看| 51精品国自产在线| 色婷婷久久久综合中文字幕 | 不卡电影免费在线播放一区| 亚洲一区视频在线| 欧美无砖专区一中文字| 国内一区二区视频| 国产一区二区视频在线| 国产精品人成在线观看免费| 亚洲成人av一区二区| 一区二区三区电影在线播| 亚洲一区在线观看免费| 天堂久久久久va久久久久| 蜜臀av性久久久久蜜臀aⅴ流畅| 日韩你懂的在线观看| jizzjizzjizz欧美| 成+人+亚洲+综合天堂| 国产精品一二三| 国产精品一级黄| 久久99久久久久久久久久久| 日本视频中文字幕一区二区三区| 欧美一区二区三区影视| 欧美美女视频在线观看| 欧美少妇bbb| 精品少妇一区二区三区在线播放| 日韩精品中文字幕一区| 久久蜜臀中文字幕| 日韩一区中文字幕| 亚洲国产综合91精品麻豆| 亚洲成人先锋电影| 国产凹凸在线观看一区二区| 成人精品视频一区二区三区尤物| www.日韩大片| 欧美一级二级在线观看| 1区2区3区精品视频| 五月天久久比比资源色| 韩国精品主播一区二区在线观看| 成人午夜视频在线观看| 欧美一区二区三区在线电影| 国产精品伦理在线| 国产精品自拍三区| 欧美精品一区二区在线播放| 中文字幕亚洲电影| 精品一区二区三区免费| 精品视频在线免费看| 亚洲精品乱码久久久久久日本蜜臀| 美女视频网站久久| 欧美主播一区二区三区美女| 国产精品萝li| 色综合久久综合网| 亚洲国产日日夜夜| 欧美一卡二卡三卡| 国产酒店精品激情| 国产精品国产三级国产三级人妇| 免费精品视频最新在线| 日韩午夜在线观看视频| 日韩 欧美一区二区三区| 精品欧美一区二区久久| 成人免费三级在线| 婷婷开心激情综合| 国产欧美日韩三级| 91麻豆精品在线观看| 婷婷综合五月天| 亚洲精品欧美激情| 久久久亚洲精品石原莉奈| 91尤物视频在线观看| 精品一区在线看| 国产精品国产馆在线真实露脸| www.欧美日韩国产在线| 亚洲sss视频在线视频| 亚洲天堂精品在线观看| 久久蜜桃一区二区| 精品国产免费视频| 欧美久久久久久久久久| 欧美国产精品专区| 日本国产一区二区| 欧美va亚洲va香蕉在线| 中文字幕免费观看一区| 成人午夜精品在线| 99久久免费国产| 久久66热re国产| 久久久99免费| 国产成都精品91一区二区三| 亚洲综合999| 综合久久久久久| 亚洲国产日产av| 亚洲天堂精品在线观看| 久久精品亚洲麻豆av一区二区| 粉嫩嫩av羞羞动漫久久久| 亚洲不卡av一区二区三区| 亚洲视频网在线直播| 中文字幕成人在线观看| 91精品国产综合久久福利 | 国产精品久久久久毛片软件| 91美女在线观看| 欧美日韩免费观看一区三区| 欧美三级中文字幕在线观看| 2021中文字幕一区亚洲| 樱花影视一区二区| 中文字幕欧美区| 欧美另类一区二区三区| 成人一区二区在线观看| 五月开心婷婷久久| 亚洲sss视频在线视频| 亚洲成人自拍一区| 日本不卡123| 日韩av不卡一区二区| 欧洲一区二区三区免费视频| 日韩欧美国产成人一区二区| 日本一不卡视频| 91亚洲精品乱码久久久久久蜜桃| 欧美刺激午夜性久久久久久久| 国产一区二区三区综合 | 成人免费视频在线观看| 亚洲一区中文在线| 亚洲国产日韩一级| 一区二区三区在线观看欧美 | 国产成人在线视频网址| 26uuu亚洲综合色| 国产99久久久国产精品潘金| 久久国产生活片100| 国产精品久久久久四虎| 精一区二区三区| 欧美亚洲综合网| 在线观看91精品国产入口| 免费观看成人av| 国产一区二区三区免费| 色香蕉成人二区免费| 国产麻豆精品在线| 99re8在线精品视频免费播放| 中文欧美字幕免费| 粉嫩绯色av一区二区在线观看| 午夜私人影院久久久久| 国产激情91久久精品导航| 日韩精品福利网| 国产精品综合在线视频| 一本色道**综合亚洲精品蜜桃冫| 欧美人体做爰大胆视频| 久久综合狠狠综合久久综合88| 日韩一区欧美小说| 美女网站一区二区| 99国产精品视频免费观看| 制服丝袜成人动漫| 亚洲日本va午夜在线影院| 久久精品国产久精国产| 在线精品视频免费播放| 国产亚洲欧洲997久久综合| 亚洲成av人综合在线观看| 国产成人鲁色资源国产91色综 | 欧美电视剧免费观看| 亚洲欧洲日韩一区二区三区| 久久国产精品第一页| 欧美日韩一区三区四区| 亚洲欧洲制服丝袜| 国产成人亚洲综合a∨婷婷图片| 7777精品伊人久久久大香线蕉经典版下载| 国产日韩欧美制服另类| 久热成人在线视频| 日韩一区二区视频| 天天射综合影视| 欧美四级电影在线观看| 中文字幕一区免费在线观看 | 国产真实乱偷精品视频免| 欧美喷水一区二区| 亚洲成av人片| 欧美另类高清zo欧美| 亚洲一区免费在线观看| 在线观看国产精品网站| 一区二区视频免费在线观看| 99麻豆久久久国产精品免费 | 欧美精品 日韩| 亚洲成人福利片| 7777精品伊人久久久大香线蕉最新版| 亚洲精品视频在线| 欧美日韩中文国产| 日本不卡一区二区| 日韩精品一区二区三区四区视频| 免费一级欧美片在线观看| 日韩欧美成人一区| 国产成人精品aa毛片| 亚洲欧美日韩久久| 欧美精品久久天天躁| 经典三级一区二区| 国产精品成人午夜| 欧美日韩国产一二三| 韩国一区二区视频| 亚洲手机成人高清视频| 91精品午夜视频|