portable-ar.js 6.3 KB
Newer Older
J
Jerome Etienne 已提交
1
var PortableARjs = function(canvasEl, options){
J
Jerome Etienne 已提交
2 3 4 5 6 7 8 9 10 11
	// handle default options
	options = options || {}
	options.debugUI = options.debugUI !== undefined ? options.debugUI : false
	options.renderThreejs = options.renderThreejs !== undefined ? options.renderThreejs : false
	this.options = options
	
	//////////////////////////////////////////////////////////////////////////////
	//		create arjsProfile
	//////////////////////////////////////////////////////////////////////////////
	
J
Jerome Etienne 已提交
12
	var trackingMethod = 'area-artoolkit'
J
Jerome Etienne 已提交
13
	var arjsProfile = new ARjs.Profile()
J
Jerome Etienne 已提交
14 15 16 17 18 19 20
		.sourceWebcam()
		.trackingMethod(trackingMethod)
		.changeMatrixMode('cameraTransformMatrix')
		.defaultMarker()
		.checkIfValid()

	//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
21
	//		init three.js scene/camera
J
Jerome Etienne 已提交
22
	//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
23 24 25 26 27
	// init scene and camera
	var threejsScene= new THREE.Scene()

	var threejsCamera = ARjs.Utils.createDefaultCamera(trackingMethod)
	threejsScene.add(threejsCamera)
J
Jerome Etienne 已提交
28 29

	//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
30
	//		init three.js renderer - never rendered except if options.renderThreejs === true
J
Jerome Etienne 已提交
31
	//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
32 33 34
	// init threejsRenderer
	// NOTE: can i avoid to have a renderer ?
	var threejsRenderer	= new THREE.WebGLRenderer({
J
Jerome Etienne 已提交
35 36 37
		antialias: true,
		alpha: true
	})
J
Jerome Etienne 已提交
38 39 40 41 42
	threejsRenderer.setClearColor(new THREE.Color('lightgrey'), 0)
	threejsRenderer.setSize( 640, 480 )
	threejsRenderer.domElement.style.position = 'absolute'
	threejsRenderer.domElement.style.top = '0px'
	threejsRenderer.domElement.style.left = '0px'
J
Jerome Etienne 已提交
43 44 45 46 47


	//////////////////////////////////////////////////////////////////////////////
	//		build ARjs.Session
	//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
48 49 50 51 52 53 54

	var arjsSession = new ARjs.Session({
		scene: threejsScene,
		renderer: threejsRenderer,
		camera: threejsCamera,
		sourceParameters: arjsProfile.sourceParameters,
		contextParameters: arjsProfile.contextParameters		
J
Jerome Etienne 已提交
55
	})
J
Jerome Etienne 已提交
56 57 58 59 60 61 62 63 64
	

	////////////////////////////////////////////////////////////////////////////////
	//          Create a ARjs.Anchor
	////////////////////////////////////////////////////////////////////////////////
	var arjsAnchor = new ARjs.Anchor(arjsSession, arjsProfile.defaultMarkerParameters)

	this.cameraProjectionMatrix = []
	this.cameraTransformMatrix = []
J
Jerome Etienne 已提交
65

J
Jerome Etienne 已提交
66
	//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
67
	//		update function
J
Jerome Etienne 已提交
68
	//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
69 70 71 72 73 74
	this.update = function(){
		// update arjsSession
		arjsSession.update()

		// update the arjsAnchor
		arjsAnchor.update()
J
Jerome Etienne 已提交
75

J
Jerome Etienne 已提交
76 77 78 79 80 81
		// resize babylon canvas
		arjsSession.arSource.copyElementSizeTo(canvasEl)
	
		// copy camera projectionMatrix and transformMatrix
		this.cameraProjectionMatrix = threejsCamera.projectionMatrix.toArray()
		this.cameraTransformMatrix = threejsCamera.matrix.toArray()
J
Jerome Etienne 已提交
82 83 84
	}

	
J
Jerome Etienne 已提交
85
	//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
86
	//		add options
J
Jerome Etienne 已提交
87 88
	//////////////////////////////////////////////////////////////////////////////

J
Jerome Etienne 已提交
89 90 91
	// add debugUI
	if( this.options.debugUI === true ){
		this._initOptionsDebugUI(arjsSession, arjsAnchor)
J
Jerome Etienne 已提交
92 93
	}

J
Jerome Etienne 已提交
94 95 96 97
	// add three.js debug
	if( this.options.renderThreejs === true ){
		this._initOptionRenderThreejs(treejsRenderer, threejsScene, threejsCamera, arjsAnchor)
	}
J
Jerome Etienne 已提交
98 99 100 101 102 103 104 105

}



