150行JavaScript代码完成加强实际

加强实际手艺(Augmented Reality,简称 AR),是一种及时地盘算摄影机影象的位置及角度并加上响应图象、视频、3D模子的手艺,这类手艺的目的是在屏幕上把假造天下套在实际天下并举行互动。这类手艺1990年提出。跟着随身电子产品CPU运算才能的提拔,预期加强实际的用处将会愈来愈广。

本文引见运用JavaScript开源框架AR.js完成的加强实际的Hello World例子。

先看结果:

首先在手机浏览器里翻开我布置在github page上的这个demo运用:

https://i042416.github.io/FioriODataTestTool2014/WebContent/098_ar.html

我用的是Android手机装置的Chrome浏览器。

《150行JavaScript代码完成加强实际》

翻开网页,会提醒你是不是许可这个网页运用接见您的手机摄像头。点击许可:

《150行JavaScript代码完成加强实际》

用手机上的摄像头扫描这张图片:

《150行JavaScript代码完成加强实际》

奇异的事变就发生了。您会看到,经由过程手机摄像头望过去,手机屏幕里会涌现一个新的不停转动的3D物体,如下图所示。

《150行JavaScript代码完成加强实际》

下面详细引见这个最简朴的例子是怎样开辟出来的。

一切的源代码在我的github上:

https://github.com/i042416/FioriODataTestTool2014/tree/master/WebContent/ar

新建一个html文件,把以下150行代码粘贴进去,然后在服务器上运转,运用之前形貌的步骤即可举行AR测试:

<!DOCTYPE html>
<meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">

<script src='ar/lib/three.min.js'></script>
<script src="ar/lib/stats.min.js"></script>
<script src="ar/lib/ar.js"></script>

<script>
debugger;
 THREEx.ArToolkitContext.baseURL = '';
</script>
<body style='margin : 0px; overflow: hidden; font-family: Monospace;'>
<div style='position: absolute; top: 10px; width:100%; text-align: center; z-index: 1;'>

<script>

    var renderer    = new THREE.WebGLRenderer({
        // antialias    : true,
        alpha: true
    });
    renderer.setClearColor(new THREE.Color('lightgrey'), 0)
    // renderer.setPixelRatio( 1/2 );
    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();
    
    var camera = new THREE.Camera();
    scene.add(camera);
    
    var arToolkitSource = new THREEx.ArToolkitSource({
        // to read from the webcam 
        sourceType : 'webcam',

        // to read from an image
        // sourceType : 'image',
        // sourceUrl : THREEx.ArToolkitContext.baseURL + '../data/images/img.jpg',        

        // to read from a video
        // sourceType : 'video',
        // sourceUrl : THREEx.ArToolkitContext.baseURL + '../data/videos/headtracking.mp4',        
    })

    arToolkitSource.init(function onReady(){
        onResize()
    })
    
    window.addEventListener('resize', function(){
        onResize()
    })
    function onResize(){
        arToolkitSource.onResize()    
        arToolkitSource.copySizeTo(renderer.domElement)    
        if( arToolkitContext.arController !== null ){
            arToolkitSource.copySizeTo(arToolkitContext.arController.canvas)    
        }    
    }

    var arToolkitContext = new THREEx.ArToolkitContext({
        // cameraParametersUrl: THREEx.ArToolkitContext.baseURL + '../data/data/camera_para.dat',
        cameraParametersUrl: 'ar/data/data/camera_para.dat',
        detectionMode: 'mono',
        maxDetectionRate: 30,
        canvasWidth: 80*3,
        canvasHeight: 60*3,
    })

    arToolkitContext.init(function onCompleted(){
        camera.projectionMatrix.copy( arToolkitContext.getProjectionMatrix() );
    })

    onRenderFcts.push(function(){
        if( arToolkitSource.ready === false )    
            return;
        arToolkitContext.update( arToolkitSource.domElement )
    })
    
    var markerRoot = new THREE.Group
    scene.add(markerRoot)
    var artoolkitMarker = new THREEx.ArMarkerControls(arToolkitContext, markerRoot, {
        type : 'pattern',
        patternUrl : THREEx.ArToolkitContext.baseURL + 'ar/data/data/patt.hiro'
    })

    // build a smoothedControls
    var smoothedRoot = new THREE.Group()
    scene.add(smoothedRoot)
    var smoothedControls = new THREEx.ArSmoothedControls(smoothedRoot, {
        lerpPosition: 0.4,
        lerpQuaternion: 0.3,
        lerpScale: 1,
    })
    onRenderFcts.push(function(delta){
        smoothedControls.update(markerRoot)
    })

    var arWorldRoot = smoothedRoot

    // 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(){
        mesh.rotation.x += 0.1
    })

    var stats = new Stats();
    document.body.appendChild( stats.dom );
    // render the scene
    onRenderFcts.push(function(){
        renderer.render( scene, camera );
        stats.update();
    })

    // 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>

《150行JavaScript代码完成加强实际》

固然,这个结果来自大神jeromeetienne开源的AR.js:

https://github.com/jeromeetienne/AR.js/

固然大神本身也很谦逊地提到,他这个开源的加强实际框架也是建立在伟人的肩膀上开辟的:比方个中3D结果的绘制,运用到了另一个开源框架three.js:

《150行JavaScript代码完成加强实际》

要猎取更多Jerry的原创文章,请关注民众号”汪子熙”:

《150行JavaScript代码完成加强实际》

    原文作者:JerryWangSAP
    原文地址: https://segmentfault.com/a/1190000017901570
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