自动化立体仓库 - WCS系统
Junjie
2023-07-20 e9ed17ca2d5eaafe69704ee817817a539d847e78
登录页面
3个文件已添加
6个文件已修改
1928 ■■■■■ 已修改文件
src/main/java/com/zy/common/web/AuthController.java 16 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/system/mapper/ConfigMapper.java 7 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/system/service/ConfigService.java 7 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/system/service/impl/ConfigServiceImpl.java 11 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/resources/mapper/ConfigMapper.xml 13 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/webapp/static/wcs/images/banner.mp4 补丁 | 查看 | 原始文档 | blame | 历史
src/main/webapp/static/wcs/images/weixin_qrcode.jpg 补丁 | 查看 | 原始文档 | blame | 历史
src/main/webapp/views/login.html 1075 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/webapp/views/login2.html 799 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main/java/com/zy/common/web/AuthController.java
@@ -46,6 +46,8 @@
    private PermissionService permissionService;
    @Autowired
    private RolePermissionService rolePermissionService;
    @Autowired
    private ConfigService configService;
    @RequestMapping("/login.action")
    @ManagerAuth(value = ManagerAuth.Auth.NONE, memo = "登录")
@@ -80,6 +82,20 @@
        return R.ok(res);
    }
    @RequestMapping("/loginInformation")
    public R getLoginPageInformation() {
        Config loginLogo = configService.selectByCode("loginLogo");
        Config loginCopyrightText = configService.selectByCode("loginCopyrightText");
        Config loginCopyrightImg1 = configService.selectByCode("loginCopyrightImg1");
        HashMap<String, Object> map = new HashMap<>();
        map.put("loginLogo", loginLogo.getValue());
        map.put("loginCopyrightText", loginCopyrightText.getValue());
        map.put("loginCopyrightImg1", loginCopyrightImg1.getValue());
        return R.ok().add(map);
    }
    @RequestMapping("/code/switch.action")
    public R code() {
        return R.ok().add(Parameter.get().getCodeSwitch());
src/main/java/com/zy/system/mapper/ConfigMapper.java
@@ -3,10 +3,17 @@
import com.baomidou.mybatisplus.mapper.BaseMapper;
import com.zy.system.entity.Config;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository;
import java.util.List;
@Mapper
@Repository
public interface ConfigMapper extends BaseMapper<Config> {
    Config selectByCode(String code);
    List<Config> selectByCodes(@Param("codes") List<String> codes);
}
src/main/java/com/zy/system/service/ConfigService.java
@@ -2,7 +2,14 @@
import com.baomidou.mybatisplus.service.IService;
import com.zy.system.entity.Config;
import org.apache.ibatis.annotations.Param;
import java.util.List;
public interface ConfigService extends IService<Config> {
    Config selectByCode(String code);
    List<Config> selectByCodes(@Param("codes") List<String> codes);
}
src/main/java/com/zy/system/service/impl/ConfigServiceImpl.java
@@ -6,7 +6,18 @@
import com.zy.system.service.ConfigService;
import org.springframework.stereotype.Service;
import java.util.List;
@Service("configService")
public class ConfigServiceImpl extends ServiceImpl<ConfigMapper, Config> implements ConfigService {
    @Override
    public Config selectByCode(String code) {
        return this.baseMapper.selectByCode(code);
    }
    @Override
    public List<Config> selectByCodes(List<String> codes) {
        return this.baseMapper.selectByCodes(codes);
    }
}
src/main/resources/mapper/ConfigMapper.xml
@@ -13,4 +13,17 @@
    </resultMap>
    <select id="selectByCode" resultMap="BaseResultMap">
        select top 1 * from sys_config
        where code = #{code}
    </select>
    <select id="selectByCodes" resultMap="BaseResultMap">
        select * from sys_config
        where code in
        <foreach item="item" collection="codes" index="index"  separator="," open="(" close=")">
            #{item}
        </foreach>
    </select>
</mapper>
src/main/webapp/static/wcs/images/banner.mp4
Binary files differ
src/main/webapp/static/wcs/images/weixin_qrcode.jpg
src/main/webapp/views/login.html
@@ -1,799 +1,308 @@
<!doctype html>
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>中扬 │ login of zoneyung wcs</title>
    <head>
        <meta charset="utf-8">
        <title>中扬 │ login of zoneyung wcs</title>
        <style>
            * {
                padding: 0;
                margin: 0;
            }
    <style>
        html,body {
            height:100%;
        }
        body {
            margin:0;
            background:#000;
        }
        canvas {
            display:block;
        }
        .waves {
            position:absolute;
            left:0;
            top:0;
            right:0;
            bottom:0;
        }
            .container {
                display: flex;
                height: 100vh;
                width: 100%;
            }
        .form_main {
            width: 300px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            background-color: rgba(255, 255, 255, 0.6);
            padding: 50px 30px 50px 30px;
            border-radius: 30px;
            box-shadow: 0px 0px 40px rgba(0, 0, 0, 0.062);
        }
            .left-box {
                height: 100%;
                width: 70%;
            }
        .heading {
            font-size: 2.5em;
            color: #2e2e2e;
            font-weight: 700;
            margin: 15px 0 0px 0;
        }
            .login-video {
                height: 100%;
                overflow: hidden;
            }
        .inputContainer {
            width: 100%;
            position: relative;
            display: flex;
            align-items: center;
            justify-content: center;
        }
            .form-main {
                width: 300px;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: center;
                background-color: rgba(255, 255, 255, 0.6);
                padding: 50px 30px 50px 30px;
                border-radius: 20px;
                box-shadow: 0px 0px 40px rgba(0, 0, 0, 0.062);
            }
        .inputIcon {
            position: absolute;
            left: 10px;
        }
            .heading {
                font-size: 2.5em;
                color: #2e2e2e;
                font-weight: 700;
                margin: 15px 0 0px 0;
            }
        .inputField {
            width: 100%;
            height: 40px;
            background-color: transparent;
            border: none;
            border-bottom: 2px solid rgb(173, 173, 173);
            border-radius: 30px;
            margin: 10px 0;
            color: black;
            font-size: .8em;
            font-weight: 500;
            box-sizing: border-box;
            padding-left: 30px;
        }
            .inputContainer {
                width: 100%;
                position: relative;
                display: flex;
                align-items: center;
                justify-content: center;
            }
        .inputField:focus {
            outline: none;
            border-bottom: 2px solid rgb(199, 114, 255);
        }
            .inputIcon {
                position: absolute;
                left: 10px;
            }
        .inputField::placeholder {
            color: rgb(80, 80, 80);
            font-size: 1em;
            font-weight: 500;
        }
            .inputField {
                width: 100%;
                height: 40px;
                background-color: transparent;
                border: none;
                border-bottom: 2px solid rgb(173, 173, 173);
                border-radius: 30px;
                margin: 10px 0;
                color: black;
                font-size: .8em;
                font-weight: 500;
                box-sizing: border-box;
                padding-left: 30px;
            }
        #login-button {
            position: relative;
            width: 100%;
            border: 2px solid #8000ff;
            background-color: #8000ff;
            height: 40px;
            color: white;
            font-size: .8em;
            font-weight: 500;
            letter-spacing: 1px;
            border-radius: 30px;
            margin: 10px;
            cursor: pointer;
            overflow: hidden;
        }
            .inputField:focus {
                outline: none;
                border-bottom: 2px solid rgb(199, 114, 255);
            }
        #login-button::after {
            content: "";
            position: absolute;
            background-color: rgba(255, 255, 255, 0.253);
            height: 100%;
            width: 150px;
            top: 0;
            left: -200px;
            border-bottom-right-radius: 100px;
            border-top-left-radius: 100px;
            filter: blur(10px);
            transition-duration: .5s;
        }
            .inputField::placeholder {
                color: rgb(80, 80, 80);
                font-size: 1em;
                font-weight: 500;
            }
            .login-box {
                height: 100%;
                display: flex;
                justify-content: center;
                align-items: center;
            }
        #login-button:hover::after {
            transform: translateX(600px);
            transition-duration: .5s;
        }
            #login-button {
                position: relative;
                width: 100%;
                border: 2px solid #8000ff;
                background-color: #8000ff;
                height: 40px;
                color: white;
                font-size: .8em;
                font-weight: 500;
                letter-spacing: 1px;
                border-radius: 30px;
                margin: 10px;
                cursor: pointer;
                overflow: hidden;
            }
        .signupContainer {
            margin: 0;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 20px;
        }
            #login-button::after {
                content: "";
                position: absolute;
                background-color: rgba(255, 255, 255, 0.253);
                height: 100%;
                width: 150px;
                top: 0;
                left: -200px;
                border-bottom-right-radius: 100px;
                border-top-left-radius: 100px;
                filter: blur(10px);
                transition-duration: .5s;
            }
        .signupContainer p {
            font-size: .9em;
            font-weight: 500;
            color: black;
        }
            #login-button:hover::after {
                transform: translateX(600px);
                transition-duration: .5s;
            }
            .right-box {
                height: 100%;
                width: 30%;
                background: #f6f6f6;
                position: relative;
            }
            .login-copyright {
                position: absolute;
                bottom: 20px;
                right: 20px;
                font-size: 14px;
                width: 100%;
                display: flex;
                justify-content: center;
                align-items: center;
            }
            .copyright-text {
                margin-right: 20px;
            }
            .copyright-img {
                width: 40px;
                height: 40px;
                position: relative;
            }
            .copyright-img > img {
                width: 100%;
                height: 100%;
            }
            .copyright-img-large {
                width: 140px;
                height: 140px;
                position: absolute;
                top: -140px;
                left: -50px;
                display: none;
            }
            .copyright-img-large > img {
                width: 100%;
                height: 100%;
            }
        </style>
    </head>
    <body>
        <div class="container">
            <div class="left-box">
                <div class="login-video">
                    <video src="../static/wcs/images/banner.mp4" height="100%" loop autoplay muted="false"
                        controlslist="nodownload" disablepictureinpicture></video>
                </div>
            </div>
        .signupContainer a {
            font-size: .7em;
            font-weight: 500;
            background-color: #2e2e2e;
            color: white;
            text-decoration: none;
            padding: 8px 15px;
            border-radius: 20px;
        }
            <div class="right-box">
                <div class="login-box">
                    <div class="form-main">
                        <p style="text-align: center;"><img class="loginLogoUrl" src="../static/wcs/images/logo.png" alt="" style="width: 80%">
                        </p>
                        <p style="margin-top: -15px;"><span class="login100-form-title p-t-20 p-b-45"
                                style="color: #868686;font-size: 24px">WCS</span></p>
                        <div class="inputContainer">
                            <svg viewBox="0 0 16 16" fill="#2e2e2e" height="16" width="16"
                                xmlns="http://www.w3.org/2000/svg" class="inputIcon">
                                <path
                                    d="M13.106 7.222c0-2.967-2.249-5.032-5.482-5.032-3.35 0-5.646 2.318-5.646 5.702 0 3.493 2.235 5.708 5.762 5.708.862 0 1.689-.123 2.304-.335v-.862c-.43.199-1.354.328-2.29.328-2.926 0-4.813-1.88-4.813-4.798 0-2.844 1.921-4.881 4.594-4.881 2.735 0 4.608 1.688 4.608 4.156 0 1.682-.554 2.769-1.416 2.769-.492 0-.772-.28-.772-.76V5.206H8.923v.834h-.11c-.266-.595-.881-.964-1.6-.964-1.4 0-2.378 1.162-2.378 2.823 0 1.737.957 2.906 2.379 2.906.8 0 1.415-.39 1.709-1.087h.11c.081.67.703 1.148 1.503 1.148 1.572 0 2.57-1.415 2.57-3.643zm-7.177.704c0-1.197.54-1.907 1.456-1.907.93 0 1.524.738 1.524 1.907S8.308 9.84 7.371 9.84c-.895 0-1.442-.725-1.442-1.914z">
                                </path>
                            </svg>
                            <input placeholder="请输入用户名" id="username" name="username" class="inputField" type="text">
                        </div>
                        <div class="inputContainer">
                            <svg viewBox="0 0 16 16" fill="#2e2e2e" height="16" width="16"
                                xmlns="http://www.w3.org/2000/svg" class="inputIcon">
                                <path
                                    d="M8 1a2 2 0 0 1 2 2v4H6V3a2 2 0 0 1 2-2zm3 6V3a3 3 0 0 0-6 0v4a2 2 0 0 0-2 2v5a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2z">
                                </path>
                            </svg>
                            <input placeholder="请输入密码" id="password" name="pass" class="inputField" type="password">
                        </div>
                        <input type="button" id="login-button" value="登录">
                    </div>
                </div>
                <div class="login-copyright">
                    <div class="copyright-text">Copyright ©2023 浙江中扬立库技术有限公司版权所有</div>
                    <div id="copyright-img1" class="copyright-img">
                        <img class="copyright-img-url" src="../static/wcs/images/weixin_qrcode.jpg" />
                        <div id="copyright-img-large1" class="copyright-img-large"><img class="copyright-img-url" src="../static/wcs/images/weixin_qrcode.jpg" /></div>
                    </div>
                </div>
            </div>
        </div>
        <script type="text/javascript" src="../static/wms/js/jquery/jquery-3.3.1.min.js"></script>
        <script type="text/javascript" src="../static/wms/js/tools/md5.js"></script>
        <script type="text/javascript" src="../static/wms/layer/layer.js"></script>
        <script type="text/javascript" src="../static/wms/js/common.js"></script>
        <script>
            // remember pwd
            $(function () {
                $.ajax({
                    url: baseUrl+"/loginInformation",
                    data: {},
                    method: 'GET',
                    success: function (res) {
                        var data = res.data
                        $(".copyright-text").text(data.loginCopyrightText);
                        $(".copyright-img-url").attr("src", data.loginCopyrightImg1);
                        $(".loginLogoUrl").attr("src", data.loginLogo);
                    }
                });
    </style>
</head>
<body>
<div class="waves">
    <div style="position: absolute;left: calc(50% - 200px);top: 25%;">
        <div class="form_main">
            <p style="text-align: center;"><img src="../static/wcs/images/logo.png" alt="" style="width: 80%"></p>
            <p style="margin-top: -15px;"><span class="login100-form-title p-t-20 p-b-45" style="color: #868686;font-size: 24px">WCS</span></p>
            <div class="inputContainer">
                <svg viewBox="0 0 16 16" fill="#2e2e2e" height="16" width="16" xmlns="http://www.w3.org/2000/svg" class="inputIcon">
                    <path d="M13.106 7.222c0-2.967-2.249-5.032-5.482-5.032-3.35 0-5.646 2.318-5.646 5.702 0 3.493 2.235 5.708 5.762 5.708.862 0 1.689-.123 2.304-.335v-.862c-.43.199-1.354.328-2.29.328-2.926 0-4.813-1.88-4.813-4.798 0-2.844 1.921-4.881 4.594-4.881 2.735 0 4.608 1.688 4.608 4.156 0 1.682-.554 2.769-1.416 2.769-.492 0-.772-.28-.772-.76V5.206H8.923v.834h-.11c-.266-.595-.881-.964-1.6-.964-1.4 0-2.378 1.162-2.378 2.823 0 1.737.957 2.906 2.379 2.906.8 0 1.415-.39 1.709-1.087h.11c.081.67.703 1.148 1.503 1.148 1.572 0 2.57-1.415 2.57-3.643zm-7.177.704c0-1.197.54-1.907 1.456-1.907.93 0 1.524.738 1.524 1.907S8.308 9.84 7.371 9.84c-.895 0-1.442-.725-1.442-1.914z"></path>
                </svg>
                <input placeholder="请输入用户名" id="username" name="username" class="inputField" type="text">
            </div>
            <div class="inputContainer">
                <svg viewBox="0 0 16 16" fill="#2e2e2e" height="16" width="16" xmlns="http://www.w3.org/2000/svg" class="inputIcon">
                    <path d="M8 1a2 2 0 0 1 2 2v4H6V3a2 2 0 0 1 2-2zm3 6V3a3 3 0 0 0-6 0v4a2 2 0 0 0-2 2v5a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2z"></path>
                </svg>
                <input placeholder="请输入密码" id="password" name="pass" class="inputField" type="password">
            </div>
            <button id="login-button">登录</button>
        </div>
    </div>
</div>
<script>
    class ShaderProgram {
        constructor( holder, options = {} ) {
            options = Object.assign( {
                antialias: false,
                depthTest: false,
                mousemove: false,
                autosize: true,
                side: 'front',
                vertex: `
        precision highp float;
        attribute vec4 a_position;
        attribute vec4 a_color;
        uniform float u_time;
        uniform vec2 u_resolution;
        uniform vec2 u_mousemove;
        uniform mat4 u_projection;
        varying vec4 v_color;
        void main() {
          gl_Position = u_projection * a_position;
          gl_PointSize = (10.0 / gl_Position.w) * 100.0;
          v_color = a_color;
        }`,
                fragment: `
        precision highp float;
        uniform sampler2D u_texture;
        uniform int u_hasTexture;
        varying vec4 v_color;
        void main() {
          if ( u_hasTexture == 1 ) {
            gl_FragColor = v_color * texture2D(u_texture, gl_PointCoord);
          } else {
            gl_FragColor = v_color;
          }
        }`,
                uniforms: {},
                buffers: {},
                camera: {},
                texture: null,
                onUpdate: ( () => {} ),
                onResize: ( () => {} ),
            }, options )
            const uniforms = Object.assign( {
                time: { type: 'float', value: 0 },
                hasTexture: { type: 'int', value: 0 },
                resolution: { type: 'vec2', value: [ 0, 0 ] },
                mousemove: { type: 'vec2', value: [ 0, 0 ] },
                projection: { type: 'mat4', value: [ 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 ] },
            }, options.uniforms )
            const buffers = Object.assign( {
                position: { size: 3, data: [] },
                color: { size: 4, data: [] },
            }, options.buffers )
            const camera = Object.assign( {
                fov: 60,
                near: 1,
                far: 10000,
                aspect: 1,
                z: 100,
                perspective: true,
            }, options.camera )
            const canvas = document.createElement( 'canvas' )
            const gl = canvas.getContext( 'webgl', { antialias: options.antialias } )
            if ( ! gl ) return false
            this.count = 0
            this.gl = gl
            this.canvas = canvas
            this.camera = camera
            this.holder = holder
            this.onUpdate = options.onUpdate
            this.onResize = options.onResize
            this.data = {}
            holder.appendChild( canvas )
            this.createProgram( options.vertex, options.fragment )
            this.createBuffers( buffers )
            this.createUniforms( uniforms )
            this.updateBuffers()
            this.updateUniforms()
            this.createTexture( options.texture )
            gl.enable( gl.BLEND )
            gl.enable( gl.CULL_FACE )
            gl.blendFunc( gl.SRC_ALPHA, gl.ONE )
            gl[ options.depthTest ? 'enable' : 'disable' ]( gl.DEPTH_TEST )
            if ( options.autosize )
                window.addEventListener( 'resize', e => this.resize( e ), false )
            if ( options.mousemove )
                window.addEventListener( 'mousemove', e => this.mousemove( e ), false )
            this.resize()
            this.update = this.update.bind( this )
            this.time = { start: performance.now(), old: performance.now() }
            this.update()
        }
        mousemove( e ) {
            let x = e.pageX / this.width * 2 - 1
            let y = e.pageY / this.height * 2 - 1
            this.uniforms.mousemove = [ x, y ]
        }
        resize( e ) {
            const holder = this.holder
            const canvas = this.canvas
            const gl = this.gl
            const width = this.width = holder.offsetWidth
            const height = this.height = holder.offsetHeight
            const aspect = this.aspect = width / height
            const dpi = this.dpi = devicePixelRatio
            canvas.width = width * dpi
            canvas.height = height * dpi
            canvas.style.width = width + 'px'
            canvas.style.height = height + 'px'
            gl.viewport( 0, 0, width * dpi, height * dpi )
            gl.clearColor( 0, 0, 0, 0 )
            this.uniforms.resolution = [ width, height ]
            this.uniforms.projection = this.setProjection( aspect )
            this.onResize( width, height, dpi )
        }
        setProjection( aspect ) {
            const camera = this.camera
            if ( camera.perspective ) {
                camera.aspect = aspect
                const fovRad = camera.fov * ( Math.PI / 180 )
                const f = Math.tan( Math.PI * 0.5 - 0.5 * fovRad )
                const rangeInv = 1.0 / ( camera.near - camera.far )
                const matrix = [
                    f / camera.aspect, 0, 0, 0,
                    0, f, 0, 0,
                    0, 0, (camera.near + camera.far) * rangeInv, -1,
                    0, 0, camera.near * camera.far * rangeInv * 2, 0
                ]
                matrix[ 14 ] += camera.z
                matrix[ 15 ] += camera.z
                return matrix
            } else {
                return [
                    2 / this.width, 0, 0, 0,
                    0, -2 / this.height, 0, 0,
                    0, 0, 1, 0,
                    -1, 1, 0, 1,
                ]
            }
        }
        createShader( type, source ) {
            const gl = this.gl
            const shader = gl.createShader( type )
            gl.shaderSource( shader, source )
            gl.compileShader( shader )
            if ( gl.getShaderParameter (shader, gl.COMPILE_STATUS ) ) {
                return shader
            } else {
                console.log( gl.getShaderInfoLog( shader ) )
                gl.deleteShader( shader )
            }
        }
        createProgram( vertex, fragment ) {
            const gl = this.gl
            const vertexShader = this.createShader( gl.VERTEX_SHADER, vertex )
            const fragmentShader = this.createShader( gl.FRAGMENT_SHADER, fragment )
            const program = gl.createProgram()
            gl.attachShader( program, vertexShader )
            gl.attachShader( program, fragmentShader )
            gl.linkProgram( program )
            if ( gl.getProgramParameter( program, gl.LINK_STATUS ) ) {
                gl.useProgram( program )
                this.program = program
            } else {
                console.log( gl.getProgramInfoLog( program ) )
                gl.deleteProgram( program )
            }
        }
        createUniforms( data ) {
            const gl = this.gl
            const uniforms = this.data.uniforms = data
            const values = this.uniforms = {}
            Object.keys( uniforms ).forEach( name => {
                const uniform = uniforms[ name ]
                uniform.location = gl.getUniformLocation( this.program, 'u_' + name )
                Object.defineProperty( values, name, {
                    set: value => {
                        uniforms[ name ].value = value
                        this.setUniform( name, value )
                    },
                    get: () => uniforms[ name ].value
                } )
            } )
        }
        setUniform( name, value ) {
            const gl = this.gl
            const uniform = this.data.uniforms[ name ]
            uniform.value = value
            switch ( uniform.type ) {
                case 'int': {
                    gl.uniform1i( uniform.location, value )
                    break
                }
                case 'float': {
                    gl.uniform1f( uniform.location, value )
                    break
                }
                case 'vec2': {
                    gl.uniform2f( uniform.location, ...value )
                    break
                }
                case 'vec3': {
                    gl.uniform3f( uniform.location, ...value )
                    break
                }
                case 'vec4': {
                    gl.uniform4f( uniform.location, ...value )
                    break
                }
                case 'mat2': {
                    gl.uniformMatrix2fv( uniform.location, false, value )
                    break
                }
                case 'mat3': {
                    gl.uniformMatrix3fv( uniform.location, false, value )
                    break
                }
                case 'mat4': {
                    gl.uniformMatrix4fv( uniform.location, false, value )
                    break
                }
            }
            // ivec2       : uniform2i,
            // ivec3       : uniform3i,
            // ivec4       : uniform4i,
            // sampler2D   : uniform1i,
            // samplerCube : uniform1i,
            // bool        : uniform1i,
            // bvec2       : uniform2i,
            // bvec3       : uniform3i,
            // bvec4       : uniform4i,
        }
        updateUniforms() {
            const gl = this.gl
            const uniforms = this.data.uniforms
            Object.keys( uniforms ).forEach( name => {
                const uniform = uniforms[ name ]
                this.uniforms[ name ] = uniform.value
            } )
        }
        createBuffers( data ) {
            const gl = this.gl
            const buffers = this.data.buffers = data
            const values = this.buffers = {}
            Object.keys( buffers ).forEach( name => {
                const buffer = buffers[ name ]
                buffer.buffer = this.createBuffer( 'a_' + name, buffer.size )
                Object.defineProperty( values, name, {
                    set: data => {
                        buffers[ name ].data = data
                        this.setBuffer( name, data )
                        if ( name == 'position' )
                            this.count = buffers.position.data.length / 3
                    },
                    get: () => buffers[ name ].data
                } )
            } )
        }
        createBuffer( name, size ) {
            const gl = this.gl
            const program = this.program
            const index = gl.getAttribLocation( program, name )
            const buffer = gl.createBuffer()
            gl.bindBuffer( gl.ARRAY_BUFFER, buffer )
            gl.enableVertexAttribArray( index )
            gl.vertexAttribPointer( index, size, gl.FLOAT, false, 0, 0 )
            return buffer
        }
        setBuffer( name, data ) {
            const gl = this.gl
            const buffers = this.data.buffers
            if ( name == null && ! gl.bindBuffer( gl.ARRAY_BUFFER, null ) ) return
            gl.bindBuffer( gl.ARRAY_BUFFER, buffers[ name ].buffer )
            gl.bufferData( gl.ARRAY_BUFFER, new Float32Array( data ), gl.STATIC_DRAW )
        }
        updateBuffers() {
            const gl = this.gl
            const buffers = this.buffers
            Object.keys( buffers ).forEach( name =>
                buffers[ name ] = buffer.data
            )
            this.setBuffer( null )
        }
        createTexture( src ) {
            const gl = this.gl
            const texture = gl.createTexture()
            gl.bindTexture( gl.TEXTURE_2D, texture )
            gl.texImage2D( gl.TEXTURE_2D, 0, gl.RGBA, 1, 1, 0, gl.RGBA, gl.UNSIGNED_BYTE, new Uint8Array( [ 0, 0, 0, 0 ] ) )
            this.texture = texture
            if ( src ) {
                this.uniforms.hasTexture = 1
                this.loadTexture( src )
            }
        }
        loadTexture( src ) {
            const gl = this.gl
            const texture = this.texture
            const textureImage = new Image()
            textureImage.onload = () => {
                gl.bindTexture( gl.TEXTURE_2D, texture )
                gl.texImage2D( gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, textureImage )
                gl.texParameteri( gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR )
                gl.texParameteri( gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR )
                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE)
                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE)
                // gl.generateMipmap( gl.TEXTURE_2D )
            }
            textureImage.src = src
        }
        update() {
            const gl = this.gl
            const now = performance.now()
            const elapsed = ( now - this.time.start ) / 5000
            const delta = now - this.time.old
            this.time.old = now
            this.uniforms.time = elapsed
            if ( this.count > 0 ) {
                gl.clear( gl.COLORBUFFERBIT )
                gl.drawArrays( gl.POINTS, 0, this.count )
            }
            this.onUpdate( delta )
            requestAnimationFrame( this.update )
        }
    }
    const pointSize = 2.5
    const waves = new ShaderProgram( document.querySelector( '.waves' ), {
        texture: '',
        uniforms: {
            size: { type: 'float', value: pointSize },
            field: { type: 'vec3', value: [ 0, 0, 0 ] },
            speed: { type: 'float', value: 5 },
        },
        vertex: `
    #define M_PI 3.1415926535897932384626433832795
    precision highp float;
    attribute vec4 a_position;
    attribute vec4 a_color;
    uniform float u_time;
    uniform float u_size;
    uniform float u_speed;
    uniform vec3 u_field;
    uniform mat4 u_projection;
    varying vec4 v_color;
    void main() {
      vec3 pos = a_position.xyz;
      pos.y += (
        cos(pos.x / u_field.x * M_PI * 8.0 + u_time * u_speed) +
        sin(pos.z / u_field.z * M_PI * 8.0 + u_time * u_speed)
      ) * u_field.y;
      gl_Position = u_projection * vec4( pos.xyz, a_position.w );
      gl_PointSize = ( u_size / gl_Position.w ) * 100.0;
      v_color = a_color;
    }`,
        fragment: `
    precision highp float;
    uniform sampler2D u_texture;
    varying vec4 v_color;
    void main() {
      gl_FragColor = v_color * texture2D(u_texture, gl_PointCoord);
    }`,
        onResize( w, h, dpi ) {
            const position = [], color = []
            const width = 400 * ( w / h )
            const depth = 400
            const height = 3
            const distance = 5
            for ( let x = 0; x < width; x += distance ) {
                for ( let z = 0; z < depth; z+= distance ) {
                    position.push( - width / 2 + x, -30, -depth / 2 + z )
                    color.push( 0, 1 - ( x / width ) * 1, 0.5 + x / width * 0.5, z / depth )
                }
            }
            this.uniforms.field = [ width, height, depth ]
            this.buffers.position = position
            this.buffers.color = color
            this.uniforms.size = ( h / 400) * pointSize * dpi
        },
    } )
