[转] 增强现实 colAR Mix 浅析

原文: 增强现实 colAR Mix 浅析

在论坛上看到大家对于 colAR Mix 这款增强现实应用是如何实现的很感兴趣。我就从我理解的角度为大家浅析一下。 大家对增强现实的实现原理一定不陌生,利用算法定位环境或物料。这是技术基础,想要将虚拟信息叠加到现实环境或物体上少不了这步。然后我们会试图用许多方式来增强物料与叠加信息的联系,这部分属于交互。比如,视频的第一帧与物料相同,给物体添加阴影,从物料中钻出来等等。再则就是从环境与物料中获取信息与虚拟信息产生交互,比如识别手势。colAR Mix 就属于从物料中提取信息。下面我们就来看看如何实现这一效果吧。

基础知识

纹理坐标与贴图

盗来一张图来简单说明一下,3D 模型在制作贴图的时候都需要将模型展开到平面,在平面上模型每个顶点所对应的坐标就是纹理坐标了。而纹理贴图就是给这个平面上完颜色画完画所生成的图片。那么问题来了,模型展开到平面后样子是不是一定会很纠结呢?答案是纹理坐标是可以调整的,而且在各类 3D 建模软件中展开的方式有许多种。所以 colAR Mix 中得物料图很可能就是物料图片。

Camera-target-patch

翻译过来不知道是不是叫相机物料遮罩,但目的就是想使用相机捕获的画面来做为纹理。这个方法在 AR 中使用的还是很普遍的,比如 Taggar 中的水波纹效果,《东京新闻》中的翻转效果等等。在 vuforia 上翻了翻,以前有一篇文章专门讲这个技术的实现的,现在文章的链接断了看不了,所以只能通过网上零零碎碎的信息弄了。

制作模型

我这里做模型使用了 Blender,这是一款免费的软件,国外用的人比较多。

关于 Blender 的基本操作大家可以到 Youtube 上找视频来看。上图中一个是物体的编辑界面,一个是纹理坐标的编辑界面。为了简单我这边只展开了三个面,并改变成了右面的样子。最后将模型导出成 fbx 文件。

为了不弄错顶点相对应的位置,我弄了一张贴图做测试。这里应该有更方便的方法,不过我 3D 设计没怎么做过,所以只能用笨办法了。

物料制作

由于我们的立方体实在是太简单了(colAR 中的填色图片复杂度足够),如果直接把它作为物料图的话一定识别不了,所以我为它增加了一张图片。

Unity 配置

将我们制作的 fbx 模型导入 Unity 工程,可以把它的 Material 改为 Diffuse,然后把贴图换成我们的物料图试试,看看是否正确。除了我们的模型之外我们还要添加一个透明的平面来标记物料图在哪里,我们将它设置成位置大小与物料图一样。最后的配置如下图。

代码

首先我们修改一下 vuforia 官网上 CameraImageAccess 的代码

========

这里是代码,特喵的复制不过来

========

其中 mPlane 使用配置中的 Quad。这个脚本的作用是获取相机捕捉到的图片并把它作为纹理传给我们的着色器。而我们需要的纹理并不是整个相机捕捉到得画面,所以我们需要用一个 shader 来计算真正的纹理坐标从而获取到正确的纹理。

========

这里是Shader "Custom/CameraTargetPatch"

========

创建一个 material ,将 shader 应用到上面。最后把脚本和 material 都使用到我们的 Cube 上运行代码,看看效果是不是很棒~。

时间: 2024-10-02 10:32:38

[转] 增强现实 colAR Mix 浅析的相关文章

AR拾取纹理功能实现

AR拾取纹理功能实现 最近大家比较关注ColARMix和涂乐等这些应用,作为开发人员吸引大家的就是运行时拾取识别目标纹理,在以线框为识别目标的图片上,用户可以图画颜色,识别之后把涂有色彩的图片作为纹理时时赋给增强对象,让用户图画的颜色体现在增强对象上,看到自己在平面上涂的颜色反应到三维增强对象上.很感谢想到这些创意的牛人们! AR进入中国视线自己就开始关注,不知不觉几年过去了,可能是移动设备硬件的限制,之前两三年的时间一直没有得到很好的发展,随着移动设备硬件的强大支持,越来越多的AR应用走进人们

虚拟现实眼镜(增强现实眼镜)成像原理浅析

