lzugis——Arcgis Server for JavaScript API之自己定义InfoWindow

用过Arcgis Server for JavaScript API肯定知道InfoWIndow。你在用InfoWindow的时候会发现各种问题,比如不能全然显示的问题,遮盖对象的问题等等。所以呢我在实现这个功能的时候动了下脑子,想自己用div+css弄一个,倒腾了半天,弄出来了一个例如以下所看到的的:

做的比較丑陋,样式方面还得好好下下功夫。东西是差点儿相同实现了,以下说说思路:

首先。DIV定义,这个样式,我定义了5个div,各自是infowin,title,colse,content。arrow,当中。infowin是整个InfoWindow的大框架,title为标题。close为关闭button,content为主要内容,arrow为以下的小尾巴。我们能够将这个小尾巴做的长一点。以免对象被遮盖的情况,代码为:

    <div id="mapDiv">
    	<div id="infowin">
        	<div id="close" onClick="closeInfoWin()">X</div>
            <div id="title"></div>
            <div id="content"></div>
            <div id="arrow"></div>
        </div>
    </div>

定义了div就得进行布局。定义样式了,样式为:

    <style>
          html, body, #mapDiv
	  {
                padding:0;
                margin:0;
                height:100%;
		font-size:10px;
		position: relative;
          }
	  #infowin
	  {
		  display:none;
		  z-index:10000;
	  }
	  #close
	  {
		  float:right;
		  padding-top:10px;
		  font-weight:bold;
		  font-size:12px;
		  color:#FFF;
		  border:#000 1px solid;
		  height:20px;
		  width:20px;
		  text-align:center;
	  }
	   #close:hover
	  {
		  cursor:pointer;
	  }
	  #title
	  {
		  background-color:#666;
		  padding:10px;
		  font-weight:bold;
		  font-size:12px;
	  }
	  #content
	  {
		  padding-left:10px;
		  padding-top:10px;
		  background-color:#999;
		  height:200px;
	  }
	  #arrow
	  {
		  background-image:url(arrow.png);
		  height:30px;
	  }
    </style>

样式定义完之后就得考虑事件了,一般InfoWindow是在点击某个对象时弹出来的,所以我们得定义对象图层的click事件:

		function leftClick(evt){
			infowin.style.display="none";

			var strtitle="城市名称"
		  	var strcontent = "****是一座漂亮的城市<br><br>****是一座好看的城市<br><br>****是一座富饶的城市<br><br>****是一座漂亮的城市";

			infowin.style.left=(evt.clientX-width/2)+"px";
			infowin.style.top=(evt.clientY-height-50)+"px";
			infowin.style.position="absolute";
			infowin.style.width=width+"px";
			infowin.style.height=height+"px";
			infowin.style.display="block";

			title.innerHTML = strtitle;
			content.innerHTML = strcontent;

		}
		//鼠标单击
		featurelayercity.on("click", leftClick);

点击对象,在鼠标的点击位置出现。所以我们得将infowin的position样式设为absolute。并定义left和top分别为clientX和clientY,并将其display设置为block,将其显示,实现的具体代码例如以下:

