Measurement.js
	
	
Summary
	
		No overview generated for 'Measurement.js'
	
    
    
 
        
mapbuilder.loadScript(baseDir+"/widget/EditButtonBase.js");
mapbuilder.loadScript(baseDir+"/model/Proj.js");
function Measurement(widgetNode, model) {
  EditButtonBase.apply(this, new Array(widgetNode, model));
  
  this.createControl = function(objRef) {
    var Control = OpenLayers.Class(OpenLayers.Control.DrawFeature, {
      CLASS_NAME: 'mbMeasurement'
    });
    return Control;
  }
  
  this.instantiateControl = function(objRef, Control) {
     var control = new Control(objRef.featureLayer, OpenLayers.Handler.Path,
          {callbacks: {point: objRef.doAction}});
    control.objRef = objRef;
    control.activate = function() {
      Control.prototype.activate.apply(this, arguments);
      objRef.targetModel.setParam('showDistance', 0);
    }
    control.deactivate = function() {
      Control.prototype.deactivate.apply(this, arguments);
      objRef.targetModel.setParam('showDistance', null);
    }
    return control;
  }
  this.cursor = "crosshair";	
        
  var totalDistance=0;
  var distance = 0;
  var state = false;
  var restart = false;
  
  
  this.doAction = function(pointGeometry) {
    var objRef = this.objRef;
    if (objRef.enabled) {
		  if(objRef.restart) {
        objRef.model.setParam("clearMeasurementLine");
			  objRef.restart= false;
			}
      var point=[pointGeometry.x, pointGeometry.y];
      var old=objRef.targetModel.getXpathValue(objRef.targetModel,objRef.featureXpath);
      if(!old) old="";
        sucess=objRef.targetModel.setXpathValue(objRef.targetModel,objRef.featureXpath,old+" "+point[0]+","+point[1]);
      if(!sucess) {
        alert(mbGetMessage("invalidFeatureXpathMeasurement", objRef.featureXpath));
      }
			
      var lineCoords = objRef.targetModel.getXpathValue(objRef.targetModel, objRef.featureXpath);
      var coordArray = lineCoords.split(" ");
      if (coordArray.length >= 3) {
        var point_P = coordArray[coordArray.length-2];
        var point_Q = coordArray[coordArray.length-1];
        var P =point_P.split(",");
        var Q =point_Q.split(",");
        objRef.srs = srs.toUpperCase();
        objRef.proj = new Proj (objRef.srs);
        
        if (!P || !Q  ){
          alert(mbGetMessage("projectionNotSupported"));
        }
        else {
          if(objRef.proj.units == "meters" || objRef.proj.units == "m") {
            Xp=parseFloat(P[0]);
            Yp=parseFloat(P[1]);
            Xq=parseFloat(Q[0]);
            Yq=parseFloat(Q[1]);
            distance=Math.sqrt(((Xp-Xq)*(Xp-Xq))+((Yp-Yq)*(Yp-Yq)))
			      if(distance==0) {
              objRef.restart = true;
              objRef.model.setParam("clearMouseLine");objRef.targetModel.setParam("mouseRenderer", false);
		    		return;
				  	}
            totalDistance = Math.round(totalDistance + distance);
          }
          else if(objRef.proj.units == "degrees" || objRef.proj.units == null) {
            var deg2rad = Math.PI / 180.0
            var centerOfEarth=new Array(0,0);
            LonpRad=parseFloat(P[0]) * deg2rad;
            LatpRad=parseFloat(P[1]) * deg2rad;
            LonqRad=parseFloat(Q[0]) * deg2rad;
            LatqRad=parseFloat(Q[1]) * deg2rad;
            
            if((LonpRad>0 && LonqRad<0) || (LonpRad<0 && LonqRad>0)){
	            if(LonpRad<0){
	           	 	radDistance=Math.acos(Math.sin(LatpRad)*Math.sin(LatqRad)+Math.cos(LatpRad)*Math.cos(LatqRad)*Math.cos(LonpRad));
	            	radDistance+=Math.acos(Math.sin(LatpRad)*Math.sin(LatqRad)+Math.cos(LatpRad)*Math.cos(LatqRad)*Math.cos(LonqRad));
	            }
	            if(LonqRad<0){
	            	radDistance=Math.acos(Math.sin(LatpRad)*Math.sin(LatqRad)+Math.cos(LatpRad)*Math.cos(LatqRad)*Math.cos(LonqRad));
	            	radDistance+=Math.acos(Math.sin(LatpRad)*Math.sin(LatqRad)+Math.cos(LatpRad)*Math.cos(LatqRad)*Math.cos(LonpRad));
	            }
             }
             else{
             
            	radDistance=Math.acos(Math.sin(LatpRad)*Math.sin(LatqRad)+Math.cos(LatpRad)*Math.cos(LatqRad)*Math.cos(LonpRad-LonqRad));
            
            }
            distance =radDistance * 6378137;
            if(distance==0) {
              objRef.restart = true;
              objRef.model.setParam("clearMouseLine");objRef.targetModel.setParam("mouseRenderer", false);
            return;
            }
            totalDistance = Math.round(totalDistance + distance);
          }
          else alert(mbGetMessage("cantCalculateDistance"));
        }
      }    
      objRef.targetModel.setParam("showDistance", totalDistance); // set parameter for the distance output
    }
  }
  
  
  this.setFeature = function(objRef, feature) {
    objRef.restart = true;
  }
    
  this.clearMeasurementLine = function(objRef){
    if (totalDistance !=0) {
      totalDistance=0;
      sucess=objRef.targetModel.setXpathValue(objRef.targetModel,objRef.featureXpath,"");
      if(!sucess){
        alert(mbGetMessage("invalidFeatureXpathMeasurement", objRef.featureXpath));
      }
      objRef.targetModel.setParam("refresh");
    }
  }
	this.model.addListener("clearMeasurementLine", this.clearMeasurementLine, this);
}
	
Documentation generated by 
JSDoc on Tue Aug 21 08:12:28 2007