派生自 wuyushui/SewerAndRainNetwork

chenyabin
2021-04-02 b6c363cdc1ea55dbfc1dfdb6a7c27c8fc51fa0e2
src/components/LayerController/modules/LcServiceLayer.vue
@@ -1,21 +1,25 @@
<template>
    <div class="inner-panel">
        <div class="title">
            图层控制
        </div>
        <div class="wms-panel">
            <div v-for="item in serviceLayers" :key="item.code" class="layerbox">
                <div><input type="checkbox" :name="'wmsLayer_'+item.code" :checked="item.checked" :value="item.code"
                            @change="swAllLayers(item)"/>{{ item.name }} <span @click="swFilter(item)"
                                                                               class="btn-filter">过滤</span>
                </div>
                <div class="layerbox-item">
                    <div class="basemap-layer-item" v-for="itm in item.layers" :key="itm.code"><input type="checkbox"
                                                                                                      :name="'wmsSublayers_'+item.code+'_'+itm.code"
                                                                                                      :checked="itm.checked"
                                                                                                      :value="itm.code"
                                                                                                      @change="swWmsLayer(item.url,itm)"/>{{
                        itm.name }}
            <el-scrollbar class="wms-panel-scrollbar">
                <div v-for="item in serviceLayers" :key="item.code" class="layerbox">
                    <div>
                        <input type="checkbox" :name="'wmsLayer_'+item.code" :checked="item.checked" :value="item.code"  @change="swAllLayers(item)"/>{{ item.name }}
                    </div>
                    <div class="layerbox-item">
                        <div class="basemap-layer-item" v-for="itm in item.layers" :key="itm.code">
                            <input type="checkbox"
                                   :name="'wmsSublayers_'+item.code+'_'+itm.code"
                                   :checked="itm.checked"
                                   :value="itm.code"
                                   @change="swWmsLayer(itm)"/>{{ itm.name }}
                        </div>
                    </div>
                </div>
            </div>
            </el-scrollbar>
        </div>
        <lc-service-layer-filter v-if="layerFilterVisible" ref="serviceLayerFilter"></lc-service-layer-filter>
    </div>
@@ -61,12 +65,12 @@
        console.log(res)
      })
    },
    swWmsLayer (url, itm) {
    swWmsLayer (itm) {
      itm.checked = !itm.checked
      if (itm.checked) {
        window.serviceLayerHelper.loadGeojsonLayer(url, itm)
        window.layerFactory.show(itm)
      } else {
        window.serviceLayerHelper.removeLayer(itm)
        window.layerFactory.hide(itm)
      }
      // this.updateWms()
    },
@@ -96,25 +100,25 @@
<style scoped lang="less">
    .inner-panel {
        display: flex;
        justify-content: center;
        align-items: center;
        .title{
            color: #ffffff;
            font-size: 16px;
            font-weight: 600;
            margin: 10px;
            text-align: center;
        }
        .btn-filter {
            cursor: pointer;
            color: #ffffff;
        }
        .wms-panel {
            width: 250px;
            display: flex;
            flex-flow: column;
            width:  1.79167rem;
            .wms-panel-scrollbar{
                height: 50vh;
                width: 100%;
            }
            .layerbox {
                width: 100%;
                display: flex;
                flex-flow: column;
                .layerbox-item {
                    display: flex;
                    flex-flow: row wrap;