<!DOCTYPE html>
<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <!--The viewport meta tag is used to improve the presentation and behavior of the samples
      on iOS devices-->
    <meta name="viewport" content="initial-scale=1, maximum-scale=1,user-scalable=no">
    <title>Feature Layer - display results as an InfoWindow onHover</title>

    <link rel="stylesheet" href="http://localhost/arcgis_js_api/library/3.8/3.8/js/dojo/dijit/themes/claro/claro.css">
	<link rel="stylesheet" href="http://localhost/arcgis_js_api/library/3.8/3.8/js/dojo/dijit/themes/tundra/tundra.css">
    <link rel="stylesheet" href="http://localhost/arcgis_js_api/library/3.8/3.8/js/esri/css/esri.css">
	<style>
      html, body, #mapDiv
	  {
        padding:0;
        margin:0;
        height:100%;
		font-size:10px;
		position: relative;
      }
	  #infowin
	  {
		  display:none;
		  z-index:10000;
	  }
	  #close
	  {
		  float:right;
		  padding-top:10px;
		  font-weight:bold;
		  font-size:12px;
		  color:#FFF;
		  border:#000 1px solid;
		  height:20px;
		  width:20px;
		  text-align:center;
	  }
	   #close:hover
	  {
		  cursor:pointer;
	  }
	  #title
	  {
		  background-color:#666;
		  padding:10px;
		  font-weight:bold;
		  font-size:12px;
	  }
	  #content
	  {
		  padding-left:10px;
		  padding-top:10px;
		  background-color:#999;
		  height:200px;
	  }
	  #arrow
	  {
		  background-image:url(arrow.png);
		  height:30px;
	  }
    </style>
    <script src="http://js.arcgis.com/3.9/"></script>
    <script>
	  var infowin,colse,title,content;

	  var width=400,height=230;

	  var closeInfoWin = function (evt){
		  infowin=document.getElementById("infowin");
		  infowin.style.display="none";
	  };

	  require([
        "esri/map", //地图
		"esri/layers/ArcGISTiledMapServiceLayer",
		"esri/layers/FeatureLayer",//特征层
		"esri/symbols/PictureMarkerSymbol",//图片点符号
        "esri/renderers/SimpleRenderer", //简单渲染
		"esri/graphic", //图片
		"esri/lang",
		"dojo/domReady!"
      ], function(
        Map,ArcGISTiledMapServiceLayer,FeatureLayer,PictureMarkerSymbol,SimpleRenderer,esriLang
      ) {
        var map = new Map("mapDiv", {
		  logo:false,
          center: [106.6854, 35.8364],
          zoom: 4,
          slider: true
        });	

		var shpServiceURL="***************************************";
		var shpTitlelayer=new ArcGISTiledMapServiceLayer(shpServiceURL);
		map.addLayer(shpTitlelayer);

		//--------------------------------------------------------------------------------------------------------
		var featurelayercity = new FeatureLayer("******************************************************", {
          mode: FeatureLayer.MODE_SNAPSHOT,
          outFields: ["*"]
        });
	    var pmsRed = new PictureMarkerSymbol(‘../images/location_icon_blue.png‘, 20, 20).setOffset(0, 15);
		//简单渲染
		var sr=new SimpleRenderer(pmsRed);
		featurelayercity.setRenderer(sr);
        map.addLayer(featurelayercity);	

		infowin = document.getElementById("infowin");
	 	colse = document.getElementById("close");
	  	title = document.getElementById("title");
	  	content = document.getElementById("content");
		function leftClick(evt){
			infowin.style.display="none";

			var strtitle="城市名称"
		  	var strcontent = "****是一座漂亮的城市<br><br>****是一座好看的城市<br><br>****是一座富饶的城市<br><br>****是一座漂亮的城市";

			infowin.style.left=(evt.clientX-width/2)+"px";
			infowin.style.top=(evt.clientY-height-50)+"px";
			infowin.style.position="absolute";
			infowin.style.width=width+"px";
			infowin.style.height=height+"px";
			infowin.style.display="block";

			title.innerHTML = strtitle;
			content.innerHTML = strcontent;

		}
		//鼠标单击
		featurelayercity.on("click", leftClick);
      });
    </script>
  </head>
  <body class="tundra">
    <div id="mapDiv">
    	<div id="infowin">
        	<div id="close" onClick="closeInfoWin()">X</div>
            <div id="title"></div>
            <div id="content"></div>
            <div id="arrow"></div>
        </div>
    </div>
  </body>
</html>

眼下仅仅实现到了这儿, 还有下面问题待解决:1、地图拖动后infowin随着地图的联动。2、地图缩放后infowin随着地图的联动;3、内容不在可视范围时候的移动;4、样式。挺难看的。希望有人实现后共享下代码,造福全GISer。

lzugis

时间: 2024-10-18 12:45:40

lzugis——Arcgis Server for JavaScript API之自己定义InfoWindow的相关文章

lzugis——Arcgis Server for JavaScript API之自定义InfoWindow(续)

同样的标题后面加了一个括弧,不是为了增减博文数量,而确实是上个功能的完善,标注为续,意思是继续上次的内容,来说说如何自定义InfoWindow. 在上一讲中,实现了InfoWindow的显示,但是并没有实现地图拖动地图InfoWindow随着联动,以及缩放地图InfoWindow随着联动的问题,在本文章中,就上述两个问题提供一个解决思路. 首先,说说拖动地图InfoWindow的联动.拖动地图时,地图并未做缩放,所以只是做一个位置的偏移,因此,定义一个公共变量,记录InfoWindow出来时候的

