Q. JS如何编写类与生成构造函数
A.
基类为Class,代码如下:
var Class = {//原始基类
create: function() {
return function() {
this.initialize.apply(this, arguments);
}
}
}
var Book = Class.create(); //声名为Book的类
Book.prototype = { //给Book类添加成员和方法
className:"Book", //属性:类名
initialize: function(name){ //构造函数
this.name = name;
},
getName:function(){ //方法:取书名
return this.name;
}
}
var book = new Book('XYZ'); //创建一个Book对像
document.write(book.getName()); //打印书名
Q. Opanlayers如何添加WMS服务层
A.
map = new OpenLayers.Map( 'map',{ controls: [] } );
layer = new OpenLayers.Layer.WMS( "test", //层别名
"http://192.168.2.60:8083/wmsconnector/com.esri.wms.Esrimap" //服务连接
, {
layers: 'street3', //包含层的ID,AXL文件里层的ID,用","分开
format:OpenLayers.Util.alphaHack()?'image/gif':'image/png', //图片格式
transparent:'true', //是否透明,注意,IE只支持GIF透明,
ServiceName: "test2",//wms服务名
async: true,
srs:'EPSG:4214' //坐标系统,经纬度写EPSG:4326
}
,{
maxExtent:new OpenLayers.Bounds(489757.940,293425.5058,534205.948491573,326902.17035), //最大范围坐标
projection:"EPSG:4214",
isBaseLayer:true,
singleTile:true,//是否瓦片图
maxResolution: (534205.948491573-489757.940)/1024 //最大分辨率
}
);
map.addLayer(layer);
map.setCenter(new OpenLayers.LonLat(512950.10208490635, 312347.9883206317), 0);//第一个参数为坐标,第二个为缩放等级,0为顶级
Q. Opanlayers如何添加工具条toolbar
A.
//关键代码
zoomIn = new OpenLayers.Control.ZoomBox({title:'放大',displayClass:'olZoomIn'});
zoomOut = new OpenLayers.Control.ZoomBox({out:true,title:'缩小',displayClass:'olZoomOut'});
pan = new OpenLayers.Control.DragPan({title:'移动',displayClass:'olPan'});
var panel = new OpenLayers.Control.Panel({defaultControl: pan}); // defaultControl为默认工具
panel.addControls([zoomIn,zoomOut,pan]);
map.addControl(panel); //map为上例定义
与代码对应的CSS文件,displayClass与下面的对应,如displayClass:'olpan',那么按钮激活状态的
CSS类为.olPanItemActive,非激活状态为.olZoomOutItemInactive。工具条的DIV的Class
默认为:.olControlPanel,通过DIV+CSS定位工具条。以上工具条的CSS示例为:
.olControlPanel div {
display:block;
top: 0px;
left: 190px;
width: 360px;
height: 26px;
margin: 0px;
}
.olControlPanel .olZoomInItemInactive {
width: 26px;
height: 26px;
float:left;
position:relative;
background-image: url("../SritGisScript/img/zoomin.gif");
}
.olControlPanel .olZoomInItemActive {
width: 26px;
height: 26px;
float:left;
position:relative;
background-image: url("../SritGisScript/img/zoomin_1.gif");
}
.olControlPanel .olZoomOutItemInactive {
width: 26px;
height: 26px;
position:relative;
float:left;
background-image: url("../SritGisScript/img/zoomout.gif");
}
.olControlPanel .olZoomOutItemActive {
width: 26px;
height: 26px;
position:relative;
float:left;
background-image: url("../SritGisScript/img/zoomout_1.gif");
}
.olControlPanel .olPanItemInactive {
width: 26px;
height: 26px;
position:relative;
float:left;
background-image: url("../SritGisScript/img/pan.gif");
}
.olControlPanel .olPanItemActive {
width: 26px;
height: 26px;
position:relative;
float:left;
background-image: url("../SritGisScript/img/pan_1.gif");
}
Q. Opanlayers如何添加测距功能
A.
说明:本段代码是在 openlayers/examples/measure.html 基础上进行完善
===================================================
CSS添加内容:
.olControlPanel .olMeasureLineItemInactive {
width: 26px;
height: 26px;
position:relative;
float:left;
background-image: url("img/measureline.gif");
}
.olControlPanel .olMeasureLineItemActive {
width: 26px;
height: 26px;
position:relative;
float:left;
background-image: url("img/measureline_1.gif");
}
.olControlPanel .olMeasurePolygonItemInactive {
width: 26px;
height: 26px;
position:relative;
float:left;
background-image: url("img/measurearea.gif");
}
.olControlPanel .olMeasurePolygonItemActive {
width: 26px;
height: 26px;
position:relative;
float:left;
background-image: url("img/measurearea_1.gif");
}
======================================================================
javascript添加内容:
var sketchSymbolizers = {
"Point": {
pointRadius: 4,
graphicName: "square",
fillColor: "white",
fillOpacity: 1,
strokeWidth: 1,
strokeOpacity: 1,
strokeColor: "#333333"
},
"Line": {
strokeWidth: 3,
strokeOpacity: 1,
strokeColor: "#666666",
strokeDashstyle: "dash"
},
"Polygon": {
strokeWidth: 2,
strokeOpacity: 1,
strokeColor: "#666666",
fillColor: "white",
fillOpacity: 0.3
}
};
var style = new OpenLayers.Style();
style.addRules([
new OpenLayers.Rule({symbolizer: sketchSymbolizers})
]);
var styleMap = new OpenLayers.StyleMap({"default": style});
measureLine=new OpenLayers.Control.Measure(
OpenLayers.Handler.Path, {
title:'测距',
displayClass:'olMeasureLine',
persist: true,
handlerOptions: {
layerOptions: {styleMap: styleMap}
}
}
);
measureLine.events.on({
"measure": handleMeasurements //测距功能回调方法
});
measurePolygon=new OpenLayers.Control.Measure(
OpenLayers.Handler.Polygon, {
title:'测面积',
displayClass:'olMeasurePolygon',
persist: true,
handlerOptions: {
layerOptions: {styleMap: styleMap}
}
}
);
measurePolygon.events.on({
"measurepartial": handleMeasurements ////测面积功能回调方法
});
map.addControls([measureLine,measurePolygon]);
==================================================================
//回调方法,根据需要编写,本示例为在output的Div里输出
function handleMeasurements(event) {
var geometry = event.geometry;
var units = event.units;
var order = event.order;
var measure = event.measure;
var element = document.getElementById('output');
var out = "";
if(order == 1) {
out += "measure: " + measure.toFixed(3) + " " + units;
} else {
out += "measure: " + measure.toFixed(3) + " " + units + "2";
}
element.innerHTML = out;
}
=====================================================================
分享到:
相关推荐
OpenLayers 是一个强大的开源JavaScript库,用于在网页上创建交互式的地图应用。它支持多种地图数据源,包括WMS、WMTS、TMS、GeoJSON等,使得开发者能够轻松地将地理信息集成到Web应用中。这个"openlayers中文.rar...
OpenLayers 是一个强大的开源JavaScript库,用于在网页上创建交互式的地图应用。它支持多种地图服务,包括WMS、WMTS等,并且能够处理多种数据格式,如GeoJSON、KML等。"openlayers很多特效demo" 提供了一系列示例,...
OpenLayers 是一个强大的开源JavaScript库,专为在Web上创建交互式地图应用而设计。它支持多种地图数据源,包括WMS、WMTS、TMS等服务,以及GeoJSON和KML等本地格式。OpenLayers v5.3.0是这个库的一个重要版本更新,...
OpenLayers 源文件,OpenLayers 源文件,OpenLayers 源文件,OpenLayers 源文件,OpenLayers 源文件,OpenLayers 源文件,OpenLayers 源文件,OpenLayers 源文件、
《OpenLayers 5.3.0 高速文档详解》 OpenLayers 是一个开源JavaScript库,专门用于在网页上创建交互式的地图应用。版本5.3.0是其一个重要里程碑,提供了丰富的功能和优化,使得开发者能更高效地构建地理信息系统...
**OpenLayers 开发指南** OpenLayers 是一个开源的JavaScript库,专门用于在Web浏览器中展示地理信息系统(GIS)数据。这个强大的工具允许开发者创建交互式的地图应用,支持多种地图服务,包括WMS、WFS、KML等。...
OpenLayers 是一个开源JavaScript库,专门用于在网页上创建交互式的地图应用。它支持多种地图服务,包括WMS、WMTS、TMS等,并且兼容各种数据格式,如GeoJSON、KML和GML。OpenLayers v4.2.0是这个库的一个特定版本,...
在GIS领域,OpenLayers和GeoServer是两个非常重要的开源组件,它们共同构成了Web GIS系统的重要组成部分。OpenLayers是一个JavaScript库,用于在Web浏览器中显示地图,而GeoServer则是一个基于Java的服务,它允许...
在OpenLayers中,删除Layer中的marker可以通过以下步骤实现:首先,获取到你想要删除的marker对象,这通常基于用户交互事件(如点击)来完成。然后,调用Layer的removeFeatures方法,传入marker对象即可将其从地图上...
OpenLayers 是一个开源JavaScript库,专门用于在网页上创建交互式的地图应用。它支持多种地图服务,包括WMS、WMTS、TMS等,并且兼容各种浏览器,包括桌面端和移动设备。这个压缩包文件包含了一系列JSON数据,很可能...
OpenLayers 是一个开源的JavaScript库,用于在网页上创建交互式的地图应用。它支持多种地图服务,包括WMS、WMTS等,并且可以与不同的数据格式兼容,如GeoJSON、KML等。中文文档的提供使得国内开发者更容易理解和使用...
OpenLayers 是一个开源JavaScript库,专门用于在Web上创建交互式的地图应用。它支持多种地图服务,包括WMS、WMTS、TMS等,并且兼容各种浏览器和设备。OpenLayers 5是其版本更新中的一项重要升级,带来了许多新特性和...
OpenLayers 是一个流行的开源JavaScript库,用于在Web上创建交互式地图应用。它支持多种地图服务,如WMS、WMTS,以及现代Web地图技术,如矢量图层和GeoJSON。本教程将深入探讨如何对OpenLayers的常用功能进行简单...
openlayers 风场渲染效果,放置风场数据即可使用
"OpenLayers典型例子展示" OpenLayers是一款基于Web的GIS(Geographic Information System)映射库,提供了强大的地图展示和交互功能。下面我们将通过一些典型例子,展示OpenLayers的强大功能和多样化的应用场景。 ...
OpenLayers 是一个开源的JavaScript库,专为构建地图应用程序而设计。它允许开发人员在网页上展示地图,处理地理数据,并提供与用户交互的各种功能。这个"openLayers-API中文版.zip"压缩包很可能是OpenLayers API的...
OpenLayers API 研究文档 OpenLayers 是一个基于 JavaScript 的开源地图库,提供了丰富的 API 用于开发基于 Web 的地图应用程序。本文档将对 OpenLayers 的一些重要 API 进行研究,包括控件、方法、类和事件处理等...
OpenLayers_GeoServer常见问题解决方案 OpenLayers 是一个基于Web的开源地理信息系统(GIS),广泛应用于地理信息系统的开发。 GeoServer 是一个基于Web的开源地理信息服务器,提供了强大的地理信息存储、处理和...
在OpenLayers中调用百度地图是一项常见的需求,特别是在构建Web GIS应用时,用户可能希望结合OpenLayers的强大功能和百度地图的丰富数据。OpenLayers是一个开源JavaScript库,用于创建交互式的地图应用,而百度地图...