IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 【AR.js】使用three.js渲染一个方块 -> 正文阅读

[游戏开发]【AR.js】使用three.js渲染一个方块

说在前面

  • 测试浏览器:Microsoft Edge(PC版本 97.0.1072.55)
  • github库:AR.js
  • AR系列文章:这里
  • go版本:go version go1.17.3 windows/amd64
  • three.js版本:r79(版本比较老)
  • 其他:AR.js支持three.js

效果图

在这里插入图片描述

代码

<!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='/js/three.js'></script>
<!-- ar.js -->
<script src="/js/ar.js"></script>
<script>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;'>

    </div>
    <script>
        //--------------------------------------------------------------------------------
        //		初始化
        //--------------------------------------------------------------------------------

        // 通过three.js初始化webgl渲染器
        var renderer = new THREE.WebGLRenderer({
            antialias: true,
            alpha: true
        });
        renderer.setClearColor(new THREE.Color('lightgrey'), 0)
        renderer.setSize(640, 480);
        renderer.domElement.style.position = 'absolute'
        renderer.domElement.style.top = '0px'
        renderer.domElement.style.left = '0px'
        document.body.appendChild(renderer.domElement);

        // 主渲染循环中使用到的渲染函数
        var onRenderFcts = [];

        // 使用three.js初始化场景
        var scene = new THREE.Scene();

        //--------------------------------------------------------------------------------
        //		初始化相机
        //--------------------------------------------------------------------------------

        // 使用three.js创建一个相机
        var camera = new THREE.Camera();
        scene.add(camera);

        //--------------------------------------------------------------------------------
        //      ar.js初始化
        //--------------------------------------------------------------------------------

        var arToolkitSource = new THREEx.ArToolkitSource({
            // webcam源
            sourceType: 'webcam',
        })

        arToolkitSource.init(function onReady() {
            setTimeout(() => {
                onResize()
            }, 2000);
        })

        // 处理浏览器resize事件
        window.addEventListener('resize', function () {
            onResize()
        })

        // resize回调
        function onResize() {
            arToolkitSource.onResizeElement()
            arToolkitSource.copyElementSizeTo(renderer.domElement)
            if (arToolkitContext.arController !== null) {
                arToolkitSource.copyElementSizeTo(arToolkitContext.arController.canvas)
            }
        }
        //--------------------------------------------------------------------------------
        //      ar.js初始化context
        //--------------------------------------------------------------------------------


        // 创建context
        var arToolkitContext = new THREEx.ArToolkitContext({
            // 设置相机内参
            cameraParametersUrl: THREEx.ArToolkitContext.baseURL + '/assets/camera_para.dat',
            // 设置检测模式为mono,单目(通常指单摄像头)
            detectionMode: 'mono',
        })
        // 初始化
        arToolkitContext.init(function onCompleted() {
            // 将ar context计算的projectionMatrix复制给three.js创建的camera
            // 相当于调整three.js camera的内参
            camera.projectionMatrix.copy(arToolkitContext.getProjectionMatrix());
        })

        // 将以下函数放入渲染队列
        // 该函数的作用应该是将ar context捕获的真实相机数据渲染到web
        onRenderFcts.push(function () {
            if (arToolkitSource.ready === false) return

            arToolkitContext.update(arToolkitSource.domElement)

            // update scene.visible if the marker is seen
            scene.visible = camera.visible
        })

        //--------------------------------------------------------------------------------
        //      使用ar.js创建three.js camera的控制器
        //--------------------------------------------------------------------------------

        // 初始化ar.js控制器
        // 将该控制器绑定到three.js camera
        // 这一步相当于调整相机的外参
        var markerControls = new THREEx.ArMarkerControls(arToolkitContext, camera, {
            // 类型为pattern 标记
            type: 'pattern',
            // 标记数据,用于计算相机外参
            patternUrl: THREEx.ArToolkitContext.baseURL + '/assets/patt.hiro',
            
            changeMatrixMode: 'cameraTransformMatrix'
        })
        // as we do changeMatrixMode: 'cameraTransformMatrix', start with invisible scene
        scene.visible = false

        //--------------------------------------------------------------------------------
        //		在three.js中的场景上添加一个方块
        //--------------------------------------------------------------------------------

        // 添加一个方块
        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
        scene.add(mesh);

        //--------------------------------------------------------------------------------
        //		渲染
        //--------------------------------------------------------------------------------

        // three.js场景渲染
        onRenderFcts.push(function () {
            renderer.render(scene, camera);
        })

        // 递归调用
        var lastTimeMsec = null
        requestAnimationFrame(function animate(nowMsec) {
            requestAnimationFrame(animate);
            // 时间
            lastTimeMsec = lastTimeMsec || nowMsec - 1000 / 60
            var deltaMsec = Math.min(200, nowMsec - lastTimeMsec)
            lastTimeMsec = nowMsec
            // 调用渲染函数
            onRenderFcts.forEach(function (onRenderFct) {
                onRenderFct(deltaMsec / 1000, nowMsec / 1000)
            })
        })
    </script>
</body>

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-01-24 11:15:39  更:2022-01-24 11:17:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 12:49:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码