从一个圆环进度功能来学习SVG

简介: 从一个圆环进度功能来学习SVG

从画方块开始


svg不设置宽高时默认宽度是 300px ,默认高度是 150px

<template>
    <svg class="box" >
    </svg>
</template>
<style scoped>
.box {
    border: 1px solid red;
}
</style>


image.png


也可以在 svg上添加 width 和 height两个属性设置宽高,默认是px,也可以带其他单位

<svg width="100" height="100">
</svg>


image.png


svg就相当于一个画布,画布的大小设置好了,我们就可以在上面作画了,先画一个圆吧


画个圆


圆使用 <circle> 标签,默认填充色是黑色,当只设置半径r时,渲染出来的圆就是黑色的圆

<svg width="100" height="100"  class="box" >
    <circle
        r="50"
    />
</svg>


image.png


此时我们可以看到圆的中心点在左上角,所以只显示了1/4,需要给圆一个位置 cx和cy,我想要把圆的背景变成红色,显得喜庆,就需要用到fill属性,进行填充颜色

<svg width="100" height="100" >
    <circle
        cx="50"
        cy="50"
        r="50"
        fill='red'
    />
</svg>


image.png


圆环


stroke是用来描边填充的颜色,和border类似stroke-width相当于描边的宽度,但是它不属于半径

可以用这两个属性画一个圆环

<svg width="100" height="100" class="box">
    <circle
        cx="50"
        cy="50"
        r="45"
        fill='none'
        stroke="red"
        stroke-width="10"
        />
</svg>


image.png


stroke-width设置的宽度,一半在圆内,一半在圆外


image.png


动起来


圆环进度和倒计时,主要要依靠stroke-dasharray这个属性来实现


stroke-dasharray


stroke-dasharray设置实线和间隔的距离

stroke-dasharray: 20, 5; 表示按照实线为 20,间隔为 5 的排列重复下去

<svg width="200" height="200" >
  <circle
    cx="100"
    cy="100"
    r="50"
    fill='none'
    stroke="red"
    stroke-width="10"
    stroke-dasharray="20, 5"
  />
</svg>


image.png


当间隔等于圆的周长,实线从0开始增加

<svg width="200" height="200" >
    <circle
        cx="100"
        cy="100"
        r="50"
        fill="green"
        stroke-width="10"
        stroke="red"
        stroke-dasharray="29.1719, 314.1592653589793" 
    />
</svg>


image.png


开始实现动态加载


常见的圆环进度通常都是默认两种颜色,一种是初始值,另一种是加载进度的颜色,我们可以使用两个圆,把他们的半径和位置等属性设置相同,只改变两个圆的颜色

  • 第一个circle设置边框颜色设置为灰色
  • 第二个circle设置为红色,好区分
<svg width="200" height="200" >
    <circle
        cx="100"
        cy="100"
        r="50"
        fill="none"
        stroke="#808080"
        stroke-width="10"
    />
    <circle
        cx="100"
        cy="100"
        r="50"
        fill="none"
        stroke-width="10"
        stroke="red"
        stroke-dasharray="20, 314.1592653589793" 
    />
</svg>


image.png


基础框架已经搭建好了,现在要让他动起来,我们可以用计算属性设置红色的实线长度

圆周长是 2πr这就是它的间隔,然后根据时间计算实线的距离

<template>
    <svg width="200" height="200" >
        <circle
            cx="100"
            cy="100"
            r="50"
            fill="none"
            stroke="#808080"
            stroke-width="10"
        />
        <circle
            cx="100"
            cy="100"
            r="50"
            fill="none"
            stroke-width="10"
            :style="{
                stroke:'red',
                strokeDasharray: `${currentLen} ${circleLength}`
            }"
        />
    </svg>
</template>
<script setup>
import { ref } from 'vue'
// 圆周长 2πr
const circleLength = 2 * Math.PI * 50
const time = 6 // 倒计时 6秒
let currentT = ref(0) // 当前时间
let currentLen = ref(0) // 当前长度
let timeId = setInterval(() => {
    currentT.value++
    // 计算长度
    currentLen.value = currentT.value / time * circleLength
    if(currentT.value>time) {
        clearInterval(timeId)
    }
}, 1000);
</script>


image.png


虽然说可以实现效果,但是动画太生硬,接下来可以使用动画属性把动效变顺畅一些

在style里添加transition属性来增加动画效果

:style="{
    stroke:'red',
    strokeDasharray: `${currentLen} ${circleLength}`,
    transition: 'all 1s linear',
}"


image.png


如果觉得圆环线头的类型不太好看,可以使用stroke-linecap属性来修改


image.png


:style="{
    stroke:'red',
    strokeDasharray: `${currentLen} ${circleLength}`,
    transition: 'all 1s linear',
    strokeLinecap:'round',
}"


image.png


至此一个简化版的圆环进度的主要功能就已经实现了,剩下的就是一些边边角角可以自由发挥了



目录
相关文章
|
8月前
|
前端开发 JavaScript 开发者
【QML进阶 进度条设计】打造动态弧形进度条特效
【QML进阶 进度条设计】打造动态弧形进度条特效
445 2
|
3月前
|
前端开发 JavaScript API
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
本文通过构建一个 3D 翻卡动画深入探讨了 CSS Houdini 的强大功能,展示了如何通过 Worklets、自定义属性、Paint API 等扩展 CSS 的能力,实现高度灵活的动画效果。文章首先介绍了 Houdini 的核心概念与 API,并通过构建一个动态星空背景、圆形进度条以及交互式 3D 翻卡动画的实际示例,展示了如何利用 CSS Houdini 赋予网页设计更多创造力。最后,还演示了如何将这种 3D 翻卡效果集成到公司网站中,提升用户体验。CSS Houdini 的创新能力为网页设计带来了前所未有的灵活性,推动了前端开发迈向新的高度。
58 0
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
|
5月前
|
前端开发 图形学
小功能⭐️3DCanvas交互方法、Unity自动调整文本框大小、改变文字大小和颜色
小功能⭐️3DCanvas交互方法、Unity自动调整文本框大小、改变文字大小和颜色
|
6月前
|
前端开发
前端 CSS 经典:水波进度样式
前端 CSS 经典:水波进度样式
86 0
|
前端开发
css三角号旋转90度,上下移动动画效果demo效果(整理)
css三角号旋转90度,上下移动动画效果demo效果(整理)
|
前端开发
【CSS动画02--卡片旋转3D】
【CSS动画02--卡片旋转3D】
|
移动开发 前端开发 HTML5
前端 HTML5 Svg 画板(支持视频、图片上涂鸦,支持缩放、修改、颜色、复选...)
前端 HTML5 Svg 画板(支持视频、图片上涂鸦,支持缩放、修改、颜色、复选...)
265 0
|
前端开发 容器
Echarts实战案例代码(46):带渐变背景颜色的倾斜角度的图表的CSS样式表解决方案
Echarts实战案例代码(46):带渐变背景颜色的倾斜角度的图表的CSS样式表解决方案
176 0
swiper轮播图缩略图效果彩色到黑白的变化的解决方案
swiper轮播图缩略图效果彩色到黑白的变化的解决方案
100 0
|
JavaScript 定位技术
WebGis——Pixi开发vue项目之使用遮罩实现图形缓慢填充颜色(三)
WebGis——Pixi开发vue项目之使用遮罩实现图形缓慢填充颜色(三)