<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 41,  comments - 90,  trackbacks - 0
    openlayers提供了幾十個示例,雖然每個示例都很簡單,但卻很具有代表性,值得初學者學習。
    現在我想做一個測試,包含多個圖層、縮放條、工具條、鼠標位置、彈出窗口,其中圖層分別來自geoservr
    提供的WMS和WFS服務接口。
    主要代碼如下:
    樣式定義,定義地圖大小,工具條位置和替換按鈕圖片。
    <style type="text/css">
            #map {
                width: 640px;
                height: 475px;
                border: 1px solid black;
            }

            .olControlPanel div {
              display:block;
              position: absolute;
                        top: 0px;
                        left: 190px;
              width:  60px;
              height: 23px;
              margin: 5px;
            }
            .olControlPanel .olControlMouseDefaultsItemActive {
              background-image: url("/openlayers/img/Pan.gif");
            }
            .olControlPanel .olControlMouseDefaultsItemInactive {
              background-image: url("/openlayers/img/PanSelected.gif");
            }
            .olControlPanel .olControlZoomBoxItemInactive {
              width:  60px; 
              height: 23px;
              position: absolute;
                        top: 0px;
                        left: 250px;
              background-image: url("/openlayers/img/ZoomInSelected.gif");
            }
            .olControlPanel .olControlZoomBoxItemActive {
              width:  60px; 
              height: 23px;
              position: absolute;
                        top: 0px;
                        left: 250px;
              background-image: url("/openlayers/img/ZoomIn.gif");
            }
             .olControlPanel .olControlSelectFeatureItemInactive {
              width:  60px; 
              height: 23px;
              position: absolute;
                        top: 0px;
                        left: 310px;
              background-image: url("/openlayers/img/InfoSelected.gif");
            }
            .olControlPanel .olControlSelectFeatureItemActive {
              width:  60px; 
              height: 23px;
              position: absolute;
                        top: 0px;
                        left: 310px;
              background-image: url("/openlayers/img/Info.gif");
            }
        </style>
    JS代碼,核心部分。
    <script src="/openlayers/OpenLayers.js"></script>
        <script type="text/javascript">
            <!--
            //定義全局變量
            var map, layer, selectControl, selectedFeature;
            //關閉彈出窗口的函數
            function onPopupClose(evt) {
                selectControl.unselect(selectedFeature);
            }
            //構造彈出窗口的函數
            function onFeatureSelect(feature) {
                selectedFeature = feature;
                popup = new OpenLayers.Popup.Anchored("chicken",
                                         feature.geometry.getBounds().getCenterLonLat(),
                                         new OpenLayers.Size(250,75),
                                         "<div style='font-size:.8em'>" + feature.attributes['cq:LNAME'] +"</div>",
                                         null, true, onPopupClose);
                feature.popup = popup;
                map.addPopup(popup);
            }
            //銷毀彈出窗口的函數
            function onFeatureUnselect(feature) {
                map.removePopup(feature.popup);
                feature.popup.destroy();
                feature.popup = null;
            }
            //地圖和頁面加載函數
            function init(){
                //設置地圖縮放范圍和縮放等級,0級比例尺最小
                map = new OpenLayers.Map( $('map'), {  maxScale: 500, minScale: 500000, numZoomLevels: 5 });
                //加載行政區圖層,WMS柵格圖像
                layer = new OpenLayers.Layer.WMS( "District",
                        "http://192.98.151.17:8081/geoserver/wms", {layers: 'cq:GMAP_DISTRICT'} );
                map.addLayer(layer);
                //加載水系圖層,WMS柵格圖像
                layer = new OpenLayers.Layer.WMS( "Water",
                        "http://192.98.151.17:8081/geoserver/wms", {layers: 'cq:GMAP_LAKE', 'transparent': true, format: 'image/png' } );
                map.addLayer(layer);
                //加載單位圖層,WFS矢量數據,由openlayers在客戶端繪制,注意:數量太多會導致速度緩慢
                layer = new OpenLayers.Layer.WFS( "Unit",
                        "http://192.98.151.17:8081/geoserver/wfs", {typename: 'cq:GPOI_GOV'},
                   { 
                          typename: 'unit',
                          featureNS: 'http://www.openplans.org/cq',
                          extractAttributes: true,
                          maxfeatures: 10,
                          textAttrToDisplay: 'lname'
                   } );
                map.addLayer(layer);
                //在地圖上添加按鈕和工具條
                zb = new OpenLayers.Control.ZoomBox();
                var panel = new OpenLayers.Control.Panel({defaultControl: zb});
                selectControl = new OpenLayers.Control.SelectFeature(layer, {onSelect: onFeatureSelect, onUnselect: onFeatureUnselect, hover: true});
                panel.addControls([
                    new OpenLayers.Control.MouseDefaults(), zb, selectControl
                ]);
                map.addControl(panel);
              
                map.addControl(new OpenLayers.Control.PanZoomBar({zoomWorldIcon:false}));
                map.addControl(new OpenLayers.Control.LayerSwitcher({'ascending':false}));
                map.addControl(new OpenLayers.Control.MousePosition());
                //設置初始地圖的中心坐標和縮放等級
                map.setCenter(new OpenLayers.LonLat(106.5, 29.5), 3);
               
            }
            // -->
        </script>
    HTML代碼
    <body onload="init()">
        <h1>OpenLayers Test</h1>
        <div id="panel"></div>
        <div id="map"></div>
        <textarea style="display:none" id="serialize" cols="96" rows="10"/>
      </body>

    posted on 2007-11-26 10:58 天狼 閱讀(31658) 評論(15)  編輯  收藏

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 毛片大全免费观看| 亚洲人成电影网站免费| 久久嫩草影院免费看夜色| 亚洲第一永久AV网站久久精品男人的天堂AV | 亚洲AV永久无码区成人网站| 两个人看的www免费视频中文| 亚洲精品成人片在线观看精品字幕| 三年片免费观看大全国语| 亚洲国产精品成人久久| 未满十八18禁止免费无码网站| 亚洲日韩区在线电影| 国产免费丝袜调教视频| 亚洲最大的成人网站| 亚洲成人高清在线| 国产无遮挡裸体免费视频在线观看 | 亚洲国产国产综合一区首页| 91频在线观看免费大全| 亚洲av乱码中文一区二区三区| 亚洲国产成人精品91久久久| 久久福利青草精品资源站免费| 亚洲人成片在线观看| 免费一级国产生活片| 免费国产成人α片| 亚洲一区二区三区无码国产| 免费永久在线观看黄网站| 老司机69精品成免费视频| 99久久国产亚洲综合精品| 亚洲国产成人五月综合网 | 日韩精品无码一区二区三区免费| 亚洲AV无码乱码在线观看代蜜桃| 国产成人精品免费视频大全五级 | 亚洲午夜精品一级在线播放放 | 特级无码毛片免费视频| 亚洲人成影院在线| 四虎影视永久免费视频观看| 免费A级毛片无码A∨| 国产精品无码亚洲一区二区三区| 久久被窝电影亚洲爽爽爽| 日本免费网站观看| 色猫咪免费人成网站在线观看| 色欲aⅴ亚洲情无码AV|