</script>
<script type="text/javascript" src="../static/wms/js/jquery/jquery-3.3.1.min.js"></script>
<script type="text/javascript" src="../static/wms/js/tools/md5.js"></script>
<script type="text/javascript" src="../static/wms/layer/layer.js"></script>
<script type="text/javascript" src="../static/wms/js/common.js"></script>
<script>
    // remember pwd
    $(function () {
        var oldUserName = localStorage.getItem('oldUserName');
        var oldPass = localStorage.getItem('oldPass');
        if(oldUserName){
            $('#username').val(oldUserName);
        }
        if(oldPass){
            $('#password').val(oldPass);
        }
    })
    window.onload = function(){document.getElementById("username").focus();}
    $(document).on('click','#login-button', function () {
        let username = $("#username").val();
        if (username === "") {
            layer.tips('请输入登录账号', '#username', {tips: [4, '#ff0000']});
            return;
        }
        let password = $("#password").val();
        if (password === "") {
            layer.tips('请输入密码', '#password', {tips: [4, '#ff0000']});
            return;
        }
        $.ajax({
            url: baseUrl+"/login.action",
            data: {
                mobile: username,
                password: hex_md5(password)
            },
            method: 'POST',
            success: function (res) {
                if (res.code === 200){
                    localStorage.setItem("token", res.data.token);
                    localStorage.setItem("username", res.data.username);
                    window.location.href = "index.html";
                } else if (res.code === 10001) {
                    layer.tips(res.msg, '#username', {tips: [4, '#ff0000']});
                } else if (res.code === 10002) {
                    layer.tips(res.msg, '#username', {tips: [4, '#ff0000']});
                } else if (res.code === 10003) {
                    layer.tips(res.msg, '#password', {tips: [4, '#ff0000']});
                } else {
                    layer.tips(res.msg, '.login-btn', {tips: [3, '#ff0000']});
                }
            }
        });
    });
    $('body').keydown(function () {
        if (event.keyCode === 13) {
            $(".login-btn").click();
        }
    });
