OGRE 3D----创建第一个OGRE 3D示例

2024-09-07 02:04
文章标签 创建 3d 第一个 示例 ogre

本文主要是介绍OGRE 3D----创建第一个OGRE 3D示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1. OGRE 3D概述

2. OGRE 3D vs VTK

3. 编译OGRE 3D 源码

4. 创建示例和配置其编译环境

5. 配置示例程序的执行环境


1. OGRE 3D概述

OGRE (Object-Oriented Graphics Rendering Engine) 是一个开源的、高级的 3D 图形渲染引擎,它提供了一个抽象层,使得开发者可以专注于创建内容和逻辑,而不必深入底层的图形硬件接口。OGRE 由 C++ 编写,但它支持多种语言绑定,包括 Python 和 .NET 语言。它是跨平台的,支持 Windows、Linux、macOS 等操作系统。

主要特性

  • 场景管理:OGRE 提供了多种场景管理策略,包括八叉树、BSP(二叉空间分割)等,以高效地管理和渲染3D场景。
  • 材质和着色:支持高级材质描述、着色器(包括 HLSL、GLSL、CG)等,允许创建丰富的视觉效果。
  • 网格和动画:支持复杂的网格模型和骨骼动画,包括网格细分、蒙皮、形态混合等功能。
  • 灯光和阴影:提供了多种灯光类型和阴影技术,包括静态阴影、动态阴影等。
  • 渲染系统:支持多种渲染系统后端,如 Direct3D 和 OpenGL,确保了跨平台的兼容性和性能。
  • 插件架构:OGRE 设计了灵活的插件架构,允许扩展新的渲染系统、场景管理器等。

应用领域

OGRE 被广泛应用于游戏开发、模拟、虚拟现实、科学可视化等领域。它的高度可扩展性和强大的功能使其成为专业开发者和爱好者的热门选择。

开发环境

OGRE 的开发活跃,社区支持强大。它提供了详细的文档、教程和示例,帮助开发者快速上手。此外,OGRE 遵循 MIT 许可证,这意味着它可以在几乎任何项目中免费使用,包括商业项目。

2. OGRE 3D vs VTK

OGRE (Object-Oriented Graphics Rendering Engine) 和 VTK (The Visualization Toolkit) 都是强大的开源库,但它们服务于不同的目的和应用领域。

OGRE 3D

  • 主要用途:OGRE 是一个3D图形渲染引擎,主要用于游戏开发、实时3D应用程序、模拟和虚拟现实。
  • 特点
    • 专注于图形渲染,提供高级的渲染接口。
    • 支持多种材质、光照模型和阴影技术。
    • 提供场景管理、动画等功能。
    • 跨平台支持(Windows、Linux、macOS等)。
    • 强调性能和视觉效果。
  • 社区和文档:拥有活跃的社区和丰富的学习资源。
  • 许可证:遵循MIT许可证,允许在商业和非商业项目中免费使用。

VTK

  • 主要用途:VTK 是一个数据可视化库,主要用于科学数据的3D计算机图形学、图像处理和可视化。
  • 特点
    • 提供了一套完整的工具,用于创建复杂的3D可视化应用程序。
    • 支持多种数据格式和可视化算法,如体渲染、等值面提取、向量场可视化等。
    • 包含大量的算法,用于图像处理和3D图形。
    • 跨平台支持(Windows、Linux、macOS等)。
    • 更侧重于科学计算和数据分析的可视化。
  • 社区和文档:具有广泛的文档和示例,社区支持强大。
  • 许可证:遵循BSD许可证,适用于商业和非商业项目。

对比总结

  • 应用领域:OGRE 3D更适合需要高级图形渲染的游戏和实时3D应用,而VTK专注于科学数据的3D可视化和图像处理。
  • 功能重点:OGRE 3D强调图形渲染和视觉效果,VTK提供了强大的数据处理和可视化工具。
  • 社区和资源:两者都有活跃的社区和丰富的学习资源,但它们的专业领域不同。

选择哪一个库取决于你的具体需求:如果你的项目需要高质量的3D图形渲染,OGRE可能是更好的选择;如果项目需要复杂的数据可视化和分析,VTK可能更适合。

3. 编译OGRE 3D 源码

Clone源码并Checkout具体的Tag

#clone source code
git clone https://github.com/OGRECave/ogre.git#checkout the specified tag
git checkout -b v14.2.5 tags/v14.2.5