lzugis——Arcgis Server for JavaScript API之POI

POI(Point Of Interest),感兴趣点,其实呢,严格意义上说应该不是POI,但是单位就这样叫了,我也就这样叫了,其实现的功能大致是这样的:用过百度地图的朋友们都知道你在百度地图时,当鼠标经过某个点时会显示这个对象的名称,点击该对象,会弹出该对象的详细信息.如下图所示: 实现后的效果呢就是这样子的,下面呢我来说说在Arcgis Server for JavaScript API下,我实现该效果的思路与想法. 首先,得有一个图层用于显示这些点对象,这个图层可以是切片,也可以是WMS,

lzugis——Arcgis Server for JavaScript API之自定义InfoWindow

用过Arcgis Server for JavaScript API肯定知道InfoWIndow,你在用InfoWindow的时候会发现各种问题,例如不能完全显示的问题,遮盖对象的问题等等,所以呢我在实现这个功能的时候动了下脑子,想自己用div+css弄一个,倒腾了半天,弄出来了一个如下所示的: 做的比较丑陋,样式方面还得好好下下功夫,东西是差不多实现了,下面说说思路: 首先,DIV定义,这个样式,我定义了5个div,分别是infowin,title,colse,content,arrow,其中

lzugis——Arcgis Server for JavaScript API在自己的定义InfoWindow

你看到这个标题嫌烦.因为我最近一直与研究问题,相关文章使这些也可以只,同时要读我文章的朋友.我的文章能够给你带来帮助. 在相关的内部的前两篇文章,达到InfoWindow经div实现的东西,成InfoWindowBase实现infowindow的. 实现后InfoWindow主要改动了arcgis原来的样式.并增加了InfoWindow出界的处理. 源码奉上: InfoWindow.js define([ "dojo/Evented", "dojo/parser",

ArcGIS server开发之API for js 本地部署

ArcGIS Server for javascript 本地部署 第一次使用arcgis server for js开发,在经验方面还有很多的不足,所以将自己在开发过程中遇到的问题写出来与大家共享.有什么不足的地方还望多多指正,共同学习. 一.arcgis arcgis for JavaScript API的下载地址为:http://help.arcgis.com/en/webapi/javascript/arcgis/ 二.下载之后的压缩包解压之后 三.将解压的api和sdk要部署到IIS的

How to CORS enable ArcGIS Server 10.2.1 to Access REST Services without Using proxy.ashx

http://gis.stackexchange.com/questions/86206/how-to-cors-enable-arcgis-server-10-2-1-to-access-rest-services-without-using-pr 比如,在你的arcgis server for javascript api网站中跨域访问WebApi的资源(取一些json格式数据?),差不多懂了

ArcGIS Server 缓存服务切图范围

ArcGIS Server 缓存服务分为创建服务时同时自动建立缓存和创建服务后手动建立缓存两种. 相关资料: 缓存: 瓦片: 切片: 10.4帮助文档: 10.2帮助文档: http://resources.arcgis.com/zh-cn/help/main/10.2/index.html#//00540000000p000000 官方文档链接:http://resources.arcgis.com/zh-cn/help/main/10.2/index.html#//00540000000p0

ArcGIS API for JavaScript(2)-ArcGIS Server发布要素图层服务

1.前言 上一篇该系列的文章我们主要讲了一下基础Web地图搭建,这篇我们主要讲一下ArcGIS Server发布服务,并且如何调用服务.将自己的数据加载到Web地图当中来,实现Web端浏览数据. 2.ArcGIS Server介绍与安装 1.ArcGIS Server 是功能强大的基于服务器的 GIS 产品,用于构建集中管理的.支持多用户的.具备高级GIS功能的企业级GIS应用与服务,如:空间数据管理.二维三维地图可视化.数据编辑.空间分析等即拿即用的应用和类型丰富的服务.ArcGIS Serv

ArcGIS Server JavaScript API 各命名空间的含义【转】

1.esri 命名空间      所有的对象都是在 esri 命名空间下的,esri 有自己的属性和方法.      如 esri.version 返回当前 JavaScript API 的版本号.esri.hide(Element) 隐藏 html 元素,像 DIV 或者是 TABLE 元素.2.Graphic 对象      如果你做过 arcserver adf 开发或者是 arcserver api for Silverlight 开发的话,对 Graphic 对象应该是很熟悉的.这是一