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

首頁 > 編程 > HTML > 正文

利用 Canvas實現繪畫一個未閉合的帶進度條的圓環

2024-08-26 00:21:36
字體:
來源:轉載
供稿:網友
最終效果圖

Canvas,繪畫,進度條,圓環

一、定義變量

定義半徑,定義圓環厚度,定義圓心位置、定義默認填充顏色

let radius = 75let thickness= 10let innerRadius = radius - thicknesslet x = 75let y = 75var canvas = document.getElementById('tutorial');var ctx = canvas.getContext('2d');ctx.fillStyle = "#f2d7d7";

二、畫第一個圓弧

ctx.beginPath();ctx.arc(x, y, radius, Math.PI * 1.5, Math.PI)

Canvas,繪畫,進度條,圓環

注意 beginPath() 這個方法,生成路徑的第一步。本質上,路徑是由很多子路徑構成,這些子路徑都是在一個列表中,所有的子路徑(線、弧形、等等)構成圖形。而每次這個方法調用之后,列表清空重置,然后我們就可以重新繪制新的圖形。
 

也就是說,這個方法可以用來給 Canvas圖像 分組,繪制新的圖形如果不調用此方法,那么新的圖形會和前面的圖形連接在一起

三、畫第一個連接處

ctx.quadraticCurveTo((x - innerRadius) - thickness / 2, y - thickness, x - innerRadius, y)

Canvas,繪畫,進度條,圓環

連接外是用二次貝塞爾曲線來畫的,Canvas的 quadraticCurveTo(cp1x, cp1y, x, y) 方法接受4個參數,第一、二個參數為控制點,第三、四個參數為結束點官方文檔
只需算出控制點和結束點,就可以畫出一個圓弧

四、畫第二個圓弧

ctx.arc(x, y, innerRadius, Math.PI, Math.PI * 1.5, true)

Canvas,繪畫,進度條,圓環

注意方法后面最后一個參數,設置為true,代表逆時針繪制(默認是順時針)

五、畫第二個連接處

ctx.quadraticCurveTo(y - thickness, (x - innerRadius) - thickness / 2, x, y - innerRadius - thickness)

Canvas,繪畫,進度條,圓環

這一步其實和第三步相差不大,簡單的調換了下參數位置

六、填充

 ctx.fill();

Canvas,繪畫,進度條,圓環

至此,一個簡單的未閉合的圓環就完成了

畫第二個進度條圓環

七、初始化

ctx.beginPath();ctx.fillStyle = "#e87c7c";

beginPath 表示繪制新的圖形,如果不調用此方法,那后面畫的圖形會和前面畫的圖形連在一起

八、繪制第二個進度條圓環

ctx.beginPath();ctx.fillStyle = "#e87c7c";ctx.arc(x, y, radius, Math.PI * 1.5, Math.PI * 2)ctx.quadraticCurveTo((x + innerRadius) + thickness / 2, y + thickness, x + innerRadius, y)ctx.arc(x, y, innerRadius, Math.PI * 2, Math.PI * 1.5, true)ctx.quadraticCurveTo(y - thickness, (x - innerRadius) - thickness / 2, x, y - innerRadius - thickness)ctx.fill();

Canvas,繪畫,進度條,圓環

由于和第一個圓環繪制方式一模一樣,就不在重復了,區別僅僅是圓的弧度

九、旋轉 Canvas

transform: rotate(-135deg);

Canvas,繪畫,進度條,圓環

由于css的旋轉比較方便,也省去了角度的計算,所以本人使用的是css的transform來旋轉的。當然 Canvas 也提供了旋轉的方法

完整代碼

 

