进度条效果:
 
话不多说,上代码
使用css动画实现,看到一篇博客的启发,稍微修改了下,
css实现的原理是用两个半圆一开始隐藏,再分别旋转180度,最后成为一个整圆
半圆效果,一开始右边的半圆在盒子左边
加上动画,实现右边进度条效果
代码:
<div class="container">
<!-- 右边圆形 -->
<div class="rigth_content">
<div class="rotate_box right_rotate"></div>
</div>
</div>
<style> .container {
padding: 30px;
padding-left: 100px;
width: 400px;
height: 200px;
border: 1px solid #2c3e50; }
<!-- 旋转动画 -->
@-webkit-keyframes rotateright {
0% {
transform: rotate(0deg);
}
50%,100% {
transform: rotate(180deg);
}
} .rigth_content {
width: 150px;
height: 150px;
/* overflow: hidden; */
position: relative;
background-color: #eee;
} .rotate_box {
width: 150px;
height: 150px;
position: absolute;
<!-- 这里我用的是内阴影效果,也可以直接用border边框 -->
box-shadow: 0 0 3px 10px #00ff00 inset;
border-radius: 50%;
top: 0px;
} .right_rotate {
<!-- 定位到盒子的外部,一开始被遮挡 -->
left: -75px;
<!-- clip属性:截取指定区域的内容,顺序为上,右,下,左,这里不需要右边的阴影,第二个参数取一半 -->
clip: rect(0px, 75px, auto, 0);
animation: rotateright 8s linear normal;
animation-fill-mode: forwards;
}
</style>
右边的圆形绘成后,用同样的方法画出左边的圆形
完整代码:
<p>css实现:</p>
<div class="container">
<!-- 左边圆形 -->
<div class="left_content">
<div class="rotate_box left_rotate"></div>
</div>
<!-- 右边圆形 -->
<div class="rigth_content">
<div class="rotate_box right_rotate"></div>
</div>
</div>
<style>
.container {
padding: 30px;
padding-left: 100px;
width: 400px;
height: 200px;
border: 1px solid #2c3e50;
background-color: rgba(0, 0, 0, .5);
}
@-webkit-keyframes rotateright {
0% {
transform: rotate(0deg);
}
50%,100% {
transform: rotate(180deg);
}
}
@-webkit-keyframes rotateleft {
0%,50% {
transform: rotate(0deg);
}
100% {
transform: rotate(180deg);
}
}
.rigth_content {
width: 150px;
height: 150px;
overflow: hidden;
position: relative;
}
.left_content {
width: 150px;
height: 150px;
overflow: hidden;
position: relative;
float: left;
}
.rotate_box {
width: 150px;
height: 150px;
position: absolute;
box-shadow: 0 0 3px 10px #00ff00 inset;
border-radius: 50%;
top: 0px;
}
.left_rotate {
left: 75px;
clip: rect(0px, auto, auto, 75px);
animation: rotateleft 8s linear normal;
animation-fill-mode: forwards;
}
.right_rotate {
left: -75px;
clip: rect(0px, 75px, auto, 0);
animation: rotateright 8s linear normal;
animation-fill-mode: forwards;
} </style>

第二种实现方法,使用canvas绘图,这种方法效果会更好一些,扩展性更好

我是写在vue项目中的,绘制方法写在mounted中
<p>canvas实现:</p>
<canvas width="500px" height="400px" style="border: 1px solid #000;" ref="myCanvas"></canvas> mounted() {
this.$nextTick(() => {
const brush = this.$refs.myCanvas
const ctx = brush.getContext("2d")
ctx.strokeStyle = 'red'
ctx.lineCap='round'
ctx.lineWidth = 10
// 初始角度,默认是在右边3点钟方向,旋转90度到12点方位
let startangle = -90*Math.PI/180
// 初始绘制结束角度
let end = -80
let endangle = end*Math.PI/180
// 进度文字百分比
let text = 0
console.log(new Date())
// 时间需要自己换算,这里我总用时是10秒,需要算的是计时器的时间间隔,总共360°,每秒旋转36°
// 1s是1000毫秒,为了动画过渡效果顺畅,一般需要在1s内绘制几次,这里的时间拆分为36/n 1000/n.例: 若n为3次,则36/3,每次增加12°;1000/3,每333毫秒执行一次
// 圆形进度条
var timer = setInterval(() => {
// 绘制完360度就停止
if (startangle > 270*Math.PI/180) {
console.log(new Date())
clearInterval(timer)
}
ctx.beginPath()
ctx.arc(200,200,100,startangle, endangle)
ctx.stroke()
startangle = endangle
end += 12
endangle = `${end}`*Math.PI/180
}, 333) // 百分比进度
// 这里的时间计算: 百分比从0-99 执行100次,总用时10S,每秒10次,1000/10,每100毫秒执行一次
var textTimer = setInterval(() => {
// 到100%时停止
if (text > 99) {
console.log(new Date())
clearInterval(textTimer)
}
// 清除上一次绘制的百分比,这里只清除了文字区域,外围的进度条区域没有清除
// 你也可以把进度条和百分比的计时器合为一个,每次绘制全部清除,不过进度条结束角度和每次增加的角度需要改变
ctx.clearRect(150,150,100,100)
ctx.font = "40px Arial"
ctx.fillText(`${text}%`, 170, 210)
text++
}, 100)
})
}

OK~~~完成

css and canvas实现圆形进度条的更多相关文章

  1. canvas绘制圆形进度条(或显示当前已浏览网页百分比)

    使用canvas绘制圆形进度条,或者是网页加载进度条 或者是显示你浏览了本网页多少-- 由于个浏览器的计算差异,打开浏览器时 初始值有所不同,但是当拉倒网页底部时,均显示100%. 兼容性:测试浏览器 ...

  2. HTML5效果:Canvas 实现圆形进度条并显示数字百分比

    实现效果 1.首先创建html代码 <canvas id="canvas" width="500" height="500" styl ...

  3. canvas 绘制圆形进度条

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 用HTML、CSS、JS制作圆形进度条(无动画效果)

    逻辑 1.首先有一个圆:蓝色的纯净的圆,效果: 2.再来两个半圆,左边一个,右边一个将此蓝色的圆盖住,效果: 此时将右半圆旋转60°,就会漏出底圆,效果:   然后我们再用一个比底圆小的圆去覆盖这个大 ...

  5. canvas圆形进度条

    通过定义一个canvas标签, new方法传进ID值,和旋转角度值,即可生成圆形进度条 <!DOCTYPE html> <html lang="en"> & ...

  6. 简单实用的纯CSS百分比圆形进度条插件

    percircle是一款简单实用的纯CSS百分比圆形进度条插件.你不需要做任何设置,只需要按该圆形进度条插件提供的标准HTML结构来编写代码,就可以生成一个漂亮的百分比圆形进度条. 首先要做的就是引入 ...

  7. 纯CSS实现圆形进度条

    CSS的优点在于的可以随意组合HTML元素来实现许多中效果,这儿我将使用CSS来实现一个运行进度条,效果如下: 思路是用两个div来作为进度条外观,表示进度的div和外面div宽度和高度保持一致,并是 ...

  8. jquery 圆形进度条

    最近手里面的项目需要完成这个对设备性能的检测显示功能,需要使用到圆形进度条这样的效果,网上找了一圈,有很多相当的插件,找到:circliful 插件,看了他的使用说明比较的方便,于是就下载了它并将自己 ...

  9. Android 高手进阶之自定义View,自定义属性(带进度的圆形进度条)

      Android 高手进阶(21)  版权声明:本文为博主原创文章,未经博主允许不得转载. 转载请注明地址:http://blog.csdn.net/xiaanming/article/detail ...

随机推荐

  1. Android:JNA实践(附Demo)

    一.JNA和JNI的对比   1.JNI的调用流程 Android应用开发中要实现Java和C,C++层交互时,想必首先想到的是JNI,但是JNI的使用过程十分繁琐,需要自己再封装一层JNI接口进行转 ...

  2. react-native-swiper设定高度的方法(设置rn轮播图所占高度)

    效果图: 直接上解决方案: 1.在Swiper标签外套一层View <View style={styles.container}> <Swiper style={styles.wra ...

  3. Fragment入门代码

    让一个activity和加载多个布局文件 package com.example.fragment; import android.app.Activity; import android.app.F ...

  4. Django Model模型

    Model简介 模型准确且唯一的描述了数据.它包含您储存的数据的重要字段和行为.一般来说,每一个模型都映射一张数据库表. 每个模型都是一个 Python 的类,这些类继承 django.db.mode ...

  5. Golang gRPC微服务01: 介绍

    gRPC 是什么 gRPC是goole开源的一个RPC框架和库,支持多语言之间的通信.底层通信采用的是 HTTP2 协议.gRPC在设计上使用了 ProtoBuf 这种接口描述语言.这种IDL语言可以 ...

  6. zabbix3.0升级到4.0

    升级步鄹: 3.0->3.2 1.停服务 service zabbix-server stop 2.备份配置文件 #cp /etc/zabbix/zabbix_server.conf /data ...

  7. python3速查参考- python基础 4 -> 元组 + 字典 + 字符串 的学习

    元组 元组:特点就是内容不可变,算只读的列表,可以被查询,不能被修改 a = 2, print(a) print(type(a)) b = ('a','b','c') print(b[1]) 运行结果 ...

  8. MBProgressHUD长时间加载无法取消的解决方法

    使用MBProgressHUD时,加载网路数据,或者等待webview加载完毕,长时间的等待导致体验不佳,这时候希望点击屏幕取消加载动画效果: // MBProgressHUD.h @protocol ...

  9. Asp.net Core深入一:数据库访问(Mysql为例)

    一.数据库概述 1.一个DBContext操纵一个数据库 2.DbContext下的一个DbSet<Model类>关联一个表,但是也可以只写一个表,DbContext可以关联其他的表. 3 ...

  10. Elasticsearch unassigned 故障排查

    1. 故障分析与排查 一个 Elasticsearch 集群至少包括一个节点和一个索引.或者它 可能有一百个数据节点.三个单独的主节点,以及一小打客户端节点--这些共同操作一千个索引(以及上万个分片) ...