</script>
</body>
</html>
                var oldUserName = localStorage.getItem('oldUserName');
                var oldPass = localStorage.getItem('oldPass');
                if(oldUserName){
                    $('#username').val(oldUserName);
                }
                if(oldPass){
                    $('#password').val(oldPass);
                }
            })
            window.onload = function(){document.getElementById("username").focus();}
            $(document).on('click','#login-button', function () {
                let username = $("#username").val();
                if (username === "") {
                    layer.tips('请输入登录账号', '#username', {tips: [4, '#ff0000']});
                    return;
                }
                let password = $("#password").val();
                if (password === "") {
                    layer.tips('请输入密码', '#password', {tips: [4, '#ff0000']});
                    return;
                }
                $.ajax({
                    url: baseUrl+"/login.action",
                    data: {
                        mobile: username,
                        password: hex_md5(password)
                    },
                    method: 'POST',
                    success: function (res) {
                        if (res.code === 200){
                            localStorage.setItem("token", res.data.token);
                            localStorage.setItem("username", res.data.username);
                            window.location.href = "index.html";
                        } else if (res.code === 10001) {
                            layer.tips(res.msg, '#username', {tips: [4, '#ff0000']});
                        } else if (res.code === 10002) {
                            layer.tips(res.msg, '#username', {tips: [4, '#ff0000']});
                        } else if (res.code === 10003) {
                            layer.tips(res.msg, '#password', {tips: [4, '#ff0000']});
                        } else {
                            layer.tips(res.msg, '.login-btn', {tips: [3, '#ff0000']});
                        }
                    }
                });
            });
            $(document).keydown(function () {
                if (event.keyCode === 13) {
                    $("#login-button").click();
                }
            });
            $("#copyright-img1").on("mouseover", () => {
                $("#copyright-img-large1").show()
            })
            $("#copyright-img1").on("mouseout", () => {
                $("#copyright-img-large1").hide()
            })
        </script>
    </body>