//////////////////////////////////////////////////////////////////////////////
//		Code Separator
//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
106

J
Jerome Etienne 已提交
107
PortableARjs.prototype._initOptionsDebugUI = function(arjsSession, arjsAnchor){
J
Jerome Etienne 已提交
108 109 110 111 112 113 114
	// create arjsDebugUIContainer if needed
	if( document.querySelector('#arjsDebugUIContainer') === null ){
		var domElement = document.createElement('div')
		domElement.id = 'arjsDebugUIContainer'
		domElement.setAttribute('style', 'position: fixed; bottom: 10px; width:100%; text-align: center; z-index: 1;color: grey;')
		document.body.appendChild(domElement)
	}
J
Jerome Etienne 已提交
115

116

J
Jerome Etienne 已提交
117 118
	var sessionDebugUI = new ARjs.SessionDebugUI(arjsSession)
	document.querySelector('#arjsDebugUIContainer').appendChild(sessionDebugUI.domElement)
J
Jerome Etienne 已提交
119

J
Jerome Etienne 已提交
120 121
	var anchorDebugUI = new ARjs.AnchorDebugUI(arjsAnchor)
	document.querySelector('#arjsDebugUIContainer').appendChild(anchorDebugUI.domElement)		
J
Jerome Etienne 已提交
122 123
}

J
Jerome Etienne 已提交
124 125 126
//////////////////////////////////////////////////////////////////////////////
//		Code Separator
//////////////////////////////////////////////////////////////////////////////
J
Jerome Etienne 已提交
127 128

// function initRenderThreejs
J
Jerome Etienne 已提交
129
PortableARjs.prototype._initOptionRenderThreejs = function(renderer, scene, camera, arjsAnchor){
J
Jerome Etienne 已提交
130 131 132
	// array of functions for the rendering loop
	var onRenderFcts= [];

J
Jerome Etienne 已提交
133 134
	var arWorldRoot = arjsAnchor.object3d

J
Jerome Etienne 已提交
135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183
	//////////////////////////////////////////////////////////////////////////////////
	//		add an object in the scene
	//////////////////////////////////////////////////////////////////////////////////
	
	// add a torus knot	
	var geometry	= new THREE.CubeGeometry(1,1,1)
	var material	= new THREE.MeshNormalMaterial({
		transparent : true,
		opacity: 0.5,
		side: THREE.DoubleSide
	}) 
	var mesh	= new THREE.Mesh( geometry, material )
	mesh.position.y	= geometry.parameters.height/2
	arWorldRoot.add( mesh )
	
	var geometry	= new THREE.TorusKnotGeometry(0.3,0.1,64,16)
	var material	= new THREE.MeshNormalMaterial() 
	var mesh	= new THREE.Mesh( geometry, material )
	mesh.position.y	= 0.5
	arWorldRoot.add( mesh )
	
	onRenderFcts.push(function(delta){
		mesh.rotation.x += Math.PI*delta
	})
	
	//////////////////////////////////////////////////////////////////////////////////
	//		render the whole thing on the page
	//////////////////////////////////////////////////////////////////////////////////
	
	if( true ){
		document.body.appendChild( renderer.domElement )
		onRenderFcts.push(function(){
			renderer.render( scene, camera )
		})		
	}

	// run the rendering loop
	var lastTimeMsec= null
	requestAnimationFrame(function animate(nowMsec){
		// keep looping
		requestAnimationFrame( animate )
		// measure time
		lastTimeMsec	= lastTimeMsec || nowMsec-1000/60
		var deltaMsec	= Math.min(200, nowMsec - lastTimeMsec)
		lastTimeMsec	= nowMsec
		// call each update function
		onRenderFcts.forEach(function(onRenderFct){
			onRenderFct(deltaMsec/1000, nowMsec/1000)
		})
J
Jerome Etienne 已提交
184
	})	
J
Jerome Etienne 已提交
185
}