编写BAT脚本编译及安装OGRE

configure_and_build_ogre_14_2_5.bat


setlocal EnableDelayedExpansionset BUILD_DIR=D:\code\orge\ogreset PYTHONHOME=C:\Python\Python310set PYTHONPATH=C:\Python\Python310\Lib;C:\Python\Python310\DLLs;C:\Python\Python310\libsset OGRE_DEPENDENCIES_DIR=D:\code\orge\ogre_v14.2.5\ogre_build\Dependencies:: Create build and install directories
mkdir "D:\code\orge\ogre_v14.2.5\ogre_build"
mkdir "D:\code\orge\ogre_v14.2.5\ogre_install":: Execute cmake from VS build tools to build VTK
cmake -S"D:\code\orge\ogre" ^
-G"Visual Studio 17 2022" ^
-B"D:\code\orge\ogre_v14.2.5\ogre_build" ^
-DCMAKE_BUILD_TYPE:STRING=RelWithDebInfo ^
-DPYTHON_EXECUTABLE:FILEPATH="C:/Python/Python310/python.exe" ^
-DPYTHON_INCLUDE_DIR:PATH="C:/Python/Python310/include" ^
-DPYTHON_LIBRARY:FILEPATH="C:/Python/Python310/libs/python310.lib" ^
-DIMGUI_DIR:PATH="D:/code/orge/ogre_v14.2.5/ogre_build/imgui-1.90.4" ^
-Dpugixml_DIR:PATH="D:/code/orge/ogre_v14.2.5/Dependencies/lib/cmake/pugixml" ^
-Dassimp_DIR:PATH=D:/code/orge/ogre_v14.2.5/Dependencies/lib/cmake/assimp-5.2 ^
-DZLIB_INCLUDE_DIR:PATH="D:/code/orge/ogre_v14.2.5/ogre_build/Dependencies/include" ^
-DZLIB_LIBRARY_RELEASE:FILEPATH="D:/code/orge/ogre_v14.2.5/ogre_build/Dependencies/lib/zlib.lib" ^
-DOGRE_BUILD_COMPONENT_PAGING:BOOL=ON ^
-DCMAKE_INSTALL_PREFIX:PATH="D:/code/orge/ogre_v14.2.5/ogre_install":: Compile code using msbuild:
cd "D:\code\orge\ogre_v14.2.5\ogre_build"
:: Create Release DLL's
"C:/Program Files/Microsoft Visual Studio/2022/Professional/Msbuild/Current/Bin/amd64/MSBuild.exe" OGRE.sln /p:Configuration="RelWithDebInfo""C:/Program Files/Microsoft Visual Studio/2022/Professional/Msbuild/Current/Bin/amd64/MSBuild.exe" INSTALL.vcxproj /p:Configuration="RelWithDebInfo"pauseendlocal

编译时需要连接网络,因为过程中会下载其编译所依赖的库文件,例如:pugixml、zlib。

安装的OGRE库目录在D:\code\orge\ogre_v14.2.5\ogre_install。

4. 创建示例和配置其编译环境

CMakeLists.txt

cmake_minimum_required(VERSION 3.10)
project(OgreDemo)set(CMAKE_CXX_STANDARD 11)# Replace this with the path to your Ogre SDK
set(OGRE_HOME "D:/code/orge/ogre_v14.2.5/ogre_install")
set(SDL2_HOME "D:/code/orge/SDL2-2.28.5")set(CUSTOM_OUTPUT_DIRECTORY "D:/code/test/ogre/testogre/build/bin")
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CUSTOM_OUTPUT_DIRECTORY})# 确保CMake可以找到OGRE的配置文件
list(APPEND CMAKE_PREFIX_PATH "${OGRE_HOME}" "${SDL2_HOME}")
list(APPEND CMAKE_PREFIX_PATH "${OGRE_HOME}")find_package(OGRE 14.2 REQUIRED COMPONENTS Bites RTShaderSystem)
find_package(SDL2 REQUIRED)include_directories(${OGRE_INCLUDE_DIRS} ${SDL2_INCLUDE_DIRS})
link_directories(${OGRE_LIBRARY_DIRS} ${SDL2_LIBRARIES})add_executable(OgreDemo main.cpp)
target_link_libraries(OgreDemo ${OGRE_LIBRARIES} ${SDL2_LIBRARIES})

main.cpp

