Posted on 2008-12-14 21:03
Condor 阅读(2190)
评论(1) 编辑 收藏 引用
前言
目前这个引擎只是一个预览版, 很多功能仍在开发当中
硬件需求: 显卡支持ShaderModel3.0
作者Blog: http://flohofwoe.blogspot.com
用到的开源工程
为了避免版本之间的不兼容, 已经在SDK中包含
体系结构一览
- Nebula3 分成三层, 每一层都是建立在另一层之上的:
- 基础层: 最底层, 提供了一个图形和音频之下基本的平台抽象. 基础层可以用作任意类型的程序开发平台, 而不仅仅是实时3D程序.
- 渲染层: 这是中间层, 它在基础层之上另加了许多特性, 像3D渲染, 音频, 物理和场景管理等.
- 应用程序层: 这是最高的一层, 提供了一个完整的游戏框架, 这使得开发人员可以集中精力在游戏逻辑上, 而不用对关心各种细节实现.
- Nebula3 会跟Mangalore 合为一个整体, Mangalore的各种子系统会集成到Nebula3的适合它们的层中去.
- Nebula3 比 Nebula2更趋向于使用C++.
- Nebula3通过引用计数和智能指针实现了对象生命周期的管理.
- Nebula3的新对象模型使用一个4 byte的基类来代替Nebula2中70+ bytes的.
- RTTI更高效, 更易用.
- Nebula3仍然不使用C++异常, RTTI和STL(所有这些不是降低性能就是降低便携性).
- 根据类名来创建对象更快更易用.
- Nebula3 避免使用C Lib, 去除了附加的代码层.
- Nebula3 使用LUA 代替TCL作为标准的脚本语言(当然也可以增加其它脚本语言的支持)
基础层
- App 包含各种Application类
- Attr 属性注册
- Core Nebula3的对象模型
- Debug 程序内存转储和基于HTTP的调试信息(这个真是个好东西, 第一次听说)
- Http 实现了HTTP服务器和客户端, 这样可以在浏览器中实时查看调试信息
- IO 输入输出系统, 很方便
- Math 基于C++的数学库, 没什么特别的
- Memory 实现了定制的内存分配器
- Messaging 消息定义
- Net 最基本的基于TCP协议的C/S架构, 更多的功能会在高层的网络扩展中给出
- Scripting 脚本系统
- System 硬件平台和特定操作系统相关的一些特性
- Threading 多线程
- Timing 时间/定时器管理
- Util 工具库, 包括各种容器, 数据结构, 还有一个强大的string类(抛弃STL吧!)
渲染层
- CoreGraphics 图形库核心类
- Frame 基于帧的处理, 如RenderTarget, PostProcess等
- Graphics 一些实体类型定义, 如Camera之类
- Input 输入设备, 就是鼠标键盘手柄…..
- Lighting 光照处理, 包括阴影算法(竟然要SM3.0@_@)
- Models 骨骼模型&粒子系统
- RenderUtil 目前就只有一个Maya的摄像机…..
- Resources 资源管理器
应用程序层
application_win32工程就是一个简单的游戏, 框架, 但是已经包含了许多特性, 如果物理, 数据库等. 不过好像还缺少GUI系统.
插件
目前有三个, 基于ODE的物理引擎, 基于SQLite的本地数据库, 基于nebula2模型的骨骼模型系统
编译
没什么好说的, 打开.sln直接编译就成了, 没见过这么简单的开源工程^_^
就以这个程序做为测试程序的模板吧
1: #include "stdneb.h"
2: #include "core/debug.h"
3: #include "core/coreserver.h"
4: #include "core/sysfunc.h"
5:
6: using namespace Core;
7:
8: void
9: __cdecl main()
10: {
11: Ptr<CoreServer> coreServer = CoreServer::Create();
12: coreServer->SetAppName("Nebula3 Hello World!");
13: coreServer->Open();
14:
15: n_printf("Hello World\n");
16: system("pause");
17:
18: coreServer->Close();
19: coreServer = NULL;
20:
21: Core::SysFunc::Exit(0);
22: }