</html>
src/main/webapp/views/login2.html
New file
@@ -0,0 +1,799 @@
<!doctype html>
<html>
<head>
    <meta charset="utf-8">
    <title>中扬 │ login of zoneyung wcs</title>
    <style>
        html,body {
            height:100%;
        }
        body {
            margin:0;
            background:#000;
        }
        canvas {
            display:block;
        }
        .waves {
            position:absolute;
            left:0;
            top:0;
            right:0;
            bottom:0;
        }
        .form_main {
            width: 300px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            background-color: rgba(255, 255, 255, 0.6);
            padding: 50px 30px 50px 30px;
            border-radius: 30px;
            box-shadow: 0px 0px 40px rgba(0, 0, 0, 0.062);
        }
        .heading {
            font-size: 2.5em;
            color: #2e2e2e;
            font-weight: 700;
            margin: 15px 0 0px 0;
        }
        .inputContainer {
            width: 100%;
            position: relative;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .inputIcon {
            position: absolute;
            left: 10px;
        }
        .inputField {
            width: 100%;
            height: 40px;
            background-color: transparent;
            border: none;
            border-bottom: 2px solid rgb(173, 173, 173);
            border-radius: 30px;
            margin: 10px 0;
            color: black;
            font-size: .8em;
            font-weight: 500;
            box-sizing: border-box;
            padding-left: 30px;
        }
        .inputField:focus {
            outline: none;
            border-bottom: 2px solid rgb(199, 114, 255);
        }
        .inputField::placeholder {
            color: rgb(80, 80, 80);
            font-size: 1em;
            font-weight: 500;
        }
        #login-button {
            position: relative;
            width: 100%;
            border: 2px solid #8000ff;
            background-color: #8000ff;
            height: 40px;
            color: white;
            font-size: .8em;
            font-weight: 500;
            letter-spacing: 1px;
            border-radius: 30px;
            margin: 10px;
            cursor: pointer;
            overflow: hidden;
        }
        #login-button::after {
            content: "";
            position: absolute;
            background-color: rgba(255, 255, 255, 0.253);
            height: 100%;
            width: 150px;
            top: 0;
            left: -200px;
            border-bottom-right-radius: 100px;
            border-top-left-radius: 100px;
            filter: blur(10px);
            transition-duration: .5s;
        }
        #login-button:hover::after {
            transform: translateX(600px);
            transition-duration: .5s;
        }
        .signupContainer {
            margin: 0;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 20px;
        }
        .signupContainer p {
            font-size: .9em;
            font-weight: 500;
            color: black;
        }
        .signupContainer a {
            font-size: .7em;
            font-weight: 500;
            background-color: #2e2e2e;
            color: white;
            text-decoration: none;
            padding: 8px 15px;
            border-radius: 20px;
        }
    </style>
