- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图只用 css 渲染一个“太阳系”图,同心圆很容易用 css border-radius、border 和一些变换来做,但我试图找到一种方法来让小“行星”遵守“轨道”或彩色边界。必须有一种更精确的方法来实现这一点
如果你看这张图片,你就会明白我要做什么:
以及它目前的样子,抱歉内联 css...
<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/
我想使用 Orbited 进行聊天。我还找到了 Orbited2。有什么不同? Orbited 死了没有?我想用solid solution,不用担心会被关闭或不支持。我还没有找到任何关于 Orbit
我最近开始学习SFML,我有一个问题,如何使第二个物体在轨道上运动,请帮助。 #include using namespace sf; int main() { RenderWindow wi
我正在尝试使用 Tweepy 获取所有带有关键字的推文,但它没有返回某些关键字的任何内容。例如,如果使用 Obama 作为关键字,我会收到很多推文,如果我使用 Arduino,我不会收到任何返回信息,
在我看来,我有一个复选框和一个标签。我正在使用 SLIM,所以代码是 = check_box_tag 'All Products' = label_tag 'All Products' 生成的等效 H
正如倾斜所暗示的那样,我试图弄清楚如何嵌入 soundcloud 文件,以及如何轻松更改嵌入的声音.. 我有一个网站,目前,让用户写一个故事,然后附加一个图像或视频。对于视频,我使用 vimeo 和
我创建了一个在应用程序的实际背景上绘制的 slider 轨道,并且还绘制了 UISlider 拇指图像。我知道如何设置 slider 的缩略图。但如何隐藏 UISlider 轨道呢? 最佳答案 如果你
从 HTTP 链接下载的 Windows Media DRM 轨道是否可以合法渐进播放? 我已经设法在没有 DRM 的情况下做到了这一点,但这里有人告诉我,使用 DRM 是不可能的。这是真的? 如果是
我有一个简单的 vtt 轨道文件编辑器,其中构建的 vtt 文件内容保存在 var vtt 中. 目前我通过保存vtt的内容来添加轨道。到文件,然后将文件读取为 我想省略保存到文件的步骤,直接将变量
我有一个简单的应用程序,用户可以在其中的文本字段中输入内容以获得各种结果。我想要一个功能,如果用户输入某些内容然后关闭浏览器选项卡,下次他们来时,我可以向他们展示他们之前/最近的搜索。即使他们关闭整个
我试图在不同的线程中同时运行 4 个 MP3 轨道。我正在使用 JLayer1.0 MP3 library播放 MP3。鉴于我无法控制线程何时启动,我使用 CountDownLatch 至少让它们同时
我可以在我的 Android 应用程序中播放来自 SoundCloud 的轨道吗?我正在尝试这段代码,但它不起作用: String res = "https://api.soundcloud.com/
我正在使用 Apple Music API 的 recent played endpoint返回最近播放的媒体 Assets 列表。 然后我使用其中之一并在 MPMusicPlayerControll
我正在使用 Foundation Orbit slider 。它工作正常,只是我需要将一些 css(移动标题)应用于页面上的特定 slider 。 如果我使用以下选择器,它会进行更改,唯一的问题是它是
我最难搞清楚如何在 Foundation 的 Orbit slider 中制作两个文本元素和一个按钮。对于这样的初学者问题,我深表歉意,但我是 Foundation 的新手,有些语法让我感到困惑。 这
我需要来自 SoundCloud 的“最流行”或“ HitTest 门的轨道”,但我找不到任何方法来做到这一点。我可以从 http://api.soundcloud.com/tracks?filter
我刚刚从 Rails 3.2 切换到 Rails 4。我正在努力确保我尽可能了解安全问题,并且我现在担心 session 。看起来 Rails 4 已经不再支持除基于 cookie 的 session
我正在开发一个应用程序,用户可以在其中流式传输或下载视频。我使用 ExoPlayer 2.9.6 实现了相同的功能。目前,在播放下载的内容时,当我尝试切换质量时,它仅显示下载的轨道。我知道它的默认行为
有谁知道制作这样的标题的最佳方法 http://i.imgur.com/NOSF0.png ?我试过使用 Firebug 并实现了这个 http://i.imgur.com/cMB3Y.png但是当我
我正在使用 Zurb 轨道 slider :http://www.zurb.com/playground/jquery_image_slider_plugin 我使用以下设置进行幻灯片放映: $(wi
所以我们在这里:http://greeceinsiders.com/VLASIOS/offcanvas/studio.html 我按照说明在页面中放置轨道 slider ,但这个似乎不起作用。我从其他
我是一名优秀的程序员,十分优秀!