<!DOCTYPE html><html lang="cn"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <meta http-equiv="X-UA-Compatible" content="ie=edge">    <title>canvas</title>    <style>        .ring {            width: 150px;            height: 150px;            display: flex;            align-items: center;            justify-content: center;            flex-direction: column;            position: relative;        }        #tutorial {            transform: rotate(-135deg);            width: 150px;             height: 150px;        }        .fraction {            position: absolute;            font-size: 30px;            font-weight: bold;            color: red;        }        .small {            font-size: 12px;            font-weight: lighter;        }        .title {            color: red;            bottom: 0;            position: absolute;        }    </style></head><body>    <div class="ring">        <canvas id="tutorial" width="150" height="150"></canvas>        <span class="fraction">100 <span class="small">分</span> </span>        <span class="title">服務分</span>    </div>    <script>        let radius = 75        let thickness = 10        let innerRadius = radius - thickness        let x = 75        let y = 75        var canvas = document.getElementById('tutorial');        var ctx = canvas.getContext('2d');        ctx.fillStyle = "#f2d7d7";        ctx.beginPath();        ctx.arc(x, y, radius, Math.PI * 1.5, Math.PI)        ctx.quadraticCurveTo((x - innerRadius) - thickness/2 , y - thickness, x - innerRadius, y)        ctx.arc(x, y, innerRadius, Math.PI, Math.PI * 1.5, true)        ctx.quadraticCurveTo(y - thickness, (x - innerRadius) - thickness / 2, x, y - innerRadius - thickness)        ctx.fill();        ctx.beginPath();        ctx.fillStyle = "#e87c7c";        ctx.arc(x, y, radius, Math.PI * 1.5, Math.PI * 2)        ctx.quadraticCurveTo((x + innerRadius) + thickness / 2, y + thickness, x + innerRadius, y)        ctx.arc(x, y, innerRadius, Math.PI * 2, Math.PI * 1.5, true)        ctx.quadraticCurveTo(y - thickness, (x - innerRadius) - thickness / 2, x, y - innerRadius - thickness)        ctx.fill();    </script></body></html>

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美国产另类| 国产精品www色诱视频| 国产99久久精品一区二区| 91国内精品久久| 欧美激情欧美狂野欧美精品| 久久噜噜噜精品国产亚洲综合| 欧美电影免费在线观看| 国产日韩欧美在线| 精品国产区一区二区三区在线观看| 亚洲综合一区二区不卡| 欧美日韩国产麻豆| 91精品国产高清自在线看超| 国产精品极品美女粉嫩高清在线| 欧美日韩国产成人| 色婷婷av一区二区三区在线观看| 有码中文亚洲精品| 亚洲人成亚洲人成在线观看| 日韩av电影在线网| 一区二区欧美久久| 精品国产福利在线| 欧美成年人网站| 亚洲欧美日韩另类| 91人成网站www| 日韩美女免费观看| 国产精品日日摸夜夜添夜夜av| 久久激情视频久久| 亚洲黄色免费三级| 亚洲风情亚aⅴ在线发布| 欧美日韩国产丝袜美女| 国内免费久久久久久久久久久| 日韩成人中文电影| 日本亚洲欧洲色α| 日韩在线一区二区三区免费视频| 国产成人精品一区| 亚洲欧美日韩国产中文专区| 国产盗摄xxxx视频xxx69| 国产精品r级在线| 亚洲第一综合天堂另类专| 国产精品丝袜高跟| 国产精品扒开腿爽爽爽视频| 欧美成人四级hd版| 2020国产精品视频| 久久99精品久久久久久噜噜| 国产成人97精品免费看片| 97视频在线观看网址| 日韩av三级在线观看| 狠狠做深爱婷婷久久综合一区| 91久久嫩草影院一区二区| 欧美日在线观看| 欧美日韩加勒比精品一区| 欧美日韩xxxxx| 亚洲开心激情网| 欧美精品一区二区免费| 日韩在线免费视频| 欧美日韩在线观看视频| 精品久久久久久国产91| 日韩视频亚洲视频| 久久久久北条麻妃免费看| 91国产精品91| 精品丝袜一区二区三区| 亚洲美女在线观看| 日韩女在线观看| 美女久久久久久久| 国产精品人人做人人爽| 精品一区二区亚洲| 日韩欧美主播在线| 精品中文视频在线| 日本午夜精品理论片a级appf发布| 午夜精品久久久久久99热| 久久精品国产成人| 国产成人在线一区| 国产有码在线一区二区视频| 91网站免费看| 日本不卡高字幕在线2019| 国产精品久久99久久| 亚洲电影免费在线观看| 超碰91人人草人人干| 欧美老肥婆性猛交视频| 欧美中文在线观看| 91成人精品网站| 中文字幕欧美日韩精品| 久久久国产精品亚洲一区| 97视频国产在线| 亚洲999一在线观看www| 久久精品最新地址| 精品亚洲男同gayvideo网站| 亚洲一区二区精品| 在线播放国产一区二区三区| 精品电影在线观看| 奇米成人av国产一区二区三区| 亚洲精品国产成人| 国产一区二区三区直播精品电影| 国产热re99久久6国产精品| 亚洲第一区第二区| 国产精品自拍偷拍视频| 国产日本欧美视频| 中文字幕久久久av一区| 久久免费国产精品1| 欧美人交a欧美精品| 色婷婷成人综合| 日韩中文字幕国产精品| 欧美最顶级丰满的aⅴ艳星| 国产精品偷伦视频免费观看国产| 精品国产乱码久久久久久婷婷| 一本一本久久a久久精品牛牛影视| 国产在线拍揄自揄视频不卡99| 日韩av中文字幕在线| 亚洲偷熟乱区亚洲香蕉av| 欧美性生活大片免费观看网址| 亚洲色图av在线| 神马国产精品影院av| 欧美一区第一页| 91亚洲精品在线观看| 亚洲a在线观看| 热99精品只有里视频精品| 欧美成人剧情片在线观看| 国产精品久久一区主播| 国产精品欧美激情| 18性欧美xxxⅹ性满足| 久久精品国产电影| 国产精品99久久久久久久久| 精品久久香蕉国产线看观看gif| 57pao国产成人免费| 日韩精品在线私人| 国产欧美日韩高清| 91久久精品国产| 亚洲精品乱码久久久久久金桔影视| 欧美大片在线免费观看| 亚洲精品ady| 热99精品只有里视频精品| 一区二区三区视频免费| 国产成人综合一区二区三区| 国产精品91久久久| 国产69精品久久久久9999| 日韩在线观看网站| 国产精品一区二区3区| 久久国产精品久久精品| 国产免费亚洲高清| 日韩av电影手机在线| 久久久久免费精品国产| 亚洲精品久久久久| 91人人爽人人爽人人精88v| 亚洲国产成人精品一区二区| 久久人人爽人人爽人人片av高清| 91精品久久久久久久久青青| 欧美日韩亚洲激情| 91亚洲精品在线观看| 91精品免费久久久久久久久| 国产欧美一区二区三区在线看| 欧美激情第1页| 日韩电影免费在线观看中文字幕| 国产精品久久精品| 久久精品视频免费播放| www.久久久久久.com| 日韩电影免费观看中文字幕| 亚洲精品美女久久| 国产一区av在线| 欧美亚洲国产另类| 亚洲成年网站在线观看| 欧美最近摘花xxxx摘花| 国产不卡精品视男人的天堂| 91av视频在线观看| 怡红院精品视频| 亚洲精品视频播放|