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

首頁 > 編程 > HTML > 正文

HTML5 Canvas自定義圓角矩形與虛線示例代碼

2024-08-26 00:16:35
字體:
來源:轉載
供稿:網友

點評:HTML5 Canvas繪制對象中提供的原生功能沒有實現繪制圓角矩形與虛線的功能,通過JavaScript的Object.prototype可以實現對對象CanvasRenderingContext2D添加這兩個函數功能,具體實現如下,感興趣的朋友可以參考下

HTML5 Canvas自定義圓角矩形與虛線(RoundedRectangle and Dash Line)

實現向HTML Canvas 2d context繪制對象中添加自定義的函數功能演示,如何繪制虛線以及控制虛線間隔大小,學會繪制圓角矩形的技巧。

HTML5 Canvas繪制對象中提供的原生功能沒有實現繪制圓角矩形與虛線的功能,但是通過JavaScript語言的Object.prototype可以實現對對象CanvasRenderingContext2D添加這兩個函數功能。代碼的演示效果如下:

HTML5 Canvas自定義圓角矩形與虛線示例代碼

 
組件fishcomponent.js的代碼如下:

復制代碼

代碼如下:


CanvasRenderingContext2D.prototype.roundRect =
function(x, y, width, height, radius, fill, stroke) {
if (typeof stroke == "undefined") {
stroke = true;
}
if (typeof radius === "undefined") {
radius = 5;
}
this.beginPath();
this.moveTo(x + radius, y);
this.lineTo(x + width - radius, y);
this.quadraticCurveTo(x + width, y, x + width, y + radius);
this.lineTo(x + width, y + height - radius);
this.quadraticCurveTo(x + width, y + height, x + width - radius, y+ height);
this.lineTo(x + radius, y + height);
this.quadraticCurveTo(x, y + height, x, y + height - radius);
this.lineTo(x, y + radius);
this.quadraticCurveTo(x, y, x + radius, y);
this.closePath();
if (stroke) {
this.stroke();
}
if (fill) {
this.fill();
}
};
CanvasRenderingContext2D.prototype.dashedLineTo = function (fromX, fromY, toX, toY, pattern) {
// default interval distance -> 5px
if (typeof pattern === "undefined") {
pattern = 5;
}
// calculate the delta x and delta y
var dx = (toX - fromX);
var dy = (toY - fromY);
var distance = Math.floor(Math.sqrt(dx*dx + dy*dy));
var dashlineInteveral = (pattern <= 0) ? distance : (distance/pattern);
var deltay = (dy/distance) * pattern;
var deltax = (dx/distance) * pattern;
// draw dash line
this.beginPath();
for(var dl=0; dl<dashlineInteveral; dl++) {
if(dl%2) {
this.lineTo(fromX + dl*deltax, fromY + dl*deltay);
} else {
this.moveTo(fromX + dl*deltax, fromY + dl*deltay);
}
}
this.stroke();
};


HTML中調用演示:

復制代碼

代碼如下:


