这一节练习一下手动创建实体,用到了对象(ManualObject)

  第一,依然是模板

#include "ExampleApplication.h"
class Example1 : public ExampleApplication
{
public:
void createScene()
{
}
protected:
private:
}; #include <windows.h>
INT WINAPI WinMain( HINSTANCE hInst, HINSTANCE, LPSTR strCmdLine, INT )
{
Example1 app;
app.go();
return ;
}

  第二,我们在createScene()添加自己手动创建的实体

  首先,创建一个平面,加载材质,详细如注释

     Ogre::Plane plane(Ogre::Vector3::UNIT_Y,-);//创建一个在原点下方10单位,并且以y轴为法线的平面
Ogre::MeshManager::getSingleton().createPlane("plane",//平面名称
Ogre::ResourceGroupManager::DEFAULT_RESOURCE_GROUP_NAME,//这个平面属于哪个资源组
plane,//平面的名称,上面创建的
,,//平面大小
,,//分段数,平面组成的精细度,
true,//为true时,它指的是向量是以垂直于平面创建
,//2D纹理坐标集的数量
,,//纹理在u方向和v方向应该重复的次数
Vector3::UNIT_Z);//当前平面的向上方向 Ogre::Entity *ent = mSceneMgr->createEntity("GrassPlane","plane");
mSceneMgr->getRootSceneNode()->createChildSceneNode()->attachObject(ent);
ent->setMaterialName("Examples/GrassFloor");

  然后,手动创建对象,我计划在面板上显示一个数字9,其中begin()是手动创建对象的开始

     Ogre::ManualObject *manualObj = mSceneMgr->createManualObject("grass");
manualObj->begin("Examples/GrassBlades",RenderOperation::OT_TRIANGLE_LIST);//开始创建

  其中的RenderOperation::OT_TRIANGLE_LIST有必要解释一下,这是一个枚举常量,源代码如下:

 enum OperationType {
/// A list of points, 1 vertex per point
OT_POINT_LIST = ,//点列表
/// A list of lines, 2 vertices per line
OT_LINE_LIST = ,//线列表
/// A strip of connected lines, 1 vertex per line plus 1 start vertex
OT_LINE_STRIP = ,//一系列连接着的线
/// A list of triangles, 3 vertices per triangle
OT_TRIANGLE_LIST = ,//一系列的三角形列表
/// A strip of triangles, 3 vertices for the first triangle, and 1 per triangle after that
OT_TRIANGLE_STRIP = ,//一系列连着的三角形
/// A fan of triangles, 3 vertices for the first triangle, and 1 per triangle after that
OT_TRIANGLE_FAN = //连接成扇形的三角形序列
};

    先来看一段代码:

        //创建一个三角形
manualObj->position(,,);
manualObj->textureCoord(,);
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
    //创建另一个三角形
manualObj->position(,,);
manualObj->textureCoord(,);
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.

  这段代码实现的效果是

  代码解释:

  我们使用的是OT_TRIANGLE_LIST,这是一系列的三角形,每个三角形有三个顶点组成,position()(三元组)给出位置创建两个个三角形组成一个长方形,textureCoord()给出一会要放的纹理的坐标(uv坐标),其中纹理坐标的组成方式为每一个平面坐标如图所示

               

  每一个三角形包括三个点,分别对应三个纹理坐标(如图2)。

  最后我们结束绘制,使用end()函数,创建一个场景节点把刚创建的对象绑定到场景节点上。

