Three.js中AR实现详解并详细介绍基于图像标记模式AR生成的详细步骤

news2025/6/9 6:58:41

文档地址

Three.js中AR实现详解

以下是Three.js中实现AR功能的详细解析,涵盖技术原理、实现步骤、核心组件及优化策略:

🧩 一、技术基础

AR.js框架的核心作用

AR.js是Three.js实现AR的基石,提供以下核心能力:

  • 多模式追踪:支持图像标记(Pattern Marker)自然特征(NFT)地理位置(Location Based)平面检测(WebXR)。

  • 跨平台性:基于WebGL和WebRTC,兼容iOS/Android/PC主流浏览器,无需安装插件。

  • 轻量化:核心库仅200KB(gzip压缩),渲染效率达60fps。

Three.js与AR.js的协作关系

Three.js负责3D场景渲染,AR.js处理现实世界追踪与虚拟对象对齐:
在这里插入图片描述

⚙️ 二、实现步骤详解

步骤1:环境搭建

引入依赖库

      <!-- 使用A-Frame简化开发(推荐) -->
   <script src="https://aframe.io/releases/1.4.0/aframe.min.js"></script>
   <script src="https://raw.githack.com/AR-js-org/AR.js/master/aframe/build/aframe-ar.js"></script>
   
   <!-- 或Three.js原生集成 -->
   <script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/r128/three.min.js"></script>
   <script src="https://raw.githack.com/AR-js-org/AR.js/master/three.js/build/ar.js"></script>

启动本地服务器

   使用http-server避免跨域问题:
      npm install -g http-server
   http-server -o

步骤2:标记生成与模型准备

创建图像标记(.patt文件)

工具:https://jeromeetienne.github.io/AR.js/three.js/examples/marker-training/examples/generator.html

要求:正方形PNG(≥512×512),高对比度+非对称图案(示例:)

操作:上传图像 → 设置Pattern Ratio=0.7 → 下载.patt文件
准备3D模型

格式:GLTF(支持动画/PBR材质)或OBJ

优化:面数≤10万三角面,纹理≤2MB

工具:Blender建模或https://sketchfab.com/下载免费模型

步骤3:场景集成

方案A:A-Frame声明式开发(快速入门)

<a-scene embedded arjs>
  <a-marker 
    type="pattern" 
    url="assets/marker.patt"    <!-- 替换为你的.patt路径 -->
<a-entity 

      gltf-model="assets/model.glb" 
      scale="0.5 0.5 0.5"
      position="0 0.5 0"       <!-- 模型悬浮高度 -->
    ></a-entity>
  </a-marker>
  <a-entity camera></a-entity>
</a-scene>

方案B:Three.js编程式开发(灵活控制)

// 初始化场景
const scene = new THREE.Scene();
const camera = new THREE.PerspectiveCamera(60, window.innerWidth/window.innerHeight, 0.1, 100);
scene.add(camera);

// 配置AR追踪
const arToolkitContext = new THREEx.ArToolkitContext({
  cameraParametersUrl: 'https://raw.githubusercontent.com/AR-js-org/AR.js/master/data/data/camera_para.dat',
  detectionMode: 'mono'
});
arToolkitContext.init(() => camera.projectionMatrix.copy(arToolkitContext.getProjectionMatrix()));

// 绑定标记与模型
const markerControls = new THREEx.ArMarkerControls(arToolkitContext, camera, {
  type: 'pattern',
  patternUrl: 'assets/marker.patt'
});
const model = await new GLTFLoader().loadAsync('assets/model.glb');
scene.add(model.scene);

步骤4:交互与动画增强

模型动画控制

     model.animations.forEach(clip => {
     const mixer = new THREE.AnimationMixer(model.scene);
     mixer.clipAction(clip).play();
   });
   
用户交互事件  

      // 点击模型旋转
   window.addEventListener('click', () => {
     raycaster.setFromCamera(mouse, camera);
     const intersects = raycaster.intersectObject(model.scene);
     if (intersects.length) model.scene.rotation.y += Math.PI/2;
   });
   

