server simple例子 代码分析

<a:toolbar id="Toolbar" mapId="Map0" activeTool="ZoomIn">
   <a:tool id="ZoomIn" clientAction="EsriMapRectangle" 
   serverAction="com.esri.adf.web.faces.event.ZoomInToolAction" clientPostBack="true"/>
   <a:tool id="ZoomOut" clientAction="EsriMapRectangle" 
   serverAction="com.esri.adf.web.faces.event.ZoomOutToolAction" clientPostBack="true"/> 
   <a:command id="fullext" clientPostBack="true">
   <f:actionListener type="com.esri.adf.web.faces.event.ZoomFullExtentListener"/>
   </a:command>
</a:toolbar> 

 

<a:map id="Map0" value="#{mapContext.webMap}" width="400" height="400"  />

在这些代码中,我们看到有个clientAction属性,这是一些javascript脚本的语句,

打开js文件夹中的,esri-map.js中

function EsriMapRectangle(id, toolName, isMarkerTool) {
	this.inheritsFrom(new EsriMapToolItem(id, toolName, new EsriDrawRectangleAction(), isMarkerTool));
  var self = this;

  this.update = function() { self = this; }
	this.postAction = function(rect) {
    if (rect.width == 0 && rect.height == 0) return;

    self.update();
    var map = self.control;

    if (self.isMarker) map.graphics.drawRectangle(rect);
    else {
      if (self.showLoading) map.showLoading();
      rect = rect.offset(-map.viewBounds.left, -map.viewBounds.top);

      EsriUtils.addFormElement(map.formId, map.id, map.id);
      EsriUtils.addFormElement(map.formId, map.id + "_mode", self.id);
      EsriUtils.addFormElement(map.formId, map.id + "_minx", rect.left);
      EsriUtils.addFormElement(map.formId, map.id + "_miny", rect.top);
      EsriUtils.addFormElement(map.formId, map.id + "_maxx", rect.left + rect.width);
      EsriUtils.addFormElement(map.formId, map.id + "_maxy", rect.top + rect.height);
      if (self.clientPostBack) EsriUtils.addFormElement(map.formId, "doPostBack", "doPostBack");
      EsriUtils.submitForm(map.formId, self.clientPostBack, EsriControls.processPostBack);
    }
	}
}

 

而serverAction指的是服务器端的运行,比如ZoomOutToolAction。

该ZoomOutToolAction继承的是MapToolAction,必须实现execute(MapEvent event) 方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值