1      manualObj->end();//创建结束
Ogre::SceneNode*grassNode = mSceneMgr->getRootSceneNode()->createChildSceneNode("GrassNode",Ogre::Vector3(,-,));
grassNode->attachObject(manualObj);

  现在看下总的代码: 

 void createScene()
{
Ogre::Plane plane(Ogre::Vector3::UNIT_Y,-);//创建一个在原点下方10单位,并且以y轴为法线的平面
Ogre::MeshManager::getSingleton().createPlane("plane",//平面名称
Ogre::ResourceGroupManager::DEFAULT_RESOURCE_GROUP_NAME,//这个平面属于哪个资源组
plane,//平面的名称,上面创建的
,,//平面大小
,,//分段数,平面组成的精细度,
true,//为true时,它指的是向量是以垂直于平面创建
,//2D纹理坐标集的数量
,,//纹理在u方向和v方向应该重复的次数
Vector3::UNIT_Z);//当前平面的向上方向 Ogre::Entity *ent = mSceneMgr->createEntity("GrassPlane","plane");
mSceneMgr->getRootSceneNode()->createChildSceneNode()->attachObject(ent);
ent->setMaterialName("Examples/GrassFloor"); //手动创建我们的新ManualObject
Ogre::ManualObject *manualObj = mSceneMgr->createManualObject("grass");
manualObj->begin("Examples/GrassBlades",RenderOperation::OT_TRIANGLE_LIST);//开始创建 //创建一个三角形
manualObj->position(,,);
manualObj->textureCoord(,);
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex. manualObj->position(,,);
manualObj->textureCoord(,);
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
//第二面
manualObj->position(,,-);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,-);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);
manualObj->textureCoord(,); manualObj->position(,,-);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);
manualObj->textureCoord(,); //第三个面
manualObj->position(,,-);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,-);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,-);
manualObj->textureCoord(,); manualObj->position(,,-);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,-);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,-);
manualObj->textureCoord(,);
//第四个面
manualObj->position(,,-);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,);
manualObj->textureCoord(,);
manualObj->position(,,-);
manualObj->textureCoord(,);//纹理坐标,二元组,uv manualObj->position(,,-);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,);
manualObj->textureCoord(,);
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv //*****************************************************************************************///
//第五面
manualObj->position(,,);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);
manualObj->textureCoord(,); manualObj->position(,,);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);
manualObj->textureCoord(,); //第六个面
manualObj->position(,,);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);
manualObj->textureCoord(,); manualObj->position(,,);//定点坐标,三元组,xyz
manualObj->textureCoord(,);//Add a texture coordinate to the current vertex.
manualObj->position(,,);
manualObj->textureCoord(,);//纹理坐标,二元组,uv
manualObj->position(,,);
manualObj->textureCoord(,); manualObj->end();//创建结束
Ogre::SceneNode*grassNode = mSceneMgr->getRootSceneNode()->createChildSceneNode("GrassNode",Ogre::Vector3(,-,));
grassNode->attachObject(manualObj); }

关键代码

  在以上代码中,一共绘制了六个面,刚好组成数字9,如图

 

 现在总结一下手动绘制对象的步骤:

  1、需要先用场景管理器去创建一个人造物体的指针

  Ogre::ManualObject *manualObj = mSceneMgr->createManualObject("grass");

  2、然后使用人造物体的begin/end对进行绘制

      manualObj->begin("Examples/GrassBlades",RenderOperation::OT_TRIANGLE_LIST);//开始创建

  .......................

  manualObj->end();//创建结束  

  3、将对象绑定到节点上

  Ogre::SceneNode*grassNode = mSceneMgr->getRootSceneNode()->createChildSceneNode("GrassNode",Ogre::Vector3(0,-10,0));
  grassNode->attachObject(manualObj);

 

  哈哈,发挥你的想象力,绘制你自己的物体吧。