🚀 三、核心优化策略

在这里插入图片描述

🌐 四、应用场景案例

  • 教育领域

生物课本叠加3D细胞模型(NFT自然特征追踪)

  • 电商展示

-家具AR预览(WebXR平面检测 + 物理碰撞模拟)

  • 工业维修

设备拆解指引(多标记协同定位 + 交互动画)

💎 总结

在这里插入图片描述

完整项目示例参考:https://github.com/AR-js-org/AR.js 或 https://aframe.io/blog/webvr-ar-js/


在这里插入图片描述

图像标记模式patt文件生成详解

以下是利用一张图片生成 .patt 文件并关联三维模型的完整步骤详解,结合 AR.js 框架和 3D 模型处理技术实现:

🔧 一、原理简述

.patt 是 AR.js 的图像标记模式文件,通过识别物理图像(如打印的标记图)触发 AR 内容。流程分三步:

  1. 图像预处理 → 生成 .patt 文件
  2. 3D 模型准备 → 导出兼容格式(如 GLTF、OBJ)
  3. AR 场景集成 → 将模型绑定到标记

✅ 技术栈:AR.js(图像识别) + Three.js(3D 渲染)

🖼️ 二、详细步骤

步骤 1:准备源图像(生成 .patt 的关键)

在这里插入图片描述

步骤 2:生成 .patt 文件

访问在线工具:https://jeromeetienne.github.io/AR.js/three.js/examples/marker-training/examples/generator.html
在这里插入图片描述

步骤 3:准备 3D 模型

模型来源(三选一):
自定义建模:
在这里插入图片描述

步骤 4:集成到 AR.js 场景

<!DOCTYPE html>
<script src="https://aframe.io/releases/1.4.0/aframe.min.js"></script>
<script src="https://raw.githack.com/AR-js-org/AR.js/master/aframe/build/aframe-ar.js"></script>
<body>
  <a-scene embedded arjs="trackingMethod: best;">
    <!-- 绑定 .patt 文件 -->
    <a-marker 
      type="pattern" 
      url="path/to/your-pattern.patt"  <!-- 替换为你的 .patt 路径 -->
<!-- 关联 3D 模型 -->

      <a-entity 
        gltf-model="path/to/model.glb" 
        scale="0.5 0.5 0.5"
        position="0 0.5 0"  <!-- 模型悬浮高度 -->
      ></a-entity>
    </a-marker>
    <a-entity camera></a-entity>
  </a-scene>
</body>

⚠️ 关键配置:

  • trackingMethod: best:自动选择最佳追踪模式(优先 WebXR)

  • 必须 HTTPS 环境(Chrome 要求摄像头权限)

⚙️ 三、调试与优化技巧

在这里插入图片描述