首先,本文仅仅介绍市面上现有的普通"头盔+透镜+屏幕"的成像原理,其他(如光场成像等等)暂不作解析,期待后续更新- 如果你明白放大镜的原理,我想这个眼镜的原理你也不难理解了. 虚拟现实眼镜现在的结构一般都是"透镜+屏幕"的成像方式,透镜在眼前2-3cm处,屏幕距透镜3-6cm,虚像成像在眼前25cm-50cm左右.(这就带来了视力疲劳的问题,戴头盔眼镜时,视线将一直持续聚焦在25cm-50cm处,无法移动,并且视野里全部是电子显示屏,时间长后眼部肌肉会极度疲劳,想象

Python之encode与decode浅析

 Python之encode与decode浅析 在 python 源代码文件中,如果你有用到非ASCII字符,则需要在文件头部进行字符编码的声明,声明如下: # code: UTF-8 因为python 只检查 #.coding 和编码字符串,为了美观等原因可以如下写法: #-*-coding:utf-8-*- 常见编码介绍: GB2312编码:适用于汉字处理.汉字通信等系统之间的信息交换. GBK编码:是汉字编码标准之一,是在 GB2312-80 标准基础上的内码扩展规范,使用了双字节编码.

浅析PHP的开源产品二次开发的基本要求

浅析PHP的开源产品二次开发的基本要求 第一, 基本要求:HTML(必须要非常熟悉),PHP(能看懂代码,能写一些小系统,如:留言板,小型CMS),Mysql(至少会一种数据库),Javascript(能看懂,能改现成的一些代码),Div+Css(能进行界面的调整,明白CSS是怎么使用的) 第二, 熟悉开源产品的使用,比如 Dedecms,你要知道怎么登录,怎么新建栏目,怎么添加文章,模板标签的使用方法,模型的概念和使用方法等等一些功能 第三, 要熟悉这个开源产品的数据库结构,还要理解里面核心文

word-break|overflow-wrap|word-wrap——CSS英文断句浅析

---恢复内容开始--- word-break|overflow-wrap|word-wrap--CSS英文断句浅析 一 问题引入 今天在再次学习 overflow 属性的时候,查看效果时,看到如下结果,内容在 div 中国换行了,可是两个 P 元素的内容并没有换行,搜索一番没有找到系统的答案,截图到群里请教大神,才知道是英文断句的问题,但是还是不太明白.之前没有遇到这种情况,为了彻底搞清楚,英文断句,又开始学习英文断句到底是怎么回事. 二 换行 每种语言里都有换行,就中文而言,我们最小语言单位

浅析vanish

浅析 VANISH --一种cache 第一部分:理解vanish的准备工作 1.对CDN的小剖析 CDN  content  delivery  network  内容分发(推送)网络,是在现有的Internet中增加一层新的网络架构,将网络内容发布到最接近用户的网络边缘(边缘服务器),使用户最近取得所需内容,解决网络拥挤状态,提高用户访问网站的速度. CDN网络架构主要有两部分组成,中心和边缘两部分,中心指CDN网管中心和DNS重定向解析中心,负责全局负载均衡.边缘主要指异地节点,CDN分发

健康,home? [java的内存浅析]

健康,home? [java的内存浅析] 摘要: 原创出处: http://www.cnblogs.com/Alandre/ 泥沙砖瓦浆木匠 希望转载,保留摘要,谢谢! 乐观上上,how can other kno u,u r yourself!I must be strong and carry on. -泥沙砖瓦浆木匠 一.闲谈下 201407月记着那时候身体垮了下来,呵呵.想说,对自己的说,也是对大家的负责吧.那时候胸疼胸闷,然后几乎累垮了,我还坚持了一星期,那一星期真的迷迷糊糊.完全不能

Mysql查询优化器浅析

--Mysql查询优化器浅析 -----------------------------2014/06/11 1 定义 Mysql查询优化器的工作是为查询语句选择合适的执行路径.查询优化器的代码一般是经常变动的,这和存储引擎不太一样.因此,需要理解最新版本的查询优化器是如何组织的,请参考相应的源代码.整体而言,优化器有很多相同性,对mysql一个版本的优化器做到整体掌握,理解起mysql新版本以及其他数据库的优化器都是类似的. 优化器会对查询语句进行转化,转化等价的查询语句.举个例子,优化器会将

Volley框架源码浅析(一)

尊重原创http://blog.csdn.net/yuanzeyao/article/details/25837897 从今天开始,我打算为大家呈现关于Volley框架的源码分析的文章,Volley框架是Google在2013年发布的,主要用于实现频繁而且粒度比较细小的Http请求,在此之前Android中进行Http请求通常是使用HttpUrlConnection和HttpClient进行,但是使用起来非常麻烦,而且效率比较地下,我想谷歌正式基于此种原因发布了Volley框架,其实出了Voll