ogre3D学习基础16 -- 手动创建实体(ManualObject)的更多相关文章

  1. ogre3D学习基础18 -- 材质的使用与脚本的简单书写

    这一节以基础16为基础,练习材质的使用. 第一,看看框架 //material #include "ExampleApplication.h" class TutorialAppl ...

  2. ogre3D学习基础9 -- 光源程序实例

    这一章练习一下光源的使用,光源分为三种:点光源,聚光源,有向光.具体内容前面说过,这里就不解释了. 继续在上一章的程序的基础上实现. 1.创建摄像机(Camera) createCamera()函数是 ...

  3. ogre3D学习基础6---场景管理器的使用

    场景管理器的使用 最常使用的坐标系统空间(同时也是Ogre程序所能提供的)即是世界空间(World).父节点空间(Parent)以及本地空间(Local). 1.世界空间 就是物体所存在的地方,当我们 ...

  4. ogre3D学习基础14 -- 雾化效果与天空面,天空盒,天空穹

    前几天设置天空盒时一直出问题,现在问题终于解决了,问题来的莫名其妙,走的也莫名其妙. 第一,还是框架,我们依然使用ExampleApplication文件,框架如下 #include "Ex ...

  5. ogre3D学习基础17 --- 如何手动创建ogre程序

    建立自己的Ogre程序 一直以来都是使用ExampleApplication.h来写程序,现在来看看它到底有什么神奇的地方. 首先,我们新建一个win32空项目 然后配置环境 最后新建define.c ...

  6. ogre3D学习基础15 -- 创建BSP Scene Manager

    BSP(binary-space partitioning) Scene Manager(二叉空间分割)场景管理器比较适合用于室内场景. 第一,添加框架代码如下 #include "Exam ...

  7. ogre3D学习基础1 -- 核心对象与脚本技术

    一.核心对象介绍1.命名空间 Ogre3d使用了C++的特性--命名空间,可以防止命名混淆.使用方法也简单,using namespace Ogre;或者直接在使用时加上“Ogre::”的前缀,如Og ...

  8. ogre3D学习基础5 -- 阴影与动画

    五.阴影 阴影是渲染一个真实场景的重要组成部分,它可以给场景中的物体提供更加真实的感觉,同时还可以帮助用户更好的了解对象间的空间关系. 启用阴影: 缺省情况下,阴影是关闭的,开启方式如下: 1.建立场 ...

  9. ogre3D学习基础13 -- 键盘控制网格动画mesh

    以上一节为蓝本,这里增加一点难度,添加了四个节点,增加键盘控制移动速度,使用bool变量控制是否移动. 第一,要增加键盘控制,那就使用OIS::KeyListener,在监听器里添加一个父类KeyLi ...

随机推荐

  1. git版本分支和分支、分支和主分支切换

    问题描述: 公司里项目管理使用的是gitLab(收费的), 如果开发人员提交代码,  需要首先创建一个分支, 然后把代码提交到你创建的分支上去(不允许把代码直接提交到主分支上). 在代码提交到已经创建 ...

  2. NEO

    平台: Windows 类型: 虚拟机镜像 软件包: .net core neo application server basic software blockchain neo open sourc ...

  3. 测试MS题

    购物车测试点:  1.界面测试        界面布局.排版是否合理:文字是否显示清晰:不同卖家的商品是否区分明显. 2.功能测试 未登录时: 将商品加入购物车,页面跳转到登录页面,登录成功后购物车数 ...

  4. Shell脚本 - 用来检查memcache并自动重启生效脚本

    #!/bin/sh#check memcache process and restart if downmm_bin="/usr/local/bin/memcached"mm_lo ...

  5. 详细讲解:tp3.2.3生成验证码并进行验证(ajax校验返回及自定义返回)

    TP3.2.3的验证码也是比较经典的小功能,框架对这个小功能的封装还是比较完美的,废话不多说,开始记录 1.总体效果: (1)初始界面 (2)自定义的返回校验效果: (3)ajax的校验返回: 2.代 ...

  6. http头部信息学习

    想的每2周进行知识的总结,自己拖延症有犯了,发现自己知识库量还是太少,平时总结和发现问题还不够深,对待问题的深度也存在很多问题,但是坚持学习,总结,后面应该会有收获, 1.常见的返回码 100: 请服 ...

  7. python剑指offer 包含min函数的栈

    题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). # -*- coding:utf-8 -*- class Solution: def ...

  8. 四面体ply格式文件图和数据对应关系分析

    通过一个简单的文件来理解ply格式的文件是有所帮助的,我在网上找了一个四面体的ply文件,我通过meshlab打开看到的效果如下所示,我录制成gif文件,希望可以从不同角度展示出来: 同时我截图少许, ...

  9. AJAX进行分页

    新建数据集:PagingDataSet.xsd SELECT * from ( select id, areaID, area, father,Row_Number() over (order by ...

  10. Bootstrap历练实例:响应式标签页

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...