虽然可以使用 CSS 实现绕圆旋转单个对象,但当您想要旋转多个对象时就会出现挑战同时地。下面是一个详细的解决方案,将指导您完成此过程:
该解决方案利用 jQuery,这是一个功能强大的 JavaScript 库,可以简化 DOM 操作和动画。它允许您围绕圆旋转多个对象,无论其数量如何。
var radius = 100; // adjust to move out items in and out var fields = $('.item'), container = $('#container'), width = container.width(), height = container.height(); var angle = 0, step = (2 * Math.PI) / fields.length; fields.each(function() { var x = Math.round(width / 2 + radius * Math.cos(angle) - $(this).width() / 2); var y = Math.round(height / 2 + radius * Math.sin(angle) - $(this).height() / 2); if (window.console) { console.log($(this).text(), x, y); } $(this).css({ left: x + 'px', top: y + 'px' }); angle += step; });
此 jQuery 代码根据圆的半径和对象的数量计算每个对象的位置。它设置每个对象的左侧和顶部位置,使其围绕圆的周边对齐。
要完成动画,您可以添加以下 CSS 规则:
body { padding: 2em; } #container { width: 200px; height: 200px; margin: 10px auto; border: 1px solid #000; position: relative; border-radius: 50%; animation: spin 10s linear infinite; } .item { width: 30px; height: 30px; line-height: 30px; text-align: center; border-radius: 50%; position: absolute; background: #f00; animation: spin 10s linear infinite reverse; } @keyframes spin { 100% { transform: rotate(1turn); } }
这些规则创建一个带有圆形边框的容器,每个对象围绕容器以相反的方向旋转。通过调整radius变量,可以控制物体距离圆心的距离。
通过结合jQuery和CSS,您可以使用CSS轻松地围绕一个圆旋转多个物体,并达到想要的动画效果.
以上是如何使用 CSS 和 jQuery 绕圆旋转多个对象?的详细内容。更多信息请关注PHP中文网其他相关文章!