</head>
<body>
<div class="waves">
    <div style="position: absolute;left: calc(50% - 200px);top: 25%;">
        <div class="form_main">
            <p style="text-align: center;"><img src="../static/wcs/images/logo.png" alt="" style="width: 80%"></p>
            <p style="margin-top: -15px;"><span class="login100-form-title p-t-20 p-b-45" style="color: #868686;font-size: 24px">WCS</span></p>
            <div class="inputContainer">
                <svg viewBox="0 0 16 16" fill="#2e2e2e" height="16" width="16" xmlns="http://www.w3.org/2000/svg" class="inputIcon">
                    <path d="M13.106 7.222c0-2.967-2.249-5.032-5.482-5.032-3.35 0-5.646 2.318-5.646 5.702 0 3.493 2.235 5.708 5.762 5.708.862 0 1.689-.123 2.304-.335v-.862c-.43.199-1.354.328-2.29.328-2.926 0-4.813-1.88-4.813-4.798 0-2.844 1.921-4.881 4.594-4.881 2.735 0 4.608 1.688 4.608 4.156 0 1.682-.554 2.769-1.416 2.769-.492 0-.772-.28-.772-.76V5.206H8.923v.834h-.11c-.266-.595-.881-.964-1.6-.964-1.4 0-2.378 1.162-2.378 2.823 0 1.737.957 2.906 2.379 2.906.8 0 1.415-.39 1.709-1.087h.11c.081.67.703 1.148 1.503 1.148 1.572 0 2.57-1.415 2.57-3.643zm-7.177.704c0-1.197.54-1.907 1.456-1.907.93 0 1.524.738 1.524 1.907S8.308 9.84 7.371 9.84c-.895 0-1.442-.725-1.442-1.914z"></path>
                </svg>
                <input placeholder="请输入用户名" id="username" name="username" class="inputField" type="text">
            </div>
            <div class="inputContainer">
                <svg viewBox="0 0 16 16" fill="#2e2e2e" height="16" width="16" xmlns="http://www.w3.org/2000/svg" class="inputIcon">
                    <path d="M8 1a2 2 0 0 1 2 2v4H6V3a2 2 0 0 1 2-2zm3 6V3a3 3 0 0 0-6 0v4a2 2 0 0 0-2 2v5a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2z"></path>
                </svg>
                <input placeholder="请输入密码" id="password" name="pass" class="inputField" type="password">
            </div>
            <button id="login-button">登录</button>
        </div>
    </div>
