外圈进度条
Outer Circle Progress Bar
我试图让进度条的外圈与它后面的黑圈对齐。我已经调整了多个元素的高度和宽度,但没有成功。
我试过:
- 调整 SVG 的宽度
- 调整圆的高度和宽度
下面是我试图让它看起来的样子:
这是目前的样子:
请帮忙解释一下我应该调整什么?
#progress-bar {
position: absolute;
left: 50%;
top: 55%;
transform: translate(-51%, -50%);
width: 40%;
}
.container {
position: relative;
width: 100%;
display: flex;
justify-content: space-around;
}
.container .card {
position: relative;
width: 400px;
display: flex;
justify-content: center;
align-items: center;
height: 400px;
border-radius: 4px;
text-align: center;
overflow: hidden;
transition: 0.5s;
}
.container .card:before {
content: '';
position: absolute;
top: 0;
left: -50%;
width: 100%;
height: 100%;
background: rgba(255, 255, 255, 0.03);
pointer-events: none;
z-index: 1;
}
.percent {
position: relative;
width: 300px;
height: 300px;
border-radius: 50%;
box-shadow: inset 0 0 50px #000;
background: #222;
z-index: 1000;
}
.percent .number {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
display: flex;
justify-content: center;
align-items: center;
border-radius: 50%;
}
.percent .number h2 {
color: #777;
font-weight: 700;
font-size: 40px;
transition: 0.5s;
}
.card:hover .percent .number h2 {
color: #fff;
font-size: 60px;
}
.percent .number h2 span {
font-size: 24px;
color: #777;
transition: 0.5s;
}
.card:hover .percent .number h2 span {
color: #fff;
}
.text {
position: relative;
color: #777;
margin-top: 20px;
font-weight: 700;
font-size: 18px;
letter-spacing: 1px;
text-transform: uppercase;
transition: 0.5s;
}
svg {
position: relative;
width: 150px;
height: 150px;
z-index: 1000;
}
svg circle {
width: 100%;
height: 100%;
fill: none;
stroke: #191919;
stroke-width: 10;
stroke-linecap: round;
transform: translate(5px, 5px);
}
svg circle:nth-child(2) {
stroke-dasharray: 440;
stroke-dashoffset: 440;
}
.card:nth-child(1) svg circle:nth-child(2) {
stroke-dashoffset: calc(
440 - (440 * 90) / 100
); /* use to adjust progress bar */
stroke: #00ff43;
}
<div class="container">
<div class="card">
<div class="box">
<div class="percent">
<svg>
<circle cx="70" cy="70" r="70"></circle>
<circle cx="70" cy="70" r="70"></circle>
</svg>
<div class="number">
<h2>90<span>%</span></h2>
</div>
</div>
<h2 class="text">Html</h2>
</div>
</div>
</div>
<style>
svg {
position: relative;
width: 200px;
height: 200px;
z-index: 1000;
}
svg circle{
fill: none;
stroke-width: 10;
stroke-linecap: round;
stroke-dasharray: 1000;
}
svg circle:nth-child(2){
stroke: #f00;
stroke-dashoffset: 1000;
animation: dash 2s linear forwards;
}
svg circle:nth-child(1){
stroke-dashoffset: 0;
stroke: #000;
}
@keyframes dash {
to {
stroke-dashoffset: 0;
}
}
</style>
<body>
<svg>
<circle cx="50%" cy="50%" r="40%"></circle>
<circle cx="50%" cy="50%" r="40%"></circle>
</svg>
</body>
将值 cx
和 cy
设置为 50%
并将 r
设置为 40%
上面的简单动画应该显示 stroke-dashoffset: 0;
和 stroke-dashoffset: 1000;
之间的动画 stroke-dashoffset
应该提到的是,0 到 1000 之间的值不是线性的。这意味着 stroke-dashoffset: 100;
不是圆的 10%。
您可以将此示例应用到您的代码中,并以 %.
为单位调整 svg 宽度和高度的大小
我试图让进度条的外圈与它后面的黑圈对齐。我已经调整了多个元素的高度和宽度,但没有成功。
我试过:
- 调整 SVG 的宽度
- 调整圆的高度和宽度
下面是我试图让它看起来的样子:
这是目前的样子:
请帮忙解释一下我应该调整什么?
#progress-bar {
position: absolute;
left: 50%;
top: 55%;
transform: translate(-51%, -50%);
width: 40%;
}
.container {
position: relative;
width: 100%;
display: flex;
justify-content: space-around;
}
.container .card {
position: relative;
width: 400px;
display: flex;
justify-content: center;
align-items: center;
height: 400px;
border-radius: 4px;
text-align: center;
overflow: hidden;
transition: 0.5s;
}
.container .card:before {
content: '';
position: absolute;
top: 0;
left: -50%;
width: 100%;
height: 100%;
background: rgba(255, 255, 255, 0.03);
pointer-events: none;
z-index: 1;
}
.percent {
position: relative;
width: 300px;
height: 300px;
border-radius: 50%;
box-shadow: inset 0 0 50px #000;
background: #222;
z-index: 1000;
}
.percent .number {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
display: flex;
justify-content: center;
align-items: center;
border-radius: 50%;
}
.percent .number h2 {
color: #777;
font-weight: 700;
font-size: 40px;
transition: 0.5s;
}
.card:hover .percent .number h2 {
color: #fff;
font-size: 60px;
}
.percent .number h2 span {
font-size: 24px;
color: #777;
transition: 0.5s;
}
.card:hover .percent .number h2 span {
color: #fff;
}
.text {
position: relative;
color: #777;
margin-top: 20px;
font-weight: 700;
font-size: 18px;
letter-spacing: 1px;
text-transform: uppercase;
transition: 0.5s;
}
svg {
position: relative;
width: 150px;
height: 150px;
z-index: 1000;
}
svg circle {
width: 100%;
height: 100%;
fill: none;
stroke: #191919;
stroke-width: 10;
stroke-linecap: round;
transform: translate(5px, 5px);
}
svg circle:nth-child(2) {
stroke-dasharray: 440;
stroke-dashoffset: 440;
}
.card:nth-child(1) svg circle:nth-child(2) {
stroke-dashoffset: calc(
440 - (440 * 90) / 100
); /* use to adjust progress bar */
stroke: #00ff43;
}
<div class="container">
<div class="card">
<div class="box">
<div class="percent">
<svg>
<circle cx="70" cy="70" r="70"></circle>
<circle cx="70" cy="70" r="70"></circle>
</svg>
<div class="number">
<h2>90<span>%</span></h2>
</div>
</div>
<h2 class="text">Html</h2>
</div>
</div>
</div>
<style>
svg {
position: relative;
width: 200px;
height: 200px;
z-index: 1000;
}
svg circle{
fill: none;
stroke-width: 10;
stroke-linecap: round;
stroke-dasharray: 1000;
}
svg circle:nth-child(2){
stroke: #f00;
stroke-dashoffset: 1000;
animation: dash 2s linear forwards;
}
svg circle:nth-child(1){
stroke-dashoffset: 0;
stroke: #000;
}
@keyframes dash {
to {
stroke-dashoffset: 0;
}
}
</style>
<body>
<svg>
<circle cx="50%" cy="50%" r="40%"></circle>
<circle cx="50%" cy="50%" r="40%"></circle>
</svg>
</body>
将值 cx
和 cy
设置为 50%
并将 r
设置为 40%
上面的简单动画应该显示 stroke-dashoffset: 0;
和 stroke-dashoffset: 1000;
之间的动画 stroke-dashoffset
应该提到的是,0 到 1000 之间的值不是线性的。这意味着 stroke-dashoffset: 100;
不是圆的 10%。
您可以将此示例应用到您的代码中,并以 %.