arcgis api 4.x for js之圖層管理篇

上篇實(shí)現(xiàn)了基礎(chǔ)地圖加載以及二三維模式切換;本篇的內(nèi)容則是圖層管理控制,從兩個(gè)不同角度來(lái)實(shí)現(xiàn),分別是直接綁定arcgis api提供的圖層管理widget(LayerList)以及自定義圖層管理圖標(biāo)的點(diǎn)擊事件來(lái)控制圖層的隱藏或者顯示。不管是LayerList或者自定義圖標(biāo)點(diǎn)擊管理圖層的實(shí)現(xiàn)方式,核心都是根據(jù)Layer的屬性visible來(lái)設(shè)置true或者false來(lái)控制的。

一、談?wù)劚酒约赫J(rèn)為比較重要的幾個(gè)專業(yè)術(shù)語(yǔ)名稱的理解:

1.TileLayer

TileLayer,加載緩存地圖服務(wù)的瓦片圖層,緩存的服務(wù)訪問(wèn)緩存中的瓦片,而不是動(dòng)態(tài)地繪制圖像。由于緩存機(jī)制,所以渲染的速度比MapImageLayers快多了,適合疊加瓦片切圖使用,而不是前端動(dòng)態(tài)渲染的。

2.MapImageLayer

MapImageLayer,允許顯示和分析在一個(gè)地圖服務(wù)定義層數(shù)據(jù),輸出圖像代替特征。地圖服務(wù)圖像是根據(jù)請(qǐng)求動(dòng)態(tài)生成的。

3. ElevationLayer

ElevationLayer,即為加載地形高程的圖層,應(yīng)用在三維模式下顯示。

4. SceneLayer

SceneLayer,即為加載三維場(chǎng)景圖層,應(yīng)用在三維模式下顯示。

5. LayerList

LayerList,圖層列表控制控件,提供了一種方法來(lái)顯示一個(gè)列表的層以及提供控制圖層隱藏或者顯示。

二、LayerList具體實(shí)現(xiàn)思路:

1.上面描述的幾個(gè)類型圖層有個(gè)屬性listMode,默認(rèn)show,即是這些圖層疊加在地圖上,默認(rèn)是在LayerList里面了的,要是LayerList創(chuàng)建的話

image

2.配置圖層信息:

/*圖層配置*/
MapConfig.feconomic_sublayers =  [
    {id: 35,title:"行政區(qū)劃",visible:false,sublayers:[    {id: 38,title:"城市界線",visible: false},{id: 37,title:"省界",visible: true}]},
    {id: 28,title:"海洋規(guī)劃",visible:true,sublayers:[    {id:34,title:"海岸基本功能區(qū) ",visible: true},{id: 33,title:"經(jīng)濟(jì)合作圈",visible: true},{id: 32,title:"經(jīng)濟(jì)發(fā)展區(qū)",visible: true},{id: 31,title:"經(jīng)濟(jì)灣區(qū)",visible:true},{id: 30,title:"經(jīng)濟(jì)島群",visible: true}]},
    {id: 27,title:"海域權(quán)屬",visible:false},
    {id: 24,title:"岸線資源",visible:false,sublayers:[    {id: 26,title:"海岸帶",visible: true},{id: 25,title:"岸線",visible: true}]},    
    {id: 14,title:"海洋生態(tài)保護(hù) ",visible:false,sublayers:[
                                                     {id:23,title:"海洋功能區(qū)劃 ",visible: true},
                                                     {id:22,title:"限制開(kāi)發(fā)區(qū) ",visible: true},
                                                     {id:21,title:"禁止開(kāi)發(fā)區(qū) ",visible: true},
                                                     {id:18,title:"海洋自然保護(hù)區(qū) ",visible: true,sublayers:[{id:20,title:"海洋自然保護(hù)區(qū) ",visible: true},{id:19,title:"海洋自然保護(hù)區(qū)點(diǎn)  ",visible: true}]},
                                                     {id:15,title:"海洋特別保護(hù)區(qū)  ",visible: true,sublayers:[{id:17,title:"海洋特別保護(hù)區(qū) ",visible: true},{id:16,title:"海洋特別保護(hù)區(qū)點(diǎn)  ",visible: true}]}
                                                     ]},
    {id: 9,title:"漁業(yè)資源 ",visible:false,sublayers:[
                                                 //{id:13,title:"漁業(yè)資源",visible: false},
                                                 {id:12,title:"漁場(chǎng)",visible: true},
                                                 {id:11,title:"漁區(qū)",visible: true},
                                                 {id:10,title:"漁港",visible: true}
                                                 ]},
    {id: 8,title:"地質(zhì)鉆孔",visible: false},
    {id: 7,title:"觀測(cè)站",visible: false},
    {id: 6,title:"海島",visible: false},
    {id: 2,title:"海洋資源 ",visible:false,sublayers:[
                                                  {id:5,title:"其他資源",visible: true},
                                                  {id:4,title:"石油資源",visible: true},
                                                  {id:3,title:"礦產(chǎn)資源",visible: true}
                                                  ]},
    //{id: 1,title:"海洋企業(yè)",visible:false},
    {id: 0,title:"視頻監(jiān)控",visible:false}
];

3.圖層創(chuàng)建:

var waterdepthLayer  = new TileLayer({
                         url: MapConfig.waterdepthLayerUrl,
                         title:"水深柵格圖",
                         opacity:0.45,
                         visible:false,
                         id:  "BaseMapWater"
                       });
                    var waterLayer  = new MapImageLayer({
                         url: MapConfig.waterLayerUrl,
                         title:"葉綠素",
                         opacity:0.45,
                         visible:false,
                         id:  "BaseMapWater"
                       });
                     var feconomicLayer = new MapImageLayer({
                         url: MapConfig.FEconomiclayerUrl,
                         title:"專題圖層",
                         visible:true,
                         sublayers: MapConfig.feconomic_sublayers
                         });
                     var elevationLayer  = new ElevationLayer({
                           url: MapConfig.elevationLayer.Url
                         });
                     var map = BX.MapVars.map = new Map({
                       basemap: imgBasemap,
                       layers:[waterdepthLayer,hdyxLayer,waterLayer,feconomicLayer],
                       ground: new Ground({layers:[elevationLayer,hddxLayer]})
                     });

4.LayerList創(chuàng)建:

//圖層控制器
         mapPage.loadSwitcherLayers(appConfig.mapView,appConfig.sceneView);
        /**
         * 圖層控制器
         */
        loadSwitcherLayers:function(mapView,sceneView){
            require([
                     "esri/widgets/LayerList"
                   ], function(LayerList) {
                mapView.then(function() {//二維模式
                      var layerList = new LayerList({
                        view: mapView,                                                                                                                     
                      });
                      mapView.ui.add(layerList, "bottom-right");
                 });
                sceneView.then(function() {//三維模式
                      var layerList = new LayerList({
                        view: sceneView
                      });
                      sceneView.ui.add(layerList, "bottom-right");
                 });                
            });            
        },

5.效果圖如下:

image

三、自定義圖標(biāo)點(diǎn)擊事件管理圖層具體實(shí)現(xiàn)思路:

1.頁(yè)面設(shè)計(jì):

<div id="tuceng_center">
        <ul>
            <li id="dynamic_0">
                <div class="tucicon tucicon1"></div>
                <p>視頻監(jiān)控</p>
            </li>
            <li id="dynamic_2">
                <div class="tucicon tucicon2"></div>
                <p>海洋資源</p>
            </li>
            <li id="dynamic_6">
                <div class="tucicon tucicon3"></div>
                <p>海島</p>
            </li>
            <li id="dynamic_7">
                <div class="tucicon tucicon4"></div>
                <p>觀測(cè)站</p>
            </li>
            <li id="dynamic_8">
                <div class="tucicon tucicon5"></div>
                <p>地質(zhì)鉆孔</p>
            </li>
            <li id="dynamic_9">
                <div class="tucicon tucicon6"></div>
                <p>漁業(yè)資源</p>
            </li>
            <li id="dynamic_14">
                <div class="tucicon tucicon7"></div>
                <p>海洋生態(tài)保護(hù)</p>
            </li>
            <li id="dynamic_24">
                <div class="tucicon tucicon8"></div>
                <p>岸線資源</p>
            </li>
            <li id="dynamic_27">
                <div class="tucicon tucicon9"></div>
                <p>海域權(quán)屬</p>
            </li>
            <li id="dynamic_28" class="selected">
                <div class="tucicon tucicon10"></div>
                <p>海洋規(guī)劃</p>
            </li>
            <li id="dynamic_35">
                <div class="tucicon tucicon11"></div>
                <p>行政區(qū)劃</p>
            </li>
            <li id="tile_0">
                <div class="tucicon tucicon12"></div>
                <p>3D場(chǎng)景</p>
            </li>
            <li id="tile_2">
                <div class="tucicon tucicon14"></div>
                <p>3D航道</p>
            </li>
            <li id="tile_1">
                <div class="tucicon tucicon13"></div>
                <p>水深柵格圖</p>
            </li>
        </ul>
    </div>
image
image

2.點(diǎn)擊事件:

//圖層控制點(diǎn)擊事件監(jiān)控
$("#tuceng_center ul li").click(function(){
                        $(this).toggleClass('selected');
                        var flag = false;
                        if($(this).attr("class") == "selected"){
                            flag = true;
                        }else{
                            flag = false;    
                        }
                       var id = $(this).attr("id");
                       if(id.indexOf("dynamic")>-1)//動(dòng)態(tài)圖層控制
                       {
                           id = id.split("_")[1];
                           if(feconomicLayer)
                              feconomicLayer.findSublayerById(Number(id)).visible = flag;
                           
                       }else{//瓦片底圖控制
                           id = id.split("_")[1];
                           switch (id) {
                           case "0"://3D場(chǎng)景
                                if(mapPage.sceneLayer)
                                   mapPage.sceneLayer.visible = flag;
                                break;
                           case "1"://水深柵格圖
                               if(waterdepthLayer)
                                  waterdepthLayer.visible = flag;
                                break;
                           case "2"://3D航道
                               if(hdyxLayer){
                                  hdyxLayer.visible = flag;
                               }
                               if(hddxLayer){
                                  hddxLayer.visible = flag;
                               }
                               break;
                                
                           }
                       }                                             
})

3.效果圖如下:

image

image
image

GIS之家新博客系列發(fā)布更新在GIS之家網(wǎng)站,歡迎關(guān)注收藏:GIS之家網(wǎng)站
GIS之家作品:GIS之家
GIS之家交流咨詢:咨詢模式

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,825評(píng)論 6 546
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,814評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 178,980評(píng)論 0 384
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 64,064評(píng)論 1 319
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,779評(píng)論 6 414
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 56,109評(píng)論 1 330
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,099評(píng)論 3 450
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 43,287評(píng)論 0 291
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,799評(píng)論 1 338
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,515評(píng)論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,750評(píng)論 1 375
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,221評(píng)論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,933評(píng)論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 35,327評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 36,667評(píng)論 1 296
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,492評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,703評(píng)論 2 380