高级功能扩展
  • 多标记互动:

    <a-marker type="pattern" url="marker1.patt">...</a-marker>
    

  • 事件交互(点击模型触发动画):

      AFRAME.registerComponent('click-handler', {
    init: function () {
      this.el.addEventListener('click', () => {
        this.el.setAttribute('animation', 'property: rotation; to: 0 360 0; loop: true');
      });
});
  • 光照适配:

    <a-entity light="type: ambient; intensity: 0.8"></a-entity>
    

💎 四、工具与资源汇总
在这里插入图片描述

🌟 最佳实践:

  • 打印标记时使用 哑光材质纸张(减少反光干扰)

  • 复杂场景优先用 GLTF 格式(支持动画、PBR材质)

  • 调试工具:Chrome 手机模拟器 + AR.js 控制台日志

通过以上步骤,即可实现从图片生成 .patt 到关联 3D 模型的完整 AR 体验。深入技术细节可参考
https://ar-js-org.github.io/AR.js-Docs/。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2405080.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

GeoBoundaries下载行政区划边界数据(提供中国资源shapefile)

要下载山东省济南市各个区的行政区划边界数据&#xff0c;你可以通过 geoBoundaries 提供的数据来实现。下面是详细步骤&#xff0c;包括网页操作和可选的 Python 自动化方式。 目录 ✅ 一、通过 geoBoundaries 官网手动下载1. 打开官网&#xff1a;2. 查找中国数据&#xff1a…

大模型如何选型?嵌入模型如何选型?

欢迎来到啾啾的博客&#x1f431;。 记录学习点滴。分享工作思考和实用技巧&#xff0c;偶尔也分享一些杂谈&#x1f4ac;。 有很多很多不足的地方&#xff0c;欢迎评论交流&#xff0c;感谢您的阅读和评论&#x1f604;。 目录 引言模型优劣认知与模型选择大模型&#xff08;L…

开源大模型网关:One API实现主流AI模型API的统一管理与分发

以下是对One API的简单介绍&#xff1a; One API是一个使用go语言开发的大语言模型 API 管理与分发系统支持Docker一键快速部署&#xff0c;且资源占用小&#xff0c;高性能开箱支持多平台大模型快速接入&#xff0c;包括OpenAI、Gemini、xAI、Grop、Anthropic Claude、Ollama…

智慧充电:新能源汽车智慧充电桩的发展前景受哪些因素影响?

全球能源结构转型与碳中和目标的推进&#xff0c;新能源汽车产业迎来爆发式增长&#xff0c;而智慧充电桩作为其核心基础设施&#xff0c;发展前景备受关注。智慧充电不仅关乎用户充电体验的优化&#xff0c;更是电网平衡、能源效率提升的关键环节。 然而&#xff0c;其发展并…

【网站建设】不同类型网站如何选择服务器?建站项目实战总结

做了几个建站项目后,深刻体会到一件事:不同类型的网站,所采用的服务器策略是完全不同的。 如果选错了服务器方案,可能带来过高的成本、过低的性能,甚至上线失败。 这篇文章分享一下我在实战中的经验,供正在做建站项目的朋友参考。 🚩 1️⃣ 纯展示型网站 —— 静态服务…

iptables实验

实验一&#xff1a;搭建web服务&#xff0c;设置任何人能够通过80端口访问。 1.下载并启用httpd服务器 dnf -y install httpd 开启httpd服务器 systemctl start httpd 查看是否启用 下载并启用iptables&#xff0c;并关闭firewalld yum install iptable…

前后端分离开发 和 前端工程化

来源&#xff1a;黑马程序员JavaWeb开发教程&#xff0c;实现javaweb企业开发全流程&#xff08;涵盖SpringMyBatisSpringMVCSpringBoot等&#xff09;_哔哩哔哩_bilibili 前后端混合开发&#xff1a; 需要使用前端的技术栈开发前端的功能&#xff0c;又需要使用Java的技术栈…

web端rtmp推拉流测试、抽帧识别计数,一键式生成巡检报告

本文旨在实现无人机城市交通智慧巡检中的一个模块——无人机视频实时推拉流以及识别流并在前端展示&#xff0c;同时&#xff0c;统计目标数量以及违停数量&#xff0c;生成结果评估&#xff0c;一并发送到前端展示。对于本文任何技术上的空缺&#xff0c;可在博主主页前面博客…

Excel 表格内批量添加前缀与后缀的实用方法

我们经常需要为 Excel 表格中的内容统一添加前缀或后缀&#xff0c;例如给编号加“NO.”、给姓名加“会员_”等。手动操作效率低&#xff0c;本文将介绍几种实用的方法&#xff0c;帮助你快速完成批量添加前缀和后缀的操作。 使用“&”运算符添加前缀或后缀&#xff08;推…

2024 CKA题库+详尽解析| 15、备份还原Etcd

目录 免费获取题库配套 CKA_v1.31_模拟系统 15、 备份还原Etcd 题目&#xff1a; 开始操作: 1&#xff09;、切换集群 2&#xff09;、登录master并提权 3&#xff09;、备份Etcd现有数据 4&#xff09;、验证备份数据快照 5&#xff09;、查看节点和Pod状态 6&am…

西门子 S7-1200 PLC 海外远程运维技术方案

西门子 S7-1200 PLC 海外远程运维技术方案 一、面向海外场景的核心优势 针对跨国企业、海外项目及远程技术支持需求&#xff0c;本方案基于巨控GRM552Y-CHE模块提供无缝的全球化远程PLC运维能力&#xff0c;突破地域及时差限制&#xff0c;显著提升国际项目响应效率。 二、海…

嵌入式学习--江协stm32day5

USART 1. 引脚与接口层 异步引脚&#xff1a; TX&#xff1a;发送数据输出&#xff1b;RX&#xff1a;接收数据输入&#xff1b;SW_RX&#xff1a;单线半双工模式的接收引脚&#xff08;替代 RX&#xff09;。 同步引脚&#xff1a;SCLK&#xff1a;同步模式下的时钟输出&…

(LeetCode 动态规划(基础版))96. 不同的二叉搜索树 (递推 || 递归)

题目&#xff1a;96. 不同的二叉搜索树 思路&#xff1a;二叉树长度为n时&#xff0c;枚举每个点u作为根节点root&#xff0c;那么root左边的数构成左子树种数left&#xff0c;root右边的数构成右子树种数right&#xff0c;那么当前u为根节点下&#xff0c;二叉树的种数为left*…

vue项目使用svg图标

下面是在 Vue 3 项目中完整引入和使用 vite-plugin-svg-icons 的步骤 1、安装插件 npm install vite-plugin-svg-icons -D # 或 yarn add vite-plugin-svg-icons -D # 或 pnpm add vite-plugin-svg-icons -D 2、配置 Vite 在 vite.config.ts 或 vite.config.js 中配置&…

智能网卡之hinic3 WQE(Work Queue Element)结构梳理

hinic3 WQE&#xff08;Work Queue Element&#xff09;结构详解 本文基于 hinic3 驱动源码&#xff0c;对 WQE&#xff08;Work Queue Element&#xff09;做详细讲解。如需查阅完整源码和结构体定义可参考hinic3_nic_qp.h等文件。 1. WQE 的作用 WQE&#xff08;Work Queue…

力扣HOT100之二分查找:4. 寻找两个正序数组的中位数

这道题如果没有时间复杂度的限制的话&#xff0c;相当好做&#xff0c;但是这道题要求时间复杂度为O(log(m n))&#xff0c;思路很难想&#xff0c;我看了一圈题解&#xff0c;发现华南溜达虎的视频讲得还不错&#xff0c;我是参考他的思路写出来的&#xff0c;这里把他的思路…

PyTorch——损失函数与反向传播(8)

Loss Functions 越小越好 L1loss MSELoss 损失函数 CrossEntyopyLoss 损失函数 import torch from torch.nn import L1Loss from torch import nn# 创建输入和目标张量&#xff0c;用于后续的损失计算 inputs torch.tensor([1,2,3],dtypetorch.float32) targets torch.tenso…

macOS 升级 bash 到最新版本

macOS 的默认「终端」&#xff0c;千年不变的版本。 》〉bash --version GNU bash, version 3.2.57(1)-release (arm64-apple-darwin24) Copyright (C) 2007 Free Software Foundation, Inc. 官方 bash.git - bash 已经将 bash 升级到了 5.2的大版本。 macOS 最新版系统的 ba…

力扣面试150题--课程表

Day 63 题目描述 做法 初次思路&#xff1a;本质就是将所有前置课程和后置课程作为一个有向图&#xff08;前者指向后者&#xff09;&#xff0c;判断这个图是否是一个有向无环图&#xff08;即是否存在拓扑排序&#xff09;&#xff08;本质做法是dfs&#xff09; 做法&…

用通俗的话解释下MCP是个啥?

在AI领域&#xff0c;模型的开发、部署和迭代速度日益加快&#xff0c;但随之而来的挑战也愈发显著&#xff1a;如何高效管理不同版本的模型&#xff1f;如何在复杂环境中确保模型的可追溯性和可复用性&#xff1f;如何实现跨团队、跨平台的模型协作&#xff1f; 在计算机领域…