提交 57b35c5c 编写于 作者: J Jerome Etienne

more owkr

上级 1a681527
<meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
<!-- three.js library -->
<script src='../../vendor/three.js/build/three.js'></script>
<script src='js/threex-augmentedwebpages.js'></script>
......
......@@ -74,7 +74,7 @@ function updateArAppURL(){
// build url
// FIXME pass from relative to absolute url in a better way
// urlOptions.arAppURL = location.protocol + '//' + location.host + location.pathname.replace(/[^\/]*$/, '') + '../vendor/ar.js/three.js/examples/augmented-website/examples/screenAsPortal/index.html'
urlOptions.arAppURL = location.protocol + '//' + location.host + location.pathname.replace(/[^\/]*$/, '') + 'examples/screenAsPortal/index.html'
urlOptions.arAppURL = location.protocol + '//' + location.host + location.pathname.replace(/[^\/]*$/, '') + '../screenAsPortal/index.html'
}
//////////////////////////////////////////////////////////////////////////////
......
<!DOCTYPE html>
<meta name='viewport' content='width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0'>
<!-- three.js library -->
<script src='../../../vendor/three.js/build/three.js'></script>
<script src='../../../vendor/three.js/examples/js/libs/stats.min.js'></script>
<script src='../vendor/three.js/build/three.js'></script>
<script src='../vendor/three.js/examples/js/libs/stats.min.js'></script>
<!-- jsartookit -->
<script src='../../../../vendor/jsartoolkit5/build/artoolkit.min.js'></script>
<script src='../../../../vendor/jsartoolkit5/js/artoolkit.api.js'></script>
<script src='../../vendor/jsartoolkit5/build/artoolkit.min.js'></script>
<script src='../../vendor/jsartoolkit5/js/artoolkit.api.js'></script>
<!-- aruco -->
<script src='../../../../vendor/js-aruco/src/svd.js'></script>
<script src='../../../../vendor/js-aruco/src/posit1.js'></script>
<script src='../../../../vendor/js-aruco/src/cv.js'></script>
<script src='../../../../vendor/js-aruco/src/aruco.js'></script>
<script src='../../../../threex/threex-aruco/threex-arucocontext.js'></script>
<script src='../../../../threex/threex-aruco/threex-arucodebug.js'></script>
<script src='../../vendor/js-aruco/src/svd.js'></script>
<script src='../../vendor/js-aruco/src/posit1.js'></script>
<script src='../../vendor/js-aruco/src/cv.js'></script>
<script src='../../vendor/js-aruco/src/aruco.js'></script>
<script src='../../threex/threex-aruco/threex-arucocontext.js'></script>
<script src='../../threex/threex-aruco/threex-arucodebug.js'></script>
<!-- include threex.artoolkit -->
<script src='../../../../threex-artoolkitsource.js'></script>
<script src='../../../../threex-artoolkitcontext.js'></script>
<script src='../../../../threex-artoolkitprofile.js'></script>
<script src='../../../../threex-arbasecontrols.js'></script>
<script src='../../../../threex-armarkercontrols.js'></script>
<script src='../../../../threex-armarkerhelper.js'></script>
<script src='../../../../threex-arsmoothedcontrols.js'></script>
<script>THREEx.ArToolkitContext.baseURL = '../../../../'</script>
<script src='../../../multi-markers/threex-armultimarkercontrols.js'></script>
<script src='../../../multi-markers/threex-armultimarkerlearning.js'></script>
<script src='../../threex-artoolkitsource.js'></script>
<script src='../../threex-artoolkitcontext.js'></script>
<script src='../../threex-artoolkitprofile.js'></script>
<script src='../../threex-arbasecontrols.js'></script>
<script src='../../threex-armarkercontrols.js'></script>
<script src='../../threex-armarkerhelper.js'></script>
<script src='../../threex-arsmoothedcontrols.js'></script>
<script>THREEx.ArToolkitContext.baseURL = '../../'</script>
<script src='../multi-markers/threex-armultimarkercontrols.js'></script>
<script src='../multi-markers/threex-armultimarkerlearning.js'></script>
<script src='js/threex-screenasportal.js'></script>
......@@ -45,7 +45,7 @@
<a href='javascript:void(0)' onclick='toggleMarkerHelper()'>marker helper : <span id='markerHelpersStatus'></span></a>
</div>
<div style='position: fixed; bottom: 16px; right: 16px; z-index:1';>
<img id='recordButton' src="../../../multi-markers/examples/images/record-start.png" width='64px' height='64px'>
<img id='recordButton' src="../multi-markers/examples/images/record-start.png" width='64px' height='64px'>
</div>
<script>
......
......@@ -58,8 +58,6 @@ function onDeviceMotion(event) {
gravity.y = event.accelerationIncludingGravity.y - event.acceleration.y
gravity.z = event.accelerationIncludingGravity.z - event.acceleration.z
document.querySelector('#gravityLength').innerHTML = gravity.length().toFixed(2)
}
window.addEventListener("devicemotion", onDeviceMotion, true);
......
<!DOCTYPE html>
<meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
<!-- three.js library -->
<script src='vendor/three.js/build/three.min.js'></script>
<body style='margin : 0px; overflow: hidden; font-family: Monospace;'><div style='position: absolute; top: 10px; width:100%; text-align: center; z-index: 1;'>
<a href="https://github.com/jeromeetienne/AR.js/" target="_blank">AR.js</a> - three.js camera transform
<br/>
Contact me any time at <a href='https://twitter.com/jerome_etienne' target='_blank'>@jerome_etienne</a>
</div><script>
//////////////////////////////////////////////////////////////////////////////////
// Init
//////////////////////////////////////////////////////////////////////////////////
// init renderer
var renderer = new THREE.WebGLRenderer({
antialias: true,
alpha: true
});
renderer.setSize( window.innerWidth, window.innerHeight );
renderer.domElement.style.position = 'absolute'
renderer.domElement.style.top = '0px'
renderer.domElement.style.left = '0px'
document.body.appendChild( renderer.domElement );
// array of functions for the rendering loop
var onRenderFcts= [];
// init scene and camera
var scene = new THREE.Scene();
//////////////////////////////////////////////////////////////////////////////////
// Initialize a basic camera
//////////////////////////////////////////////////////////////////////////////////
// Create a camera
var camera = new THREE.PerspectiveCamera( 23*2, window.innerWidth / window.innerHeight, 0.01, 100 );
camera.position.z = 4;
window.addEventListener( 'resize', function() {
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
renderer.setSize( window.innerWidth, window.innerHeight );
}, false );
//////////////////////////////////////////////////////////////////////////////////
// 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 meshCube = new THREE.Mesh( geometry, material );
scene.add( meshCube );
meshCube.add( new THREE.AxisHelper() )
var geometry = new THREE.TorusKnotGeometry(0.3,0.1,64,16);
var material = new THREE.MeshNormalMaterial();
var mesh = new THREE.Mesh( geometry, material );
meshCube.add( mesh );
onRenderFcts.push(function(delta){
mesh.rotation.x += Math.PI*delta
})
window.addEventListener("deviceorientation", function onDeviceOrientation(event) {
var deviceEuler = new THREE.Euler()
deviceEuler.x = event.beta / 180 * Math.PI
deviceEuler.y = event.gamma / 180 * Math.PI
deviceEuler.z = event.alpha / 180 * Math.PI
deviceEuler.order = "XZY"
var controllerQuaternion = new THREE.Quaternion().setFromEuler(deviceEuler).inverse()
meshCube.quaternion.copy(controllerQuaternion)
});
// window.addEventListener("deviceorientation", function onDeviceOrientation(event) {
// var deviceEuler = new THREE.Euler()
// deviceEuler.x = event.beta / 180 * Math.PI
// deviceEuler.y = event.gamma / 180 * Math.PI
// deviceEuler.z = event.alpha / 180 * Math.PI
// deviceEuler.order = "XZY"
//
// var controllerQuaternion = new THREE.Quaternion().setFromEuler(deviceEuler).inverse()
// meshCube.quaternion.copy(controllerQuaternion)
// });
//
// window.addEventListener("devicemotion", function onDeviceMotion(event) {
// // document.querySelector('#accelerationIncludingGravityX').innerHTML = event.accelerationIncludingGravity.x.toFixed(2)
// // document.querySelector('#accelerationIncludingGravityY').innerHTML = event.accelerationIncludingGravity.y.toFixed(2)
// // document.querySelector('#accelerationIncludingGravityZ').innerHTML = event.accelerationIncludingGravity.z.toFixed(2)
// //
// // document.querySelector('#accelerationX').innerHTML = event.acceleration.x.toFixed(2)
// // document.querySelector('#accelerationY').innerHTML = event.acceleration.y.toFixed(2)
// // document.querySelector('#accelerationZ').innerHTML = event.acceleration.z.toFixed(2)
// //
// // document.querySelector('#gravityX').innerHTML = (event.accelerationIncludingGravity.x - event.acceleration.x).toFixed(2)
// // document.querySelector('#gravityY').innerHTML = (event.accelerationIncludingGravity.y - event.acceleration.y).toFixed(2)
// // document.querySelector('#gravityZ').innerHTML = (event.accelerationIncludingGravity.z - event.acceleration.z).toFixed(2)
// //
// var gravity = new THREE.Vector3()
// gravity.x = event.accelerationIncludingGravity.x - event.acceleration.x
// gravity.y = event.accelerationIncludingGravity.y - event.acceleration.y
// gravity.z = event.accelerationIncludingGravity.z - event.acceleration.z
//
// meshCube.lookAt(gravity)
// });
//////////////////////////////////////////////////////////////////////////////////
// render the whole thing on the page
//////////////////////////////////////////////////////////////////////////////////
// render the scene
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)
})
})
</script></body>
<!DOCTYPE html>
<meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
<!-- three.js library -->
<script src='vendor/three.js/build/three.min.js'></script>
<body style='margin : 0px; overflow: hidden; font-family: Monospace;'><div style='position: absolute; top: 10px; width:100%; text-align: center; z-index: 1;'>
<a href="https://github.com/jeromeetienne/AR.js/" target="_blank">AR.js</a> - three.js camera transform
<br/>
Contact me any time at <a href='https://twitter.com/jerome_etienne' target='_blank'>@jerome_etienne</a>
</div><script>
//////////////////////////////////////////////////////////////////////////////////
// Init
//////////////////////////////////////////////////////////////////////////////////
// init renderer
var renderer = new THREE.WebGLRenderer({
antialias: true,
alpha: true
});
renderer.setSize( window.innerWidth, window.innerHeight );
renderer.domElement.style.position = 'absolute'
renderer.domElement.style.top = '0px'
renderer.domElement.style.left = '0px'
document.body.appendChild( renderer.domElement );
// array of functions for the rendering loop
var onRenderFcts= [];
// init scene and camera
var scene = new THREE.Scene();
//////////////////////////////////////////////////////////////////////////////////
// Initialize a basic camera
//////////////////////////////////////////////////////////////////////////////////
// Create a camera
var camera = new THREE.PerspectiveCamera( 60, window.innerWidth / window.innerHeight, 0.01, 100 );
camera.position.z = 3;
window.addEventListener( 'resize', function() {
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
renderer.setSize( window.innerWidth, window.innerHeight );
}, false );
//////////////////////////////////////////////////////////////////////////////////
// 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 );
scene.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 );
scene.add( mesh );
onRenderFcts.push(function(delta){
mesh.rotation.x += Math.PI*delta
})
//////////////////////////////////////////////////////////////////////////////////
// render the whole thing on the page
//////////////////////////////////////////////////////////////////////////////////
// render the scene
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)
})
})
</script></body>
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册