做一个有天有地的css及html画的旋转阴阳鱼

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>天地阴阳</title>
    <style>
        /* 重置默认样式 */
        * {
            padding: 0;
            margin: 0;
            box-sizing: border-box;
        }

        /* 基础布局 */
        html, body {
            height: 100%;
        }

        .container {
            height: 100%;
            display: flex;
            flex-direction: column;
            position: relative;
        }

        /* 天地背景 */
        .sky {
            flex: 1;
            background: linear-gradient(to bottom, #87CEEB, #E0F6FF);
        }

        .earth {
            height: 50%;
            background: linear-gradient(to bottom, #90EE90, #228B22);
        }

        /* 八卦图主容器 */
        .box {
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);
            width: 300px;
            height: 300px;
            border-radius: 50%;
            box-shadow: 0 0 30px rgba(0, 0, 0, 0.3);
            animation: rotate 8s linear infinite;
            transform-origin: center center;
            backdrop-filter: blur(5px);
            /* 移除重复的样式定义和背景色 */
        }

        /* 阴阳鱼左右半圆 */
        .semi-circle {
            position: absolute;
            height: 100%;
            width: 50%;
        }

        .left {
            left: 0;
            background: #000;
            border-radius: 150px 0 0 150px;
            width: 50%;
        }

        .right {
            right: 0;
            background: #fff;
            border-radius: 0 150px 150px 0;
            width: 50%;
        }

        /* 在box容器中添加背景色 */
        .box {
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);
            width: 300px;
            height: 300px;
            border-radius: 50%;
            box-shadow: 0 0 30px rgba(0, 0, 0, 0.3);
            animation: rotate 8s linear infinite;
            transform-origin: center center;
            backdrop-filter: blur(5px);
            background: rgba(255, 255, 255, 0.8);  /* 添加背景色 */
        }

        /* 阴阳鱼大圆 */
        .circle {
            position: absolute;
            left: 25%;
            width: 50%;
            height: 50%;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .top-circle {
            top: 0;
            background: #000;  /* 改为纯黑色 */
        }

        .bottom-circle {
            bottom: 0;
            background: #fff;  /* 改为纯白色 */
        }

        /* 阴阳眼 */
        .small-circle {
            width: 30px;
            height: 30px;
            border-radius: 50%;
        }

        .white { background: #fff; }  /* 改为纯白色 */
        .black { background: #000; }  /* 改为纯黑色 */

        /* 旋转动画 */
        @keyframes rotate {
            from { transform: translate(-50%, -50%) rotate(0deg); }
            to { transform: translate(-50%, -50%) rotate(360deg); }
        }

        /* 悬停效果 */
        .box:hover {
            animation-play-state: paused;
            box-shadow: 0 0 40px rgba(0, 0, 0, 0.4);
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="sky"></div>
        <div class="earth"></div>
        <div class="box">
            <div class="semi-circle left"></div>
            <div class="semi-circle right"></div>
            <div class="circle top-circle">
                <span class="small-circle white"></span>
            </div>
            <div class="circle bottom-circle">
                <span class="small-circle black"></span>
            </div>
        </div>
    </div>
</body>
</html>
相关推荐
小奋斗几秒前
深入浅出:ES5/ES6+数组扁平化详解
javascript·面试
掘金安东尼9 分钟前
解读 hidden=until-found 属性
前端·javascript·面试
1024小神18 分钟前
jsPDF 不同屏幕尺寸 生成的pdf不一致,怎么解决
前端·javascript
古夕28 分钟前
my-first-ai-web_问题记录02:Next.js 15 动态路由参数处理
前端·javascript·react.js
清风不问烟雨z2 小时前
不仅仅是 Mock 服务:mock-h3,让前端也能优雅拥有后端能力
前端·javascript·vite
前端老鹰2 小时前
CSS backdrop-filter:给元素背景添加模糊与色调的高级滤镜
前端·css·html
Lsx_2 小时前
TypeScript 是怎么去查找类型定义的?
前端·javascript·typescript
....4923 小时前
Vue3 + Element Plus 实现可搜索、可折叠、可拖拽的部门树组件
前端·javascript·vue.js
范范之交3 小时前
JavaScript基础语法two
开发语言·前端·javascript
bitbitDown4 小时前
重构缓存时踩的坑:注释了三行没用的代码却导致白屏
前端·javascript·vue.js