</div>
<script>
    class ShaderProgram {
        constructor( holder, options = {} ) {
            options = Object.assign( {
                antialias: false,
                depthTest: false,
                mousemove: false,
                autosize: true,
                side: 'front',
                vertex: `
        precision highp float;
        attribute vec4 a_position;
        attribute vec4 a_color;
        uniform float u_time;
        uniform vec2 u_resolution;
        uniform vec2 u_mousemove;
        uniform mat4 u_projection;
        varying vec4 v_color;
        void main() {
          gl_Position = u_projection * a_position;
          gl_PointSize = (10.0 / gl_Position.w) * 100.0;
          v_color = a_color;
        }`,
                fragment: `
        precision highp float;
        uniform sampler2D u_texture;
        uniform int u_hasTexture;
        varying vec4 v_color;
        void main() {
          if ( u_hasTexture == 1 ) {
            gl_FragColor = v_color * texture2D(u_texture, gl_PointCoord);
          } else {
            gl_FragColor = v_color;
          }
        }`,
                uniforms: {},
                buffers: {},
                camera: {},
                texture: null,
                onUpdate: ( () => {} ),
                onResize: ( () => {} ),
            }, options )
            const uniforms = Object.assign( {
                time: { type: 'float', value: 0 },
                hasTexture: { type: 'int', value: 0 },
                resolution: { type: 'vec2', value: [ 0, 0 ] },
                mousemove: { type: 'vec2', value: [ 0, 0 ] },
                projection: { type: 'mat4', value: [ 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 ] },
            }, options.uniforms )
            const buffers = Object.assign( {
                position: { size: 3, data: [] },
                color: { size: 4, data: [] },
            }, options.buffers )
            const camera = Object.assign( {
                fov: 60,
                near: 1,
                far: 10000,
                aspect: 1,
                z: 100,
                perspective: true,
            }, options.camera )
            const canvas = document.createElement( 'canvas' )
            const gl = canvas.getContext( 'webgl', { antialias: options.antialias } )
            if ( ! gl ) return false
            this.count = 0
            this.gl = gl
            this.canvas = canvas
            this.camera = camera
            this.holder = holder
            this.onUpdate = options.onUpdate
            this.onResize = options.onResize
            this.data = {}
            holder.appendChild( canvas )
            this.createProgram( options.vertex, options.fragment )
            this.createBuffers( buffers )
            this.createUniforms( uniforms )
            this.updateBuffers()
            this.updateUniforms()
            this.createTexture( options.texture )
            gl.enable( gl.BLEND )
            gl.enable( gl.CULL_FACE )
            gl.blendFunc( gl.SRC_ALPHA, gl.ONE )
            gl[ options.depthTest ? 'enable' : 'disable' ]( gl.DEPTH_TEST )
            if ( options.autosize )
                window.addEventListener( 'resize', e => this.resize( e ), false )
            if ( options.mousemove )
                window.addEventListener( 'mousemove', e => this.mousemove( e ), false )
            this.resize()
            this.update = this.update.bind( this )
            this.time = { start: performance.now(), old: performance.now() }
            this.update()
        }
        mousemove( e ) {
            let x = e.pageX / this.width * 2 - 1
            let y = e.pageY / this.height * 2 - 1
            this.uniforms.mousemove = [ x, y ]
        }
        resize( e ) {
            const holder = this.holder
            const canvas = this.canvas
            const gl = this.gl
            const width = this.width = holder.offsetWidth
            const height = this.height = holder.offsetHeight
            const aspect = this.aspect = width / height
            const dpi = this.dpi = devicePixelRatio
            canvas.width = width * dpi
            canvas.height = height * dpi
            canvas.style.width = width + 'px'
            canvas.style.height = height + 'px'
            gl.viewport( 0, 0, width * dpi, height * dpi )
            gl.clearColor( 0, 0, 0, 0 )
            this.uniforms.resolution = [ width, height ]
            this.uniforms.projection = this.setProjection( aspect )
            this.onResize( width, height, dpi )
        }
        setProjection( aspect ) {
            const camera = this.camera
            if ( camera.perspective ) {
                camera.aspect = aspect
                const fovRad = camera.fov * ( Math.PI / 180 )
                const f = Math.tan( Math.PI * 0.5 - 0.5 * fovRad )
                const rangeInv = 1.0 / ( camera.near - camera.far )
                const matrix = [
                    f / camera.aspect, 0, 0, 0,
                    0, f, 0, 0,
                    0, 0, (camera.near + camera.far) * rangeInv, -1,
                    0, 0, camera.near * camera.far * rangeInv * 2, 0
                ]
                matrix[ 14 ] += camera.z
                matrix[ 15 ] += camera.z
                return matrix
            } else {
                return [
                    2 / this.width, 0, 0, 0,
                    0, -2 / this.height, 0, 0,
                    0, 0, 1, 0,
                    -1, 1, 0, 1,
                ]
            }
        }
        createShader( type, source ) {
            const gl = this.gl
            const shader = gl.createShader( type )
            gl.shaderSource( shader, source )
            gl.compileShader( shader )
            if ( gl.getShaderParameter (shader, gl.COMPILE_STATUS ) ) {
                return shader
            } else {
                console.log( gl.getShaderInfoLog( shader ) )
                gl.deleteShader( shader )
            }
        }
        createProgram( vertex, fragment ) {
            const gl = this.gl
            const vertexShader = this.createShader( gl.VERTEX_SHADER, vertex )
            const fragmentShader = this.createShader( gl.FRAGMENT_SHADER, fragment )
            const program = gl.createProgram()
            gl.attachShader( program, vertexShader )
            gl.attachShader( program, fragmentShader )
            gl.linkProgram( program )
            if ( gl.getProgramParameter( program, gl.LINK_STATUS ) ) {
                gl.useProgram( program )
                this.program = program
            } else {
                console.log( gl.getProgramInfoLog( program ) )
                gl.deleteProgram( program )
            }
        }
        createUniforms( data ) {
            const gl = this.gl
            const uniforms = this.data.uniforms = data
            const values = this.uniforms = {}
            Object.keys( uniforms ).forEach( name => {
                const uniform = uniforms[ name ]
                uniform.location = gl.getUniformLocation( this.program, 'u_' + name )
                Object.defineProperty( values, name, {
                    set: value => {
                        uniforms[ name ].value = value
                        this.setUniform( name, value )
                    },
                    get: () => uniforms[ name ].value
                } )
            } )
        }
        setUniform( name, value ) {
            const gl = this.gl
            const uniform = this.data.uniforms[ name ]
            uniform.value = value
            switch ( uniform.type ) {
                case 'int': {
                    gl.uniform1i( uniform.location, value )
                    break
                }
                case 'float': {
                    gl.uniform1f( uniform.location, value )
                    break
                }
                case 'vec2': {
                    gl.uniform2f( uniform.location, ...value )
                    break
                }
                case 'vec3': {
                    gl.uniform3f( uniform.location, ...value )
                    break
                }
                case 'vec4': {
                    gl.uniform4f( uniform.location, ...value )
                    break
                }
                case 'mat2': {
                    gl.uniformMatrix2fv( uniform.location, false, value )
                    break
                }
                case 'mat3': {
                    gl.uniformMatrix3fv( uniform.location, false, value )
                    break
                }
                case 'mat4': {
                    gl.uniformMatrix4fv( uniform.location, false, value )
                    break
                }
            }
            // ivec2       : uniform2i,
            // ivec3       : uniform3i,
            // ivec4       : uniform4i,
            // sampler2D   : uniform1i,
            // samplerCube : uniform1i,
            // bool        : uniform1i,
            // bvec2       : uniform2i,
            // bvec3       : uniform3i,
            // bvec4       : uniform4i,
        }
        updateUniforms() {
            const gl = this.gl
            const uniforms = this.data.uniforms
            Object.keys( uniforms ).forEach( name => {
                const uniform = uniforms[ name ]
                this.uniforms[ name ] = uniform.value
            } )
        }
        createBuffers( data ) {
            const gl = this.gl
            const buffers = this.data.buffers = data
            const values = this.buffers = {}
            Object.keys( buffers ).forEach( name => {
                const buffer = buffers[ name ]
                buffer.buffer = this.createBuffer( 'a_' + name, buffer.size )
                Object.defineProperty( values, name, {
                    set: data => {
                        buffers[ name ].data = data
                        this.setBuffer( name, data )
                        if ( name == 'position' )
                            this.count = buffers.position.data.length / 3
                    },
                    get: () => buffers[ name ].data
                } )
            } )
        }
        createBuffer( name, size ) {
            const gl = this.gl
            const program = this.program
            const index = gl.getAttribLocation( program, name )
            const buffer = gl.createBuffer()
            gl.bindBuffer( gl.ARRAY_BUFFER, buffer )
            gl.enableVertexAttribArray( index )
            gl.vertexAttribPointer( index, size, gl.FLOAT, false, 0, 0 )
            return buffer
        }
        setBuffer( name, data ) {
            const gl = this.gl
            const buffers = this.data.buffers
            if ( name == null && ! gl.bindBuffer( gl.ARRAY_BUFFER, null ) ) return
            gl.bindBuffer( gl.ARRAY_BUFFER, buffers[ name ].buffer )
            gl.bufferData( gl.ARRAY_BUFFER, new Float32Array( data ), gl.STATIC_DRAW )
        }
        updateBuffers() {
            const gl = this.gl
            const buffers = this.buffers
            Object.keys( buffers ).forEach( name =>
                buffers[ name ] = buffer.data
            )
            this.setBuffer( null )
        }
        createTexture( src ) {
            const gl = this.gl
            const texture = gl.createTexture()
            gl.bindTexture( gl.TEXTURE_2D, texture )
            gl.texImage2D( gl.TEXTURE_2D, 0, gl.RGBA, 1, 1, 0, gl.RGBA, gl.UNSIGNED_BYTE, new Uint8Array( [ 0, 0, 0, 0 ] ) )
            this.texture = texture
            if ( src ) {
                this.uniforms.hasTexture = 1
                this.loadTexture( src )
            }
        }
        loadTexture( src ) {
            const gl = this.gl
            const texture = this.texture
            const textureImage = new Image()
            textureImage.onload = () => {
                gl.bindTexture( gl.TEXTURE_2D, texture )
                gl.texImage2D( gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, textureImage )
                gl.texParameteri( gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR )
                gl.texParameteri( gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR )
                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE)
                gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE)
                // gl.generateMipmap( gl.TEXTURE_2D )
            }
            textureImage.src = src
        }
        update() {
            const gl = this.gl
            const now = performance.now()
            const elapsed = ( now - this.time.start ) / 5000
            const delta = now - this.time.old
            this.time.old = now
            this.uniforms.time = elapsed
            if ( this.count > 0 ) {
                gl.clear( gl.COLORBUFFERBIT )
                gl.drawArrays( gl.POINTS, 0, this.count )
            }
            this.onUpdate( delta )
            requestAnimationFrame( this.update )
        }
    }
    const pointSize = 2.5
    const waves = new ShaderProgram( document.querySelector( '.waves' ), {
        texture: '',
        uniforms: {
            size: { type: 'float', value: pointSize },
            field: { type: 'vec3', value: [ 0, 0, 0 ] },
            speed: { type: 'float', value: 5 },
        },
        vertex: `
    #define M_PI 3.1415926535897932384626433832795
    precision highp float;
    attribute vec4 a_position;
    attribute vec4 a_color;
    uniform float u_time;
    uniform float u_size;
    uniform float u_speed;
    uniform vec3 u_field;
    uniform mat4 u_projection;
    varying vec4 v_color;
    void main() {
      vec3 pos = a_position.xyz;
      pos.y += (
        cos(pos.x / u_field.x * M_PI * 8.0 + u_time * u_speed) +
        sin(pos.z / u_field.z * M_PI * 8.0 + u_time * u_speed)
      ) * u_field.y;
      gl_Position = u_projection * vec4( pos.xyz, a_position.w );
      gl_PointSize = ( u_size / gl_Position.w ) * 100.0;
      v_color = a_color;
    }`,
        fragment: `
    precision highp float;
    uniform sampler2D u_texture;
    varying vec4 v_color;
    void main() {
      gl_FragColor = v_color * texture2D(u_texture, gl_PointCoord);
    }`,
        onResize( w, h, dpi ) {
            const position = [], color = []
            const width = 400 * ( w / h )
            const depth = 400
            const height = 3
            const distance = 5
            for ( let x = 0; x < width; x += distance ) {
                for ( let z = 0; z < depth; z+= distance ) {
                    position.push( - width / 2 + x, -30, -depth / 2 + z )
                    color.push( 0, 1 - ( x / width ) * 1, 0.5 + x / width * 0.5, z / depth )
                }
            }
            this.uniforms.field = [ width, height, depth ]
            this.buffers.position = position
            this.buffers.color = color
            this.uniforms.size = ( h / 400) * pointSize * dpi
        },
    } )
