博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mozilla开源了VR框架A-Frame
阅读量:6241 次
发布时间:2019-06-22

本文共 1781 字,大约阅读时间需要 5 分钟。

Mozilla创建并开源了,这是一个用于在桌面浏览器、智能手机和Oculus Rift上创建VR场景的框架。

\\

A-Frame是一个在浏览器中创建VR体验的开源框架。该框架由Mozilla的团队创建和开发。A-Frame使用了一个在游戏开发中经常使用的“实体-组件()”系统,其中,实体是放置在场景中的对象,而组件是与那些实体相关的属性。实体使用HTML标签定义,而组件则基于一种类似CSS语法的HTML属性。实体需要置入一个场景,其中包含了VR中需要渲染的一切内容。

\\

下面的示例代码描绘了一个边长为1米的红盒子实体(立方体):

\\
\u0026lt;a-scene\u0026gt;\   \u0026lt;a-entity geometry=\"primitive: box; width: 1\" material=\"color: red\"\u0026gt;\u0026lt;/a-entity\u0026gt;\\u0026lt;/a-scene\u0026gt;
\\

目前,geometry组件支持下列primitiveboxcirclecylinderplaneringspheretorustorusKnot。其他组件包括:cameralightsoundfogmaterialscale,等等。实体可以关联多个组件创建更复杂的场景,像下面的示例代码这样:

\\
\u0026lt;a-entity geometry=\"primitive: cube; depth: 1; height: 1; width: 1\"\          material=\"color: pink\"\          light=\"intensity: 2\"\          position=\"-1 5 0\"\          sound=\"src: dangerzone.mp3; volume: 2\"\u0026gt;\\u0026lt;/a-entity\u0026gt;
\\

为了简化开发人员的工作,Mozilla封装了一些实体-组件元素,创建了若干语法更简单易用的原语。如下所示,这行代码描绘了与上文相同的正方体:

\\
\u0026lt;a-cube width=\"1\" color=\"red\"\u0026gt;\u0026lt;/a-cube\u0026gt;
\\

预定义的原语包括:a-cameraa-cylindera-planea-spherea-lighta-skya-imagea-video,等等。a-model让开发人员可以在场景中加载OBJ或DAE 3D模型资产。

\\

动画是虚拟现实渲染的重要组成部分。A-Frame内部使用基于规范的。下面的这段代码实现了一个男人的旋转模型:

\\
\u0026lt;a-entity id=\"model\" position=\"0 0 -2\"\u0026gt;\   \u0026lt;a-animation attribute=\"rotation\" from=\"0 -30 0\" to=\"0 330 0\" dur=\"15000\" easing=\"linear\" repeat=\"inifite\"\u0026gt;\u0026lt;/a-animation\u0026gt;\   \u0026lt;a-model position=\"-.35 0 .55\" rotation=\"0 -20 0\" scale=\"1.5 1.5 1.5\" src="../_models/man/man.dae"\u0026gt;\u0026lt;/a-model\u0026gt;\\u0026lt;/a-entity\u0026gt;
\\

A-Frame可以用于主流的桌面浏览器中,场景受鼠标或键盘控制,也可以用于智能手机和Oculus Rift头戴设备上。有个问题是,某些特定的场景在部分Android设备上不能正常渲染,但这个问题很快就会被修复。Mozilla创建了若干展示这项技术的。感兴趣的读者可以从GitHub上下载A-Frame的。

\\

查看英文原文:

转载地址:http://srdia.baihongyu.com/

你可能感兴趣的文章
PHPnow升级PHP 5.4与Mysql 5.5
查看>>
正则表达式验证邮箱格式
查看>>
如何围绕企业战略,建设BI驾驶舱?
查看>>
java多线程stop,suspend使用代码实际例子
查看>>
中小型研发团队架构实践三:微服务架构(MSA)
查看>>
Windows动态库学习心得
查看>>
在VMware虚拟机上安装Ubuntu 10.04
查看>>
LDA主题模型简介
查看>>
可拖动的DIV续
查看>>
关于“类型初始值设定项引发异常”
查看>>
MySql 小表驱动大表
查看>>
Redis 数据结构的底层实现 (一) RealObject,embstr,sds,ziplist,quicklist
查看>>
SQL语句注入的问题
查看>>
jQueryEasyUI Messager基本使用
查看>>
【C语言学习趣事】_33_关于C语言和C++语言中的取余数(求模)的计算_有符号和无符号数的相互转换问题...
查看>>
Tensorboard教程:显示计算图中节点信息
查看>>
java 线程基本概念 可见性 同步
查看>>
Java:JUnit包
查看>>
unity_快捷键
查看>>
洛谷P3358 最长k可重区间集问题(费用流)
查看>>