ymAnslysis.vue 7.3 KB
// 淹没分析弹窗
<template>
    <div class="container">
        <div class="wrapper">
            <div class="box">
            </div>
        </div>
        <div class="mian">
            <div class="title-bt">
                <span>淹没分析</span>
                <span @click="closePop" class="close">×</span>
            </div>
            <div class="func-input">
                <span>分析区域</span>
                <div class="btn-wrapper2" :class="[isXmbj?'add-bg2': '']" @click="handleIsXmbj(true)">
                    <span class="center">项目边界</span>
                </div>
                <div class="btn-wrapper2" :class="[!isXmbj?'add-bg2': '']" @click="handleIsXmbj(false)">
                    <span class="center">绘制</span>
                </div>
            </div>
            <div class="func-input">
                <span>水底高程</span>
                <el-input-number v-model="sdgc" controls-position="right"
                    style="width:245px; height:38px; margin-left: 12px;" :step='step' :min="0" :max="100000">
                </el-input-number>
                <span style="margin-left: 12px;"></span>
            </div>
            <div class="func-input">
                <span>水位深度</span>
                <el-input-number v-model="swsd" controls-position="right"
                    style="width:245px; height:38px; margin-left: 12px;" :step='step' :min="0" :max="100000">
                </el-input-number>
                <span style="margin-left: 12px;"></span>
            </div>
            <div class="func-input">
                <span>淹没速度</span>
                <el-input-number v-model="ymsd" controls-position="right"
                    style="width:245px; height:38px; margin-left: 12px;" :step='step' :min="0" :max="100000">
                </el-input-number>
                <span style="margin-left: 12px;"></span>
            </div>
            <div class="func-input">
                <span>当前水位</span>
                <span style="margin-left: 36px;">1263.7米</span>
            </div>
            <div class="func-btn">
                <div class="btn-wrapper add-bg" @click="startAnalysis">
                    <img style="width: 20px; height: 20px; margin: 0 5px 0 44px" src="../assets/icon_开始分析.png" alt="">
                    <span>开始分析</span>
                </div>
                <div class="btn-wrapper" @click="stopAnalysis" style="margin-left: 30px;">
                    <img style="width: 20px; height: 20px;margin: 0 5px 0 26px" src="../assets/icon_暂停分析.png" alt="">
                    <span>暂停分析</span>
                </div>
            </div>
        </div>
    </div>
</template>

<script>
    import flood from "../assets/js/map/flood";
    import objectManage from '../assets/js/map/maputils';
    export default {
        name: 'allSee',
        components: {},
        data() {
            return {
                step: 0.01,
                num: 1,
                sdgc: '', // 水底高程
                swsd: 50, // 水位深度
                ymsd: '', // 淹没速度
                isXmbj: true,
                // isAnalysis: true
            }
        },
        mounted() {
            this.flood instanceof flood || (this.flood = new flood());
        },
        methods: {
            closePop() {
                this.$emit('closePop', 'ymAnslysis')
            },
            handleChange() {

            },
            startAnalysis() {
                this.flood.floodParse(0, this.swsd);
			    this.flood.handlerPolygon.clear();
            },
            stopAnalysis() {
                this.flood.remove();
            },
            handleIsXmbj(flag) {
                this.isXmbj = flag;
                this.flood.handlerPolygon.deactivate();
			    !flag && this.flood.handlerPolygon.activate();
            }
        }
    }
</script>

<style scoped>
    .container {
        position: relative;
        color: #fff;
        font-size: 16px;
        width: 450px;
    }

    .wrapper {
        position: absolute;
        width: 100%;
        height: 100%;
        z-index: 1;
        border: 1px solid rgba(151, 151, 151, 0.58);
    }

    .box {
        background: rgba(4, 10, 10, 0.58);
        box-shadow: 0px 4px 9px 0px rgba(0, 0, 0, 0.5);
        /* filter: blur(10px); */
        height: 100px;
        position: absolute;
        width: 100%;
        height: 100%;
        z-index: 1;
    }

    .mian {
        position: relative;
        width: 100%;
        height: 100%;
        z-index: 1000;
    }

    .list-box span:nth-of-type(1) {
        display: inline-block;
        width: 98px;
        margin-right: 20px;
        color: rgba(255, 255, 255, .7);
    }

    .list-box span:nth-of-type(2) {
        margin-top: 14px;
        display: inline-block;
    }


    .title-bt {
        display: flex;
        justify-content: space-between;
        border-bottom: 1px solid rgba(255, 255, 255, 0.15);
        padding: 18px 24px;
        font-size: 20px;
    }


    .func-input {
        display: flex;
        align-items: center;
        /* justify-content: space-between; */
        padding: 18px 24px 0px 24px;
        font-size: 18px;
        cursor: pointer;
    }

    .func {
        padding: 18px 24px;
    }



    .func-btn {
        display: flex;
        padding: 18px 24px 37px 24px;
        align-items: center;
        font-size: 18px;
        cursor: pointer;
    }

    .btn-wrapper {
        display: flex;
        align-items: center;
        width: 190px;
        height: 36px;
        background-image: url('../assets/弹窗按钮背景-默认.png');
        background-size: 100% 100%;
        background-repeat: no-repeat;
        line-height: 36px;
    }

    .add-bg {
        background-image: url('../assets/弹窗按钮背景-选中.png');
    }


    .btn-wrapper2 {
        display: flex;
        align-items: center;
        width: 116px;
        height: 38px;
        background-image: url('../assets/一张图/bg_专题分析.png');
        background-size: 100% 100%;
        background-repeat: no-repeat;
        text-align: center;
        line-height: 38px;
        margin-left: 13px;
    }

    .add-bg2 {
        background-image: url('../assets/一张图/bg_资源目录.png');
    }

    .close {
        cursor: pointer;
    }

    .center {
        display: inline-block;
        width: 100%;
        height: 100%;
        text-align: center;
    }

    >>>input::-webkit-input-placeholder {
        font-size: 16px;
        color: rgba(255, 255, 255, 0.78) !important;
    }

    >>>.el-input__inner {
        background: rgba(4, 10, 10, 0.58) !important;
        border: 1px solid rgba(23, 34, 38, 0.57);
        color: #fff;
    }
    >>>.el-input__inner {
        text-align: left !important;
    }

    >>>.el-input__suffix {
        color: #fff;
        font-size: 17px;
    }

    >>>.el-input-number__increase,
    >>>.el-input-number__decrease {
        background: rgba(4, 10, 10, 0.58);
    }

    >>>.el-input-number.is-controls-right .el-input-number__decrease,
    >>>.el-input-number__increase {
        border-left: 1px solid rgba(4, 10, 10, 0.58);
    }

    >>>.el-icon-arrow-up:before,
    >>>.el-icon-arrow-down:before {
        color: #fff;
    }

    >>>.el-input-number.is-controls-right .el-input-number__increase {
        border-bottom: 1px solid rgba(4, 10, 10, 0.58);
    }
</style>