又到了周末的时间,依旧的例牌菜。只是近期在和一些同事交流下,学习了一些新的知识。过去一直没有明确的问题,如今总算有点感觉了。
平时编程偶然会用到数学,特别是在做3d的时候。相信看过rokix的3d,那种震撼感染力到了如今还是存在。
为什么?由于rokix将flash 用得非常熟练,虽然如今的3d引擎已经能够满足了非常多功能,也是能够实现到当年rokix的效果,只是那份创意和精髓还是非常须要经验的积累。
flash 10 后新增了高级的画图API,一直非常少使用,只是当发现用上去。还是非常不错。有人说flash3d 已经阵忙得差点儿相同,unity3d 取缔它。
站在好玩角度。个人还是选择flash,由于比較熟悉。
unity3d 的坑还是存在非常深。所以说。原理还是非常重要。
当你使用过3dmax的时候,会导出一种叫obj格式文件。这个格式记录了顶点,法线。纹理信息和顶点,uv等索引相关的信息。
有了它,我们就能够尝试做一些实验来解析它。as3提供了高级的画图API。有了GraphicsTrianglePath 的这种方法,解析3d 导出的文件格式就能实现出来了。并且还是非常好玩。
以下 是经过3dmax 导出的 长方体模型,v 代表顶点,vn代表法线。vt 代表纹理坐标。即uv ,f 则是顶点索引。uv索引、法线索引。
v 顶点,代表空间坐标的3个坐标点(x,y,z);
这个还是比較easy理解,
以下f 的结构,
1/1/1 2/2/1 3/3/1 (顶点索引。纹理索引。法线索引)
生成的文件。他们的关系是有序的,索引不能任意调换位置。
知道了这些,解析就变得easy多了。
以下就针对obj格式来解析我们想要的数据就可以。例牌菜使用urlloader 进行读取文本方式解析以下的格式。
var urlLoader:URLLoader = new URLLoader();
urlLoader.addEventListener(Event.COMPLETE,onLoadComplete);
urlLoader.dataFormat = URLLoaderDataFormat.TEXT;
urlLoader.load(new URLRequest("cube.obj"));
GraphicsTrianglePath 參数里面,仅仅是须要四个參数,而obj 给我们提供的数据,仅仅是须要顶点坐标,uv贴图数据,等就可以。 有了这个数据后,我们读取的模型就能通过这个函数来创建显示出来。
当然以下的图并没有真正的贴图数据,并且还是不对,只是有了这个基础后。我们就能够对这个文件进行加工。获取我们想要的数据进行拼装。
而基本上 满足了这些參数下,一个基本模型就能呈现到屏幕下去。
当然你看到以下的图也是在实验的过程其中,呈现出来,可是离真正的3d 还是逊色不少。可是对眼下项目而已stage3d 基本上能够满足了,仅仅是stage3d 在硬件兼容性上 还多少出现故障。导致奇奇怪怪的问题。有了这个基础后。对解析obj 文件。就有进一步的玩法了。
= null, uvtData:Vector.<Number> = null, culling:String = "none")
IAO
# 3ds Max Wavefront OBJ Exporter v0.97b - (c)2007 guruware
# 创建的文件:22.05.2014 14:35:13 mtllib cube.mtl #
# object Box01
# v -22.9110 0.0000 31.5364
v -22.9110 0.0000 -32.0755
v 32.6146 0.0000 -32.0755
v 32.6146 0.0000 31.5364
v -22.9110 60.9164 31.5364
v 32.6146 60.9164 31.5364
v 32.6146 60.9164 -32.0755
v -22.9110 60.9164 -32.0755
# 8 vertices vn 0.0000 -1.0000 -0.0000
vn 0.0000 1.0000 -0.0000
vn 0.0000 0.0000 1.0000
vn 1.0000 0.0000 -0.0000
vn 0.0000 0.0000 -1.0000
vn -1.0000 0.0000 -0.0000
# 6 vertex normals vt 0.7029 0.6461 0.0000
vt 0.3680 0.6461 0.0000
vt 0.3680 0.3539 0.0000
vt 0.7029 0.3539 0.0000
vt 0.3680 0.3023 0.0000
vt 0.3680 0.0100 0.0000
vt 0.7029 0.0100 0.0000
vt 0.7029 0.3023 0.0000
vt 0.0100 0.9900 0.0000
vt 0.0100 0.6977 0.0000
vt 0.3307 0.6977 0.0000
vt 0.3307 0.9900 0.0000
vt 0.3448 0.6745 0.0000
vt 0.0100 0.6745 0.0000
vt 0.0100 0.3539 0.0000
vt 0.3448 0.3539 0.0000
vt 0.3680 0.9694 0.0000
vt 0.3680 0.6771 0.0000
vt 0.6887 0.6771 0.0000
vt 0.6887 0.9694 0.0000
vt 0.3448 0.3307 0.0000
vt 0.0100 0.3307 0.0000
vt 0.0100 0.0100 0.0000
vt 0.3448 0.0100 0.0000
# 24 texture coords g Box01
usemtl 01___Default
s 2
f 1/1/1 2/2/1 3/3/1
f 3/3/1 4/4/1 1/1/1
s 4
f 5/5/2 6/6/2 7/7/2
f 7/7/2 8/8/2 5/5/2
s 8
f 1/9/3 4/10/3 6/11/3
f 6/11/3 5/12/3 1/9/3
s 16
f 4/13/4 3/14/4 7/15/4
f 7/15/4 6/16/4 4/13/4
s 32
f 3/17/5 2/18/5 8/19/5
f 8/19/5 7/20/5 3/17/5
s 64
f 2/21/6 1/22/6 5/23/6
f 5/23/6 8/24/6 2/21/6
# 12 faces
flash画图API:解析obj格式的更多相关文章
-
Obj格式解析以及在Unity3D下导入测试
目前基本实现了导入,注意只能打开含有单个模型的obj文件 四边面模型: 全三角面模型(测试单一材质,自动分了下UV): 这里介绍下obj格式: obj格式是waveFront推出的一种3D模型格式,可 ...
-
CSharpGL(9)解析OBJ文件并用CSharpGL渲染
CSharpGL(9)解析OBJ文件并用CSharpGL渲染 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立的Demo ...
-
java微信开发API解析(二)-获取消息和回复消息
java微信开发API解析(二)-获取消息和回复消息 说明 * 本演示样例依据微信开发文档:http://mp.weixin.qq.com/wiki/home/index.html最新版(4/3/20 ...
-
源生API解析XML文档与dom4j解析XML文档
一.XML语言 XML是一种可扩展的标记语言,是一种强类型的语言,类似HTML(超文本标记语言,是一种弱类型的语言).XML是一种通用的数据交换格式(关系型数据库),综上所诉:XML可以传输数据,也可 ...
-
urlparse模块(专门用来解析URL格式)
# -*- coding: utf-8 -*- #python 27 #xiaodeng #urlparse模块(专门用来解析URL格式) #URL格式: #protocol ://hostname[ ...
-
Android中解析XML格式数据的方法
XML介绍:Extensible Markup Language,即可扩展标记语言 一.概述 Android中解析XML格式数据大致有三种方法: SAX DOM PULL 二.详解 2.1 SAX S ...
-
Scala解析Json格式
Scala解析Json格式 代码块 Scala原生包 导入包 import scala.util.parsing.json._ def main(args: Array[String]): Unit ...
-
JavaScript 对象所有API解析【2020版】
JavaScript 对象所有API解析[2020版] 写于 2019年08月20日,虽然是2019年写的文章,但现在2020年依旧不过时,现在补充了2019年新增的ES10 Object.fromE ...
-
WP8解析JSON格式(使用DataContractJsonSerializer类)(推荐)
DataContractJsonSerializer是.NET自带的类,在解析JSON格式的时候使用起来方便快捷,至于生成方面由于暂时没用到就没去看了.使用需要引用System.Runtime.Ser ...
随机推荐
-
block
不使用__block修饰: ; self.myBlock = ^(){ NSLog(@"block num == %d",num); }; num = ; self.myBlock ...
-
MIT 6.828 JOS学习笔记17. Lab 3.1 Part A User Environments
Introduction 在这个实验中,我们将实现操作系统的一些基本功能,来实现用户环境下的进程的正常运行.你将会加强JOS内核的功能,为它增添一些重要的数据结构,用来记录用户进程环境的一些信息:创建 ...
-
C语言中不同函数之间怎么传值?
#include <stdio.h> int change(); int change(int j) { j=; return(j); } void main() { int b = ch ...
-
soinn
Growing Cell Structures A Self-Organizing Network for Unsupervised and Supervised Learning Here, and ...
-
深入理解Java的接口和抽象类 _摘抄
http://www.cnblogs.com/dolphin0520/p/3811437.html 原文 深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可 ...
-
ES6数字扩展
前面的话 本文将详细介绍ES6数字扩展 指数运算符 ES2016引入的唯一一个JS语法变化是求幂运算符,它是一种将指数应用于基数的数学运算.JS已有的Math.pow()方法可以执行求幂运算,但它也是 ...
-
201521123033《Java程序设计》第6周学习总结
1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. 注1:关键词与内容不求多,但概念之间的联系要清晰,内容覆盖 ...
-
float是什么样式?
什么是float样式? 让标签浮动起来,总体方向往上 right,left(右浮,左浮) 联合height,width使用,分别占用y方向和x方向多少,单位px或百分比(%) 作用对象不是页面,而是作 ...
-
[HNOI2014]画框
题目描述 小T准备在家里摆放几幅画,为此他买来了N幅画和N个画框.为了体现他的品味,小T希望能合理地搭配画与画框,使得其显得既不过于平庸也不太违和. 对于第 幅画与第 个画框的配对,小T都给出了这个配 ...
-
VUE+webpack+npm项目中的RSA加解密
一.安装jsencrypt npm i jsencrypt node_modules文件夹中出现jsencrypt 二.引入jsencrypt 在main.js中import: import JsEn ...