关于Sparrow 3D Engine(SPE)

2024-06-21 11:38
文章标签 3d engine spe sparrow

本文主要是介绍关于Sparrow 3D Engine(SPE),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Sparrow 3D Engine,简称SPE,是一个兴趣Project,基于OpenGL和Freeglut。其实起初并没有要写一个引擎的想法,况且开源的3D引擎非常多,直接拿来用就可以了。后来导师让我做科研,方向是跟布料仿真相关的,我就开始看文献,做实验,由于不需要很多太炫的功能,于是就直接用OpenGL写demo,但每次创建一个新的demo时我就发现要写很多跟以前做过的demo重复的代码,像摄像机控制、输入输出相关的代码。于是我就基于OpenGL做了一个封装,把一些公共的功能包装起来,尽量避免写重复的代码。后来我渐渐地向这个封装库中添加功能,代码量也在慢慢变大。在今年4月初,因为业余时间比较充裕,也因为个人兴趣我在里头添加了很多跟做论文demo关系不大的功能。目前,它具有下面这些功能:

1、应用程序基类以及更方便的IO事件处理。

2、摄像机控制类,包括Model View以及First Person摄像机。

3、基于glsl shader的光照系统,对OpenGL灯光、材质及纹理进行了包装,使用更方便。

4、基于Scene Graph的场景管理。

5、骨骼蒙皮动画,支持由Assimp插件导入动画,支持shader硬件蒙皮加速。

6、支持一些渲染效果,如凹凸贴图、镜面反射、Shadow Mapping、Stencil Shadow(Shadow Volume)以及SSAO。

7、基于高度图的地形创建以及地形光照和贴图。

8、渲染加速,支持视景体剔除以及一些空间数据结构,如QuadTree,Octree。

9、延时渲染(Deferred Shading),目前加入了SSAO以及FXAA抗锯齿。

先贴几个截图吧,

图1:骨骼蒙皮动画,由Assimp导入

图2:基于高度图的地形创建以及基于斜率的贴图混合

图3:基于Shadow Volume的阴影

现在SPE只能算是一个引擎雏形,不过我会持续更新它,让它更完善。另外以上这些功能的实现细节我会写在后续的博客中,一来是为了深度总结一下自己这几个月的工作,二来是希望能获得大家的意见和建议,使SPE更完善。

这篇关于关于Sparrow 3D Engine(SPE)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1081123

相关文章

轻量级在线服装3D定制引擎Myway简介

我写的面向web元宇宙轻量级系列引擎中的另外一个,在线3D定制引擎Myway 3D。 用于在线商品定制,比如个性化服装的定制、日常用品(如杯子)、家装(被套)等物品的在线定制。 特性列表: 可更换衣服款式,按需定制更换模型可实时更改材质颜色可实时添加文本,并可实时修改大小、颜色和角度,支持自定义字体可实时添加艺术图标,并可实时修改大小、颜色和角度,支持翻转、各种对齐可更改衣服图案,按需求定制

POLYGON Horror Carnival - Low Poly 3D Art by Synty

465 个独特的预设模型 一个正在运行的摩天轮和旋转木马 包括10个示例脚本,让嘉年华栩栩如生 ◼ 描述◼ 欢迎来到恐怖嘉年华。这个地方曾经有诱人的音乐,现在却有着令人不安的旋律,暗示着其中令人不安的惊喜。 这场险恶的盛会的真正核心在于演示场景。它使用3D低多边形资源构建,具有来自不祥的狂欢帐篷、摊位、摩天轮、旋转木马等游戏开发资源。它是疯狂人物与毫无戒心的寻求刺激者玩捉迷藏游戏的完美狩猎场。

自动驾驶---Perception之Lidar点云3D检测

1 背景         Lidar点云技术的出现是基于摄影测量技术的发展、计算机及高新技术的推动以及全球定位系统和惯性导航系统的发展,使得通过激光束获取高精度的三维数据成为可能。随着技术的不断进步和应用领域的拓展,Lidar点云技术将在测绘、遥感、环境监测、机器人等领域发挥越来越重要的作用。         目前全球范围内纯视觉方案的车企主要包括特斯拉和集越,在达到同等性能的前提下,纯视觉方

3D模型相关生成

3D模型相关生成 1. DreamFusion Model DreamFusion Model 是一种将文本描述转化为三维模型的技术。你可以想象它是一个“魔法翻译器”,你告诉它一个场景或物体的描述,比如“一个飞翔的龙”,它就能生成一个相应的 3D 模型。 原理: 文本到图像生成:DreamFusion 首先将文本描述转化为一系列可能的 2D 图像。这部分利用了预训练的扩散模型(如 DALL

初学WebGL,使用Three.js开发第一个3d场景示例

使用Three.js 开发3d场景   在图书馆偶然撞见《Three.js开发指南》一书,便试着捣鼓一翻,现将第一个示例的部分代码、注解和相关方法的API记录在此。因为此书发行时是Three.js r69版本,所以当前部分代码有所修改,且所有方法和参数以官方最新版本Three.js r90为准。 <!doctype html><html lang="en"><head><meta char

体验了一下AI生产3D模型有感

我的实验路子是想试试能不能帮我建一下实物模型 SO 我选择了一个成都环球中心的网图 但是生成的结果掺不忍睹,但是看demo来看,似乎如果你能给出一张干净的提示图片,他还是能做出一些东西的 这里我延申的思考是这个物体他如果没看过背面,他怎么猜? 他产出的物品为啥都是一张图的,我还是不太理解 但是如果多张图片,其实又和一个多图3D重建的能力似乎重复了 或者我感觉这个功能需求两张图片 正上面45

tensorRT C++使用pt转engine模型进行推理

目录 1. 前言2. 模型转换3. 修改Binding4. 修改后处理 1. 前言 本文不讲tensorRT的推理流程,因为这种文章很多,这里着重讲从标准yolov5的tensort推理代码(模型转pt->wts->engine)改造成TPH-yolov5(pt->onnx->engine)的过程。 2. 模型转换 请查看上一篇文章https://blog.csdn.net/

一些3D数据集的简单介绍

一、Objaverse 1.0 Objaverse 1.0: a large dataset of objects with 800K+ (and growing) 3D models with descriptive captions, tags and animations. Assets not only belong to varied categories like animals,

Google Earth Engine(GEE)——ui.DateSlider时间进度条的设置

结果    函数: ui.DateSlider(start, end, value, period, <

Vision Pro的3D跟踪能力:B端应用的工作流、使用教程和经验总结

Vision Pro的最新3D跟踪能力为工业、文博、营销等多个B端领域带来了革命性的交互体验。本文将详细介绍这一功能的工作流、使用教程,并结合实际经验进行总结。 第一部分:工作流详解 一、对象扫描 使用Reality Composer iPhone应用程序对目标对象进行3D扫描,如吉他或雕塑,生成精确的3D模型。 二、模型训练 工具:CreateML训练数据:以Reality