</script>
<script type="text/javascript" src="../static/wms/js/jquery/jquery-3.3.1.min.js"></script>
<script type="text/javascript" src="../static/wms/js/tools/md5.js"></script>
<script type="text/javascript" src="../static/wms/layer/layer.js"></script>
<script type="text/javascript" src="../static/wms/js/common.js"></script>
<script>
    // remember pwd
    $(function () {
        var oldUserName = localStorage.getItem('oldUserName');
        var oldPass = localStorage.getItem('oldPass');
        if(oldUserName){
            $('#username').val(oldUserName);
        }
        if(oldPass){
            $('#password').val(oldPass);
        }
    })
    window.onload = function(){document.getElementById("username").focus();}
    $(document).on('click','#login-button', function () {
        let username = $("#username").val();
        if (username === "") {
            layer.tips('请输入登录账号', '#username', {tips: [4, '#ff0000']});
            return;
        }
        let password = $("#password").val();
        if (password === "") {
            layer.tips('请输入密码', '#password', {tips: [4, '#ff0000']});
            return;
        }
        $.ajax({
            url: baseUrl+"/login.action",
            data: {
                mobile: username,
                password: hex_md5(password)
            },
            method: 'POST',
            success: function (res) {
                if (res.code === 200){
                    localStorage.setItem("token", res.data.token);
                    localStorage.setItem("username", res.data.username);
                    window.location.href = "index.html";
                } else if (res.code === 10001) {
                    layer.tips(res.msg, '#username', {tips: [4, '#ff0000']});
                } else if (res.code === 10002) {
                    layer.tips(res.msg, '#username', {tips: [4, '#ff0000']});
                } else if (res.code === 10003) {
                    layer.tips(res.msg, '#password', {tips: [4, '#ff0000']});
                } else {
                    layer.tips(res.msg, '.login-btn', {tips: [3, '#ff0000']});
                }
            }
        });
    });
    $('body').keydown(function () {
        if (event.keyCode === 13) {
            $(".login-btn").click();
        }
    });
</script>
</body>
</html>