云端效果页面

背景是云端效果,可以随着鼠标动显示相应的动态效果

放上效果图(不完善)

 

 

里面唯一麻烦的就是你想在这个上面放上你想要的div块的时候,这个效果会被遮盖,所以这个时候你需要给他一个绝对定位absolute就可以展示在这个上面了

代码为了方便我把css写在上面了,如果为了简洁可以放到css文件中再引入(里面部分内容重复,有需要的可以取出来重复的封装到一个类样式中)

 

放上源码:(部分js代码在上篇文章中)

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js" type="text/javascript" charset="utf-8"></script>
    <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
    <script src="https://unpkg.com/element-ui/lib/index.js"></script>
    <script src="js/ThreeWebGL.js" type="text/javascript" charset="utf-8"></script>
    <script type="text/javascript" src="js/ThreeExtras.js"></script>
    <script type="text/javascript" src="js/Detector.js"></script>
    <script type="text/javascript" src="js/RequestAnimationFrame.js"></script>
    <title></title>
    <style type="text/css">
        #app{
            position: absolute;
            height: 100%;
            width: 100%;
        }
        .image1{
            margin-left: 35px;
            margin-top: 20px;
        }
        .bg-purple-light{
            text-decoration: none;
            font-size: 40px;
            margin-top: -70px;
            color: white;
            margin-left: -2%;
        }
        .bg-purple {
            float: right;
            margin-top: -40px;
            margin-right: 50px;
            font-size: 20px;
        }
        .Talentpool {
            box-shadow: -15px 15px 15px rgba(6, 17, 47, .7);
            opacity: 1;
            -webkit-transition-timing-function: cubic-bezier(.68, -.25, .265, .85);
            width: 250px;
            height: 250px;
            position: absolute;
            left: 0;
            right: 0;
            margin: auto;
            top: 0;
            bottom: 0;
            margin-left: 40%;
            font-size: 25px;
            background: -webkit-gradient(linear, left bottom, right top, color-stop(0%, #35394a), color-stop(100%, rgb(0, 0, 0)));
            background: -webkit-linear-gradient(230deg, rgba(53, 57, 74, 0) 0%, rgb(0, 0, 0) 100%);
            background: linear-gradient(230deg, rgba(53, 57, 74, 0) 0%, rgb(0, 0, 0) 100%);
            filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='rgba(53, 57, 74, 0)', endColorstr='rgb(0, 0, 0)', GradientType=1)
        }
        .Subsystem {
            box-shadow: -15px 15px 15px rgba(6, 17, 47, .7);
            opacity: 1;
            -webkit-transition-timing-function: cubic-bezier(.68, -.25, .265, .85);
            width: 250px;
            height: 250px;
            position: absolute;
            display: inline-block;
            left: 100;
            right: 100;
            margin: auto;
            top: 0;
            bottom: 0;
            margin-left: 70%;
            font-size: 25px;
            background: -webkit-gradient(linear, left bottom, right top, color-stop(0%, #35394a), color-stop(100%, rgb(0, 0, 0)));
            background: -webkit-linear-gradient(230deg, rgba(53, 57, 74, 0) 0%, rgb(0, 0, 0) 100%);
            background: linear-gradient(230deg, rgba(53, 57, 74, 0) 0%, rgb(0, 0, 0) 100%);
            filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='rgba(53, 57, 74, 0)', endColorstr='rgb(0, 0, 0)', GradientType=1)
        }
        .message {
            box-shadow: -15px 15px 15px rgba(6, 17, 47, .7);
            opacity: 1;
            -webkit-transition-timing-function: cubic-bezier(.68, -.25, .265, .85);
            width: 250px;
            height: 250px;
            position: absolute;
            margin: auto;
            top: 0;
            bottom: 0;
            margin-left: 10%;
            background: #35394a;
            background: -webkit-gradient(linear, left bottom, right top, color-stop(0%, #35394a), color-stop(100%, rgb(0, 0, 0)));
            background: -webkit-linear-gradient(230deg, rgba(53, 57, 74, 0) 0%, rgb(0, 0, 0) 100%);
            background: linear-gradient(230deg, rgba(53, 57, 74, 0) 0%, rgb(0, 0, 0) 100%);
            font-size: 25px;
            filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='rgba(53, 57, 74, 0)', endColorstr='rgb(0, 0, 0)', GradientType=1)
        }
        #login {
            margin-right: 35px;
        }
        #image{
            margin-top: 60px;
        }
        .message span{
            line-height: 60px;
        }
        .Subsystem span{
            line-height: 60px;
        }
        .Talentpool span{
            line-height: 60px;
        }
        .ring {
            height: 30px;
            width: 30px;
            background-image: url(img/lock_64px_1175815_easyicon.net.png);
            margin-top: -10px;
            margin-left: 10px;
            -webkit-background-size:100% 100%;
        }
        .showColor {
            margin-right: 80px;
            margin-top: 460px;
            float: right;
            height: 200px;
        }
        .showStyle {
            height: 20px;
            width: 20px;
            -webkit-background-size:100% 100%;
        }
        .showColor3 {
            background-image: url(img/89a213d4f8612d60e859a52aa89e169.png) !important;
        }
        .showColor2 {
            background-image:  url(img/lock_64px_1175815_easyicon.net.png) !important;
            /* red */
        }
        .showColor1 {
            background-image: url(img/lock_open_64px_1175616_easyicon.net.png) !important;
            /* green */
        }
        span{
            color: white;
        }
        a{
            color: white;
        }
        .foot {
            text-align: center;
            font-size: 18px;
            margin-top: 600px;
            margin-left: 160px;
        }
        body {
            perspective: 800px;
            height: 100vh;
            margin: 0 auto;
            overflow: hidden;
            font-family: gudea, sans-serif;
            filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#EA5C54 ', endColorstr='#bb6dec', GradientType=1)
        }
        .grid-content {
            text-align: center;
        }
    </style>
</head>
<body>
    
    <div id="app">
        <el-row>
            <el-col :span="8">
                <div class="image1">
                    <img src="img/微信图片_20190925110523.png" style="height: 80px; width: 80px;">
                </div>
            </el-col>
    
            <el-col :span="8">
                <div class="grid-content bg-purple-light">信息管理系统</div>
            </el-col>
    
            <el-col :span="8">
                <div class="grid-content bg-purple">
                    <span id="login">
                        登录名
                    </span>
                    <a href="">退出</a>
                </div>
            </el-col>
    
        </el-row>
    
        <el-row type="flex" justify="space-between">
            
            <el-col :span="6">
                <div class="grid-content message" id="divF">
                    <div id="image">
                        <img src="img/f1d20bca9cb4edaa12ce5589d35dc8d.png" style="height: 80px; width: 80px;">
                    </div>
                    <span>信息系统</span>
                    <div class="ring" id="chooseF" ></div>
                </div>
            </el-col>
            
            <el-col :span="6">
                <div class="grid-content Talentpool" id="divS">
                    <div id="image">
                        <img src="img/d96e766032b408675b13043ab109abf.png" style="height: 80px; width: 80px;">
                    </div>
                    <span>人才库管理</span>
                    <div class="ring" id="chooseS" ></div>
                </div>
            </el-col>
            
            <el-col :span="6">
                <div class="grid-content Subsystem" id="divT">
                    <div id="image">
                        <img src="img/d6c68bdc5d6888d76958d0e94f8ef3c.png" style="height: 80px; width: 80px;">
                    </div>
                    <span>文档系统</span>
                    <div class="ring" id="chooseT" ></div>
                </div>
            </el-col>
            
        </el-row>
    
        <el-row>
            <el-col :span="24">
                <div class="showColor">
                    <table style="border-spacing:0px 10px;">
                        <tr>
                            <td class="showStyle showColor1"></td>
                            <td >&nbsp;&nbsp;&nbsp;可访问</td>
                        </tr>
                        <tr>
                            <td class="showStyle showColor2"></td>
                            <td >&nbsp;&nbsp;&nbsp;无权限</td>
                        </tr>
                        <tr>
                            <td class="showStyle showColor3"></td>
                            <td >&nbsp;&nbsp;&nbsp;开发中</td>
                        </tr>
                    </table>
                </div>
            </el-col>
        </el-row>
    
        <el-row>
            <el-col :span="24">
                <div class="foot">
                    © 2019 中商云信息管理中心 版权所有
                </div>
            </el-col>
        </el-row>
    </div>
    
    
    
    
    
    
    <script id="vs" type="x-shader/x-vertex">
        varying vec2 vUv; void main() { vUv = uv; gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 ); }
    </script>
    <script id="fs" type="x-shader/x-fragment">
        uniform sampler2D map; 
        uniform vec3 fogColor; 
        uniform float fogNear; 
        uniform float fogFar; 
        varying vec2 vUv; 
        void main() { float depth = gl_FragCoord.z / gl_FragCoord.w; 
        float fogFactor = smoothstep( fogNear, fogFar, depth ); 
        gl_FragColor = texture2D( map, vUv ); 
        gl_FragColor.w *= pow( gl_FragCoord.z, 20.0 ); 
        gl_FragColor = mix( gl_FragColor, vec4( fogColor, gl_FragColor.w ), fogFactor ); }
    </script>
    <script type="text/javascript">
        if (!Detector.webgl) Detector.addGetWebGLMessage();
        var canvas = document.createElement('canvas');
        canvas.width = 32;
        canvas.height = window.innerHeight;
        var context = canvas.getContext('2d');
        var gradient = context.createLinearGradient(0, 0, 0, canvas.height);
        gradient.addColorStop(0, "#1e4877");
        gradient.addColorStop(0.5, "#4584b4");
        context.fillStyle = gradient;
        context.fillRect(0, 0, canvas.width, canvas.height);
        document.body.style.background = 'url(' + canvas.toDataURL('image/png') + ')';
        var container;
        var camera, scene, renderer, sky, mesh, geometry, material, i, h, color, colors = [],
            sprite, size, x, y, z;
        var mouseX = 0,
            mouseY = 0;
        var start_time = new Date().getTime();
        var windowHalfX = window.innerWidth / 2;
        var windowHalfY = window.innerHeight / 2;
        init();
        animate();
    
        function init() {
            container = document.createElement('div');
            document.body.appendChild(container);
            camera = new THREE.Camera(30, window.innerWidth / window.innerHeight, 1, 3000);
            camera.position.z = 6000;
            scene = new THREE.Scene();
            geometry = new THREE.Geometry();
            var texture = THREE.ImageUtils.loadTexture(
                ''
            );
            texture.magFilter = THREE.LinearMipMapLinearFilter;
            texture.minFilter = THREE.LinearMipMapLinearFilter;
            var fog = new THREE.Fog(0x4584b4, -100, 3000);
            material = new THREE.MeshShaderMaterial({
                uniforms: {
                    "map": {
                        type: "t",
                        value: 2,
                        texture: texture
                    },
                    "fogColor": {
                        type: "c",
                        value: fog.color
                    },
                    "fogNear": {
                        type: "f",
                        value: fog.near
                    },
                    "fogFar": {
                        type: "f",
                        value: fog.far
                    },
                },
                vertexShader: document.getElementById('vs').textContent,
                fragmentShader: document.getElementById('fs').textContent,
                depthTest: false
            });
            var plane = new THREE.Mesh(new THREE.Plane(64, 64));
            for (i = 0; i < 8000; i++) {
                plane.position.x = Math.random() * 1000 - 500;
                plane.position.y = -Math.random() * Math.random() * 200 - 15;
                plane.position.z = i;
                plane.rotation.z = Math.random() * Math.PI;
                plane.scale.x = plane.scale.y = Math.random() * Math.random() * 1.5 + 0.5;
                GeometryUtils.merge(geometry, plane)
            }
            mesh = new THREE.Mesh(geometry, material);
            scene.addObject(mesh);
            mesh = new THREE.Mesh(geometry, material);
            mesh.position.z = -8000;
            scene.addObject(mesh);
            renderer = new THREE.WebGLRenderer({
                antialias: false
            });
            renderer.setSize(window.innerWidth, window.innerHeight);
            container.appendChild(renderer.domElement);
            document.addEventListener('mousemove', onDocumentMouseMove, false);
            window.addEventListener('resize', onWindowResize, false)
        }
    
        function onDocumentMouseMove(event) {
            mouseX = (event.clientX - windowHalfX) * 0.25;
            mouseY = (event.clientY - windowHalfY) * 0.15
        }
    
        function onWindowResize(event) {
            camera.aspect = window.innerWidth / window.innerHeight;
            camera.updateProjectionMatrix();
            renderer.setSize(window.innerWidth, window.innerHeight)
        }
    
        function animate() {
            requestAnimationFrame(animate);
            render()
        }
    
        function render() {
            position = ((new Date().getTime() - start_time) * 0.03) % 8000;
            camera.position.x += (mouseX - camera.target.position.x) * 0.01;
            camera.position.y += (-mouseY - camera.target.position.y) * 0.01;
            camera.position.z = -position + 8000;
            camera.target.position.x = camera.position.x;
            camera.target.position.y = camera.position.y;
            camera.target.position.z = camera.position.z - 1000;
            renderer.render(scene, camera)
        }
    </script>
</body>
</html>
html

 

posted @ 2019-10-14 14:11  阿蒙不萌  阅读(999)  评论(0编辑  收藏  举报