<!DOCTYPE html>
<html>
<head>
<meta http-equiv="X-UA-Compatible" content="chrome=IE8">
<meta http-equiv="Content-type" content="text/html;charset=UTF-8">
<title>Canvas Rounded Rectangle Demo</title>
<script src="fishcomponent.js"></script>
<link href="default.css" />
<script>
var ctx = null; // global variable 2d context
var imageTexture = null;
window.onload = function() {
var canvas = document.getElementById("text_canvas");
console.log(canvas.parentNode.clientWidth);
canvas.width = canvas.parentNode.clientWidth;
canvas.height = canvas.parentNode.clientHeight;
if (!canvas.getContext) {
console.log("Canvas not supported. Please install a HTML5 compatible browser.");
return;
}
var context = canvas.getContext('2d');
context.strokeStyle="red";
context.fillStyle="RGBA(100,255,100, 0.5)";
context.roundRect(50, 50, 150, 150, 5, true);
context.strokeStyle="blue";
for(var i=0; i<10; i++) {
var delta = i*20;
var pattern = i*2+1;
context.dashedLineTo(250, 50+delta, 550, 50+delta, pattern);
}
}
</script>
</head>
<body>
<h1>HTML5 Canvas Dash-line Demo - By Gloomy Fish</h1>
<pre>Dash line and Rounded Rectangle</pre>
<div>
<canvas></canvas>
</div>
</body>
</html>


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本高清+成人网在线观看| 在线观看国产精品淫| 北条麻妃久久精品| 国产一区二区精品丝袜| 中文字幕日韩免费视频| 亚洲电影av在线| 国产成人精品免费久久久久| 亚洲天堂av图片| 最近2019年中文视频免费在线观看| 在线观看久久av| 亚洲成人激情小说| 国产69久久精品成人看| 国产精品视频男人的天堂| 91免费人成网站在线观看18| 51ⅴ精品国产91久久久久久| 18久久久久久| 亚洲欧美激情在线视频| 欧美视频免费在线| 亚洲国产精品视频在线观看| 亚洲japanese制服美女| 日产精品99久久久久久| 色妞在线综合亚洲欧美| 欧美一区二区三区图| 国产视频亚洲精品| 在线视频一区二区| 日韩精品中文字幕在线观看| 欧美精品少妇videofree| 久久精品成人一区二区三区| 日韩一区二区在线视频| 亚洲欧美国产va在线影院| 成人高h视频在线| 欧美亚洲国产日本| 亚洲韩国欧洲国产日产av| 久久亚洲春色中文字幕| 97在线精品国自产拍中文| 亚洲最新视频在线| 久久夜色精品国产欧美乱| 精品国产精品三级精品av网址| 成人激情黄色网| 亚洲激情在线视频| 亚洲欧美另类中文字幕| 91精品国产91久久久久| 亚洲japanese制服美女| 欧美大片在线影院| 欧美激情视频一区二区| 国产盗摄xxxx视频xxx69| 久久久久久久久久国产| 青青久久av北条麻妃海外网| 久久久精品网站| 国产一区二区三区网站| 亚洲第一精品久久忘忧草社区| 欧美亚洲国产另类| 国产精品自产拍在线观看| 高潮白浆女日韩av免费看| 国产精品久久久久免费a∨大胸| 日本高清不卡在线| 亚洲人线精品午夜| 精品久久久91| 国产精品亚洲精品| 久久亚洲精品中文字幕冲田杏梨| 欧美激情极品视频| 亚洲国产精品久久久| 久久夜色精品国产欧美乱| 在线视频国产日韩| 国产精品久久久久久久久久| 欧美乱大交xxxxx| 色综合视频网站| 亚洲人成免费电影| 精品精品国产国产自在线| 亚洲欧美日韩国产中文专区| 亚洲精品久久久久中文字幕欢迎你| 亚洲国产精品一区二区久| 一区二区三区日韩在线| 91精品视频播放| 久久久久久com| 亚洲综合成人婷婷小说| 日韩的一区二区| 欧美日本在线视频中文字字幕| 亚洲精品女av网站| 亚洲一级免费视频| 国产黑人绿帽在线第一区| 国产成人精品一区二区在线| 国产精品久久久久久久午夜| 日韩亚洲一区二区| 欧美日韩高清在线观看| 日韩中文字在线| 午夜精品久久久久久久白皮肤| 亚洲欧美三级伦理| 欧美成人手机在线| 欧美日韩国产精品一区二区三区四区| 欧美日韩国产123| 91高清在线免费观看| 亚洲精品国产精品乱码不99按摩| y97精品国产97久久久久久| 国产精品福利观看| 午夜精品蜜臀一区二区三区免费| 欧美午夜精品伦理| 久久欧美在线电影| 国产精品高潮在线| 亚洲精品久久久久久久久久久久久| 一本大道久久加勒比香蕉| 92看片淫黄大片欧美看国产片| 一个人www欧美| 国产精品久久久久久久久| 日韩中文在线中文网在线观看| 欧美日韩中国免费专区在线看| 精品亚洲一区二区三区在线观看| 国产亚洲xxx| 久久视频精品在线| 国产在线观看精品一区二区三区| 97**国产露脸精品国产| www.日韩.com| 尤物yw午夜国产精品视频明星| 精品中文字幕视频| 992tv成人免费影院| 精品爽片免费看久久| 狠狠色噜噜狠狠狠狠97| 久久精品99久久久香蕉| 亚洲欧美日本精品| 亚洲少妇激情视频| 在线精品视频视频中文字幕| 中文字幕亚洲图片| 国内精品久久久久影院 日本资源| 中文字幕日韩精品在线观看| 亚洲自拍av在线| 91色p视频在线| 国模精品视频一区二区三区| 久久久精品国产一区二区| 欧美日韩国产丝袜美女| 国产在线精品一区免费香蕉| 国产精品r级在线| 亚洲精品自拍第一页| 最近2019好看的中文字幕免费| 国产精品久久91| 亚洲欧美制服丝袜| 日韩中文字幕在线免费观看| 色综合天天综合网国产成人网| 亚洲r级在线观看| 欧美黄色免费网站| 亚洲图片制服诱惑| 亚洲国产美女精品久久久久∴| 高清一区二区三区日本久| www.亚洲一二| 一区二区三区视频免费| 亚洲国产精品99| 欧美专区福利在线| 久久资源免费视频| 欧美激情视频免费观看| 欧美一级电影免费在线观看| 国产一区二区美女视频| 久久久久久久国产精品| 亚洲电影免费在线观看| 色婷婷综合成人av| 国产精品老女人精品视频| 国产精品久久视频| 欧美日韩在线观看视频小说| 欧美视频中文在线看| 亚洲欧美一区二区三区在线| 亚洲aaaaaa| 91成人福利在线| 伊人成人开心激情综合网| 欧美日韩亚洲一区二区| 在线播放日韩欧美| 亚洲国产欧美一区二区丝袜黑人|