欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue使用Canvas繪制圓與半圓的示例詳解

 更新時(shí)間:2023年08月28日 08:42:34   作者:炭烤小橙微辣  
在?Canvas?中,基本圖形包括直線圖形和曲線圖形,在我們的工作中,經(jīng)常在統(tǒng)計(jì)圖中會(huì)看到有餅狀圖等這樣的圓弧圖形,當(dāng)然繪制曲線圖形那么我們要知道曲線圖形的繪制往往會(huì)涉及到曲線與弧線,所以本文就給大家介紹一下Canvas繪制圓與半圓的方法

前言

在 Canvas 中,基本圖形包括直線圖形曲線圖形,之前的文章已經(jīng)學(xué)習(xí)了直線圖形,接下來我們就開啟曲線圖形的學(xué)習(xí)。 在我們的工作中,經(jīng)常在統(tǒng)計(jì)圖中會(huì)看到有餅狀圖等這樣的圓弧圖形,當(dāng)然繪制曲線圖形那么我們要知道曲線圖形的繪制往往會(huì)涉及到曲線弧線,我們需要明天曲線與弧線的區(qū)別點(diǎn):

  • 弧線上的每個(gè)點(diǎn)都具有相同的曲率,那么曲率相同,自然就是圓的一部分,這有就是圓弧的由來。
  • 曲線的概念就比較廣泛了,他可以是直線,可以是線段,可以是弧線,甚至可以是折線。

因此,我們可以現(xiàn)有的知識(shí)點(diǎn)上得出一些結(jié)論:

  • 曲線包含弧線;(弧線∈曲線)
  • 弧線也是每個(gè)點(diǎn)具有相同曲率的曲線;

我們先對(duì)更簡(jiǎn)單的圓弧展開繪制,但是要繪制圓弧,我們首先的先繪制圓吧?

繪制圓

我們來看一下繪制圓的方法:

ctx.arc(x,y,radius,startAngle,endAngle,counterclockwise)
  • x: 圓心 O 點(diǎn)橫坐標(biāo);
  • y: 圓心 O 點(diǎn)縱坐標(biāo);
  • radius: 半徑 r;
  • startAngle: 繪制開始角度(弧度制,即 角度 * Math.PI / 180);
  • endAngle: 繪制開始角度(弧度制,即 角度 * Math.PI / 180);
  • counterclockwise: 布爾值, 默認(rèn)為 false,繪制方向順時(shí)針,反之為逆時(shí)針方向;

描邊圓

還記的描邊的語法嗎?ctx.stroke() 方法;

<template>
  <canvas ref="cnv" width="200" height="150" style="border: 1px dashed gray"></canvas>
</template>
<script setup>
import {ref, onMounted} from "vue";
const cnv = ref();
const drawStrokeCircular = () => {
  const ctx = cnv.value.getContext('2d');
  ctx.beginPath();
  ctx.arc(100, 80, 60, 0, 360 * Math.PI / 180, false);
  ctx.closePath();
  ctx.strokeStyle = "hotpink";
  ctx.stroke();
}
onMounted(() => {
  drawStrokeCircular();
});
</script>

這里我們?cè)俅斡玫搅?beginPath 與 closePath 方法,表示開始一段路徑,閉合一段路徑,圓形的繪制需要這兩個(gè)方法的配合才能完成。我們重點(diǎn)來看一下 arc 方法中第5個(gè)參數(shù) 360 * Math.PI / 180,圓我們從 0° 開始繪畫,再回到原來的起畫點(diǎn),角度也應(yīng)該是 0° ?感興趣的 jym 可以試試,這樣繪畫出來其實(shí)什么都沒有,我們都知道一周的角度是 360°,所以要想繪畫出圓形,我們?cè)诶L制時(shí),也要設(shè)置成 360° 的弧度制。我們來看一下繪制的效果:

半圓以及順時(shí)針逆時(shí)針的區(qū)別

我們繪制出來了一個(gè)圓形,那么半圓我們只需要把旋轉(zhuǎn)角度設(shè)置為 180° 那么就可以實(shí)現(xiàn),我們知道 counterclockwise 參數(shù)布爾值 false 為順時(shí)針,true 為逆時(shí)針我們來看看順時(shí)針與逆時(shí)針的效果。

<template>
  <canvas ref="cnv" width="200" height="150" style="border: 1px dashed gray"></canvas>
</template>
<script setup>
import {ref, onMounted} from "vue";
const cnv = ref();
const drawSemicircle = () => {
  const ctx = cnv.value.getContext('2d');
  ctx.beginPath();
  ctx.arc(100, 75, 60, 0, 180 * Math.PI / 180, true);
  ctx.closePath();
  ctx.strokeStyle = "hotpink";
  ctx.stroke();
  ctx.beginPath();
  ctx.arc(100, 80, 60, 0, 180 * Math.PI / 180, false);
  ctx.closePath();
  ctx.strokeStyle = "hotpink";
  ctx.stroke();
}
onMounted(() => {
  drawSemicircle();
});
</script>

我們半徑,與起始,結(jié)束角度都是相同的,只有 counterclockwise 參數(shù)值相反,上半圓是逆時(shí)針繪制,下半圓為逆時(shí)針繪制的效果,沒有放在同一個(gè)圓心,主要是為了區(qū)分順時(shí)針與逆時(shí)針繪制的效果。我們來看一下效果:

填充圓

