gpt4 book ai didi

CSS 同心圆轨道 "planets"

转载 作者:行者123 更新时间:2023-11-29 10:00:55 25 4
gpt4 key购买 nike

我试图只用 css 渲染一个“太阳系”图,同心圆很容易用 css border-radius、border 和一些变换来做,但我试图找到一种方法来让小“行星”遵守“轨道”或彩色边界。必须有一种更精确的方法来实现这一点

如果你看这张图片,你就会明白我要做什么:

enter image description here

以及它目前的样子,抱歉内联 css...

enter image description here

<div style="width:100%; height:100vh; padding:0px; background-color:white; display:flex; flex-direction:column; position:relative; align-items:flex-end;">
<div style="width:250px; height:250px; position:absolute; border-radius:50%; background-color:red; top:50%; transform:translateY(-50%) translateX(50%); right:0px"></div>
<div style="width:450px; height:450px; position:absolute; border-radius:50%; border:2px solid red; top:50%; transform:translateY(-50%) translateX(50%); right:0px"></div>
<div style="width:650px; height:650px; position:absolute; border-radius:50%; border:2px solid red; top:50%; transform:translateY(-50%) translateX(50%); right:0px"></div>
<div style="width:850px; height:850px; position:absolute; border-radius:50%; border:2px solid red; top:50%; transform:translateY(-50%) translateX(50%); right:0px"></div>
<div style="position:absolute; height:70%; width:100px; top:50%; transform:translateY(-50%); right:15%; outline:1px solid red;">
<div style="width:25px; height:25px; border-radius:50%; border:1px solid red; position:absolute; top:0px; left:0px;"></div>
<div style="width:25px; height:25px; border-radius:50%; border:1px solid red; position:absolute; transform:translateY(-50%); top:50%; right:100%;"></div>
<div style="width:25px; height:25px; border-radius:50%; border:1px solid red; position:absolute; bottom:0px; left:0px;"></div>
</div>
<div style="position:absolute; height:80%; width:100px; top:50%; transform:translateY(-50%); right:55%; outline:1px solid red;">
<div style="width:50px; height:50px; border-radius:50%; border:1px solid red; position:absolute; top:0px; left:0px;"></div>
<div style="width:50px; height:50px; border-radius:50%; border:1px solid red; position:absolute; transform:translateY(-50%); top:50%; right:100%;"></div>
<div style="width:50px; height:50px; border-radius:50%; border:1px solid red; position:absolute; bottom:0px; left:0px;"></div>
</div>
</div>

最佳答案

因为它是关于圆的,所以您可以依靠旋转,您只需要知道距中心的距离(半径)即可。您还可以通过使用更少的元素来优化同心圆。

这是一个示例,我将使用 CSS 变量轻松控制每个元素。注意 the order of transformation is important (我们使用翻译居中,我们旋转,然后我们再次翻译)

.orbit{
width:150px;
height:150px;
padding:30px;
border-radius:50%;
background:red content-box;
border:1px solid red; /*1st orbit at 105px (30px + 150px/2) */
margin:auto;
position:relative;
}
/* 2nd at 135px */
.orbit:before,
.orbit:after{
content:"";
position:absolute;
top: var(--o,-30px);
bottom: var(--o,-30px);
left: var(--o,-30px);
right: var(--o,-30px);
border:inherit;
border-radius:inherit
}
/* 3rd orbit at 165px*/
.orbit:after {
--o:-60px;
}
.orbit span {
position:absolute;
z-index:1;
height:20px;
width:20px;
background:blue;
border-radius:inherit;
top:50%;
left:50%;
transform:translate(-50%,-50%) rotate(var(--r,0deg)) translateX(var(--d,0px));
}
body {
margin:0;
height:100vh;
display:flex;
}
<div class="orbit">
<span style="--d:105px;--r:80deg"></span>
<span style="--d:105px;--r:120deg"></span>
<span style="--d:105px;--r:-80deg"></span>
<span style="--d:135px;--r:80deg;height:30px;width:30px;background:green"></span>
<span style="--d:135px;--r:-90deg;height:30px;width:30px;background:green"></span>
<span style="--d:165px;--r:-45deg"></span>
<span style="--d:165px;--r:200deg;height:50px;width:50px;background:purple"></span>
</div>

另一个没有透明度的优化代码:

.orbit{
width:150px;
height:150px;
padding:30px;
border-radius:50%;
background:red content-box;
border:1px solid red;
box-shadow:
0 0 0 29px #fff,
0 0 0 30px red,
0 0 0 59px #fff,
0 0 0 60px red;
margin:auto;
position:relative;
}

.orbit span {
position:absolute;
height:20px;
width:20px;
background:blue;
border-radius:inherit;
top:50%;
left:50%;
transform:translate(-50%,-50%) rotate(var(--r,0deg)) translateX(var(--d,0px));
}
body {
margin:0;
height:100vh;
display:flex;
}
<div class="orbit">
<span style="--d:105px;--r:80deg"></span>
<span style="--d:105px;--r:120deg"></span>
<span style="--d:105px;--r:-80deg"></span>
<span style="--d:135px;--r:80deg;height:30px;width:30px;background:green"></span>
<span style="--d:135px;--r:-90deg;height:30px;width:30px;background:green"></span>
<span style="--d:165px;--r:-45deg"></span>
<span style="--d:165px;--r:200deg;height:50px;width:50px;background:purple"></span>
</div>

关于CSS 同心圆轨道 "planets",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58513403/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com