API Docs for: 1.0.2
Show:

File: GIScene\Control\Compass.js

/**
 * The Compass Control provides a graphical information on the current camera orientation, like a compass.
 * 
 * @namespace GIScene
 * @class Control.Compass
 * @constructor
 * @extends GIScene.Control
 * @param {THREE.Camera} camera 
 */

GIScene.Control.Compass = function(camera, config) {
	
	//make this a control
	GIScene.Control.call(this);
	
	var defaults = {
		//positioning in px from canvas border
	};
	
	/**
	 * The config which is used to initialize the Compass-Control. Merged from defaults and passed config Object.
	 * 
	 * @property config
	 * @type Object
	 */
	this.config = GIScene.Utils.mergeObjects(defaults, config || {});
	
	
	this.camera = camera;
	
	var compassDegrees = 0;
	
	var windroseDataURL = "";
	
	
	var spriteTexture = new THREE.Texture(null);
	var windroseImg = new Image();
		windroseImg.onload = function() {
			spriteTexture.image = windroseImg;
			spriteTexture.needsUpdate = true;
		};
		windroseImg.src = windroseDataURL;
	
	// var spriteTexture = THREE.ImageUtils.loadTexture( GIScene.LIBRARYPATH + GIScene.RESOURCESPATH.replace(/([^\/])$/, "$1/") +"resources/images/windrose3.png" );

	var spriteMaterial = new THREE.SpriteMaterial({ map : spriteTexture, /*useScreenCoordinates:true,*/ opacity:1  });
	this.sprite = new THREE.Sprite(spriteMaterial);
	this.sprite.scale.set( 100, 100, 1 );
	// this.sprite.position.set(60,60,0);
	
	
	this.update = function() {
		//calc angle
		
		var ctp = this.camera.localToWorld(this.camera.target.position.clone());
		var cp = this.camera.position;
		var dir = ctp.sub(cp);
		var up = new THREE.Vector3(0,1,0);
		var north = new THREE.Vector3(0,0,-1);
		var dirOnPlane = dir.projectOnPlane(up);
		var isEastside = (dirOnPlane.clone().cross(up).angleTo(north) > Math.PI/2) ? true : false;
		var angleToNorth = dirOnPlane.angleTo(north);
		var compassAngle = (isEastside) ? angleToNorth : Math.PI*2 - angleToNorth;
		compassDegrees = THREE.Math.radToDeg(compassAngle);
		this.sprite.material.rotation = compassAngle;
		
	}.bind(this);
	
	/**
	 * Get Compass direction in degrees
	 * 
	 * @method getCompassDegrees 
	 * @return {Number} heading of compass in degrees
	 */
	
	this.getCompassDegrees = function() {
		return compassDegrees;
	};
	
	var onResize = function() {
		this.sprite.position.set((-this.scene.canvas.width/2)+60,(this.scene.canvas.height/2)-60,0);
	}.bind(this);
	
	
	/**
	 * Activates this Control
	 * 
	 * @method activate
	 *  
	 */
	this.activate = function(){
		if(this.isActive) return;
		
		this.scene.spriteRoot.add(this.sprite);
		this.sprite.position.set((-this.scene.canvas.width/2)+60,(this.scene.canvas.height/2)-60,0);
		this.update();
		
		//eventListeners
		//hang in render loop
		this.scene.addEventListener("cameraChange", this.update);
		window.addEventListener('resize', onResize, false);
		
		//call super class method
		GIScene.Control.prototype.activate.call(this);
	};
	
	/**
	 * Deactivates this Control
	 * 
	 * @method deactivate
	 *  
	 */
	this.deactivate = function(){
		if(!this.isActive) return;
		
		this.scene.spriteRoot.remove(this.sprite);
		//remove from render loop
		this.scene.removeEventListener("cameraChange", this.update);
		window.removeEventListener('resize', onResize, false);
		
		//call super class method
		GIScene.Control.prototype.deactivate.call(this);
	};
	

};
//Inherit from GIScene.Control
GIScene.Control.Compass.prototype = Object.create( GIScene.Control.prototype );