從前面的學(xué)習(xí),我們知道了填充的繪制方法: 先設(shè)置填充顏色 ctx.fillStyle ,再進(jìn)行填充繪制 ctx.fill() ; 我們就上邊的半圓進(jìn)行填充繪制:

const drawSemicircle = () => {
  const ctx = cnv.value.getContext('2d');
  ctx.beginPath();
  ctx.arc(100, 75, 60, 0, 180 * Math.PI / 180, true);
  ctx.closePath();
  ctx.fillStyle = "hotpink";
  ctx.fill();
  ctx.beginPath();
  ctx.arc(100, 80, 60, 0, 180 * Math.PI / 180, false);
  ctx.closePath();
  ctx.fillStyle = "#1677ff";
  ctx.fill();
}

從代碼中我們可以看到,我們只是把 strokeStyle 屬性換成了 fillStyle 屬性,stroke 方法 換成 fill 方法,我們就把填充圖繪制出來了,這樣看下來還是很簡(jiǎn)單的吧。

總結(jié)

回憶一下我們這一節(jié)的內(nèi)容,很簡(jiǎn)單,就是圓的繪制,我們重點(diǎn)掌握繪制圓的方法:

arc(x,y,radius,startAngle,endAngle,counterclockwise)

重點(diǎn)理解:

  • startAngle 與 endAngle 如果是相同的角度,那么是畫不出圓的。
  • counterclockwise: 繪制方向 false 為順時(shí)針繪制,反之為逆時(shí)針繪制。

以上就是Vue使用Canvas繪制圓與半圓的示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue Canvas繪制圓與半圓的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 讓firefox支持IE的一些方法的javascript擴(kuò)展函數(shù)代碼

    讓firefox支持IE的一些方法的javascript擴(kuò)展函數(shù)代碼

    因?yàn)橐恍┐a,只能在IE下實(shí)現(xiàn),如果用firefox實(shí)現(xiàn)就必須用一些擴(kuò)展函數(shù)。
    2010-01-01
  • javascript+HTML5 canvas繪制時(shí)鐘功能示例

    javascript+HTML5 canvas繪制時(shí)鐘功能示例

    這篇文章主要介紹了javascript+HTML5 canvas繪制時(shí)鐘功能,結(jié)合實(shí)例形式分析了javascript+HTML5 canvas數(shù)值運(yùn)算、圖形繪制與時(shí)間顯示相關(guān)操作技巧,需要的朋友可以參考下
    2019-05-05
  • js獲取數(shù)組對(duì)象中的全部key和value值

    js獲取數(shù)組對(duì)象中的全部key和value值

    本文主要介紹了js獲取數(shù)組對(duì)象中的全部key和value值,主要使用JavaScript的?map()?函數(shù)和?values()?迭代器來實(shí)現(xiàn)取出數(shù)組對(duì)象的所有key值和value值,感興趣的可以了解下
    2024-01-01
  • 詳解JavaScript中JSON.stringify方法

    詳解JavaScript中JSON.stringify方法

    JSON 對(duì)象是我們經(jīng)常使用的一種數(shù)據(jù)存儲(chǔ)對(duì)象,它的適用范圍非常廣,JSON.stringify 方法可以幫我們把一個(gè)對(duì)象或數(shù)組轉(zhuǎn)換成一個(gè) JSON字符串,本文我們給大家詳細(xì)介紹一下JavaScript中JSON.stringify方法,需要的朋友可以參考下
    2023-09-09
  • 原生js獲取元素樣式的簡(jiǎn)單方法

    原生js獲取元素樣式的簡(jiǎn)單方法

    下面小編就為大家?guī)硪黄鷍s獲取元素樣式的簡(jiǎn)單方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-08-08
  • JavaScript設(shè)計(jì)模式之外觀模式介紹

    JavaScript設(shè)計(jì)模式之外觀模式介紹

    這篇文章主要介紹了JavaScript設(shè)計(jì)模式之外觀模式介紹,外觀模式是用于由于子系統(tǒng)或程序組成較復(fù)雜而提供的一個(gè)高層界面接口,使用客戶端更容易訪問底層的程序或系統(tǒng)接口,需要的朋友可以參考下
    2014-12-12
  • 小程序兼容安卓和IOS數(shù)據(jù)處理問題及坑

    小程序兼容安卓和IOS數(shù)據(jù)處理問題及坑

    這篇文章主要介紹了小程序兼容安卓和IOS數(shù)據(jù)處理問題及坑,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • 微信小程序按鈕去除邊框線分享頁面功能

    微信小程序按鈕去除邊框線分享頁面功能

    這篇文章主要介紹了微信小程序按鈕去除邊框線分享頁面功能,文中通過一段簡(jiǎn)單的代碼給大家介紹了微信小程序的button去邊框的方法,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-08-08
  • javascript實(shí)現(xiàn)列表滾動(dòng)的方法

    javascript實(shí)現(xiàn)列表滾動(dòng)的方法

    這篇文章主要介紹了javascript實(shí)現(xiàn)列表滾動(dòng)的方法,較為詳細(xì)的分析了javascript實(shí)現(xiàn)列表滾動(dòng)的頁面布局及javascript滾動(dòng)效果的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • webpack動(dòng)態(tài)加載與打包方式

    webpack動(dòng)態(tài)加載與打包方式

    webpack有兩種組織模塊依賴的方式,同步和異步,這篇文章主要介紹了webpack動(dòng)態(tài)加載與打包方式,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02

最新評(píng)論