// This file is part of the OGRE project.
// It is subject to the license terms in the LICENSE file found in the top-level directory
// of this distribution and at https://www.ogre3d.org/licensing.
// SPDX-License-Identifier: MIT#include "Ogre.h"
#include "OgreApplicationContext.h"
#include "SDL.h"//! [key_handler]
class KeyHandler : public OgreBites::InputListener
{bool keyPressed(const OgreBites::KeyboardEvent& evt) override{if (evt.keysym.sym == SDLK_ESCAPE){Ogre::Root::getSingleton().queueEndRendering();}return true;}
};
//! [key_handler]int main(int argc, char *argv[])
{
//! [constructor]OgreBites::ApplicationContext ctx("OgreTutorialApp");ctx.initApp();
//! [constructor]//! [setup]// get a pointer to the already created rootOgre::Root* root = ctx.getRoot();Ogre::SceneManager* scnMgr = root->createSceneManager();// register our scene with the RTSSOgre::RTShader::ShaderGenerator* shadergen = Ogre::RTShader::ShaderGenerator::getSingletonPtr();shadergen->addSceneManager(scnMgr);// without light we would just get a black screen    Ogre::Light* light = scnMgr->createLight("MainLight");Ogre::SceneNode* lightNode = scnMgr->getRootSceneNode()->createChildSceneNode();lightNode->setPosition(0, 10, 15);lightNode->attachObject(light);// also need to tell where we areOgre::SceneNode* camNode = scnMgr->getRootSceneNode()->createChildSceneNode();camNode->setPosition(0, 0, 15);camNode->lookAt(Ogre::Vector3(0, 0, -1), Ogre::Node::TS_PARENT);// create the cameraOgre::Camera* cam = scnMgr->createCamera("myCam");cam->setNearClipDistance(5); // specific to this samplecam->setAutoAspectRatio(true);camNode->attachObject(cam);// and tell it to render into the main windowctx.getRenderWindow()->addViewport(cam);// finally something to renderOgre::Entity* ent = scnMgr->createEntity("Sinbad.mesh");Ogre::SceneNode* node = scnMgr->getRootSceneNode()->createChildSceneNode();node->attachObject(ent);
//! [setup]//! [main]// register for input eventsKeyHandler keyHandler;ctx.addInputListener(&keyHandler);ctx.getRoot()->startRendering();ctx.closeApp();
//! [main]return 0;
}

配置SDL2库环境

由于OGRE安装时并没有将SDL2也安装到OGRE库目录中,但示例程序在编译时需要依赖SDL2头文件和库文件,所以我们从网上下载编译好的SDL2库 
https://github.com/libsdl-org/SDL/releases/download/release-2.30.4https://github.com/libsdl-org/SDL/releases/download/release-2.28.5/SDL2-devel-2.28.5-VC.ziphttps://github.com/libsdl-org/SDL/releases/download/release-2.30.4
,当然你也可以收集ogre_build\Dependencies下的SDL2的头文件、LIB文件和DLL文件,然后组成SDL2库目录,当这样不方便。

5. 配置示例程序的执行环境

将ogre_install\bin目录下的exe,DLL,cfg文件都拷贝到示例程序exe所在的目录下。

将ogre_install\Media拷贝到示例程序exe的上一级目录下。

运行示例程序exe,你将看到文章前面那张图的效果。

这篇关于OGRE 3D----创建第一个OGRE 3D示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

批处理以当前时间为文件名创建文件

批处理以当前时间为文件名创建文件 批处理创建空文件 有时候,需要创建以当前时间命名的文件,手动输入当然可以,但是有更省心的方法吗? 假设我是 windows 操作系统,打开命令行。 输入以下命令试试: echo %date:~0,4%_%date:~5,2%_%date:~8,2%_%time:~0,2%_%time:~3,2%_%time:~6,2% 输出类似: 2019_06

zeroclipboard 粘贴板的应用示例, 兼容 Chrome、IE等多浏览器

zeroclipboard单个复制按钮和多个复制按钮的实现方法 最近网站改版想让复制代码功能在多个浏览器上都可以实现,最近看网上不少说我们的代码复制功能不好用的,我们最近将会增加代码高亮等功能,希望大家多多支持我们 zeroclipboard是一个跨浏览器的库类 它利用 Flash 进行复制,所以只要浏览器装有 Flash 就可以运行,而且比 IE 的