Compare commits

...

2 Commits

Author SHA1 Message Date
d3b2ae30d5 Making this work 2025-08-21 10:58:22 +03:00
52de5b16a8 Making this work 2025-08-21 10:58:17 +03:00
11 changed files with 147 additions and 46 deletions

View File

@@ -457,9 +457,11 @@ public:
std::cout << "Init camera" << "\n";
initCamera();
std::cout << "Set up water" << "\n";
m_water.createWater(getRenderWindow(), mCamera);
m_water.createWater(getRenderWindow(), mCamera,
mDynWorld.get());
std::cout << "Set up cursor" << "\n";
Ogre::ResourceGroupManager::getSingleton().initialiseAllResourceGroups();
Ogre::ResourceGroupManager::getSingleton()
.initialiseAllResourceGroups();
// OgreBites::ApplicationContext::loadResources();
setupCursor();
std::cout << "Create content" << "\n";
@@ -470,7 +472,6 @@ public:
}
void setupCursor()
{
// mKeyDirection = Ogre::Vector3::ZERO;
// mVerticalVelocity = 0;
Ogre::ManualObject *mobj =

View File

@@ -244,6 +244,7 @@ public:
float panel_width;
void initGui();
};
#define WATER
class App : public OgreBites::ApplicationContext {
std::unique_ptr<Ogre::Bullet::DynamicsWorld> mDynWorld;
std::unique_ptr<Ogre::Bullet::DebugDrawer> mDbgDraw;
@@ -258,7 +259,9 @@ class App : public OgreBites::ApplicationContext {
TerrainSetup m_terrain;
Ogre::Light *mSun;
SkyBoxRenderer *sky;
#ifdef WATER
Water m_water;
#endif
class KeyboardListener : public OgreBites::InputListener,
public Ogre::FrameListener {
App *mApp;
@@ -361,6 +364,10 @@ class App : public OgreBites::ApplicationContext {
fps_timer.reset();
}
update(evt.timeSinceLastFrame);
if (mApp->getCharacterController() && gui_active)
mApp->getCharacterController()->disableUpdates();
else if (mApp->getCharacterController() && !gui_active)
mApp->getCharacterController()->enableUpdates();
if (!gui_active) {
mApp->updateSun(evt.timeSinceLastFrame);
mApp->updateTerrain(evt.timeSinceLastFrame);
@@ -407,7 +414,11 @@ public:
}
void dump_water()
{
#if 0
#ifdef WATER
m_water.dump_textures();
#endif
#endif
}
void initCamera()
@@ -457,7 +468,10 @@ public:
std::cout << "Init camera" << "\n";
initCamera();
std::cout << "Set up water" << "\n";
m_water.createWater(getRenderWindow(), mCamera);
#ifdef WATER
m_water.createWater(getRenderWindow(), mCamera,
mDynWorld.get());
#endif
std::cout << "Set up cursor" << "\n";
Ogre::ResourceGroupManager::getSingleton()
.initialiseAllResourceGroups();
@@ -467,7 +481,9 @@ public:
createContent();
std::cout << "Setup terrain" << "\n";
setupTerrain();
#ifdef WATER
m_water.init();
#endif
setupPlayer();
setupInput();
}
@@ -535,13 +551,23 @@ public:
void updateTerrain(float delta)
{
}
// TODO: implement rough water level calculation
float getWaterLevel(const Ogre::Vector3 &position)
{
Ogre::Vector3::UNIT_Y;
float etime =
Ogre::ControllerManager::getSingleton().getElapsedTime();
return 0.0f;
}
void updateWorld(float delta)
{
mDynWorld->getBtWorld()->stepSimulation(delta, 10);
mDynWorld->getBtWorld()->stepSimulation(delta, 60);
}
void updateWater(float delta)
{
#ifdef WATER
m_water.updateWater(delta);
#endif
}
void setupInput()
{
@@ -608,6 +634,10 @@ public:
m_terrain.setupTerrain(mCamera, mSun, mDynWorld.get(),
mDbgDraw.get());
}
CharacterController *getCharacterController()
{
return mCharacterController;
}
};
void EditUI::buildings_editor()

Binary file not shown.

View File

@@ -22,6 +22,7 @@ Character::Character(Ogre::SceneManager *scnMgr, const Ogre::String &model,
, mGhostObject(nullptr)
, mWorld(world)
, mGoalDirection(0, 0, 0)
, mUpdate(false)
{
setupBody();
setupAnimations();
@@ -38,10 +39,12 @@ bool Character::frameStarted(const Ogre::FrameEvent &evt)
bool Character::frameRenderingQueued(const Ogre::FrameEvent &evt)
{
updateBody(evt.timeSinceLastFrame);
updateAnimations(evt.timeSinceLastFrame);
if (evt.timeSinceLastFrame > 0)
updateRootMotion(evt.timeSinceLastFrame);
if (mUpdate) {
updateBody(evt.timeSinceLastFrame);
updateAnimations(evt.timeSinceLastFrame);
if (evt.timeSinceLastFrame > 0)
updateRootMotion(evt.timeSinceLastFrame);
}
return true;
}

View File

@@ -38,6 +38,7 @@ class Character : public Ogre::FrameListener {
btCompoundShape *mCollisionShape;
btPairCachingGhostObject *mGhostObject;
Ogre::Bullet::DynamicsWorld *mWorld;
bool mUpdate;
public:
Character(Ogre::SceneManager *scnMgr, const Ogre::String &modelName,
@@ -112,4 +113,16 @@ public:
return mGoalDirection;
}
Ogre::Vector3 getPosition();
};
void enableUpdates()
{
mUpdate = true;
}
void disableUpdates()
{
mUpdate = false;
}
bool getUpdates()
{
return mUpdate;
}
};

View File

@@ -183,6 +183,7 @@ CharacterController::CharacterController(Ogre::SceneNode *camNode,
, mWorld(world)
, mCollisionShape(nullptr)
, mGhostObject(nullptr)
, mUpdate(false)
{
setupBody();
setupCamera();
@@ -445,11 +446,13 @@ bool CharacterController::mousePressed(const OgreBites::MouseButtonEvent &evt)
}
void CharacterController::frameRendered(const Ogre::FrameEvent &evt)
{
updateBody(evt.timeSinceLastFrame);
updateAnimations(evt.timeSinceLastFrame);
updateCamera(evt.timeSinceLastFrame);
if (evt.timeSinceLastFrame > 0)
updateRootMotion(evt.timeSinceLastFrame);
if (mUpdate) {
updateBody(evt.timeSinceLastFrame);
updateAnimations(evt.timeSinceLastFrame);
updateCamera(evt.timeSinceLastFrame);
if (evt.timeSinceLastFrame > 0)
updateRootMotion(evt.timeSinceLastFrame);
}
}
bool CharacterController::frameStarted(const Ogre::FrameEvent &evt)
{

View File

@@ -81,6 +81,8 @@ class CharacterController : public OgreBites::InputListener,
btCompoundShape *mCollisionShape;
btPairCachingGhostObject *mGhostObject;
bool mUpdate;
public:
CharacterController(Ogre::SceneNode *camNode, Ogre::Camera *cam,
Ogre::SceneManager *scnMgr,
@@ -159,4 +161,17 @@ private:
q = convert(from.getRotation());
v = convert(from.getOrigin());
}
public:
void enableUpdates()
{
mUpdate = true;
}
void disableUpdates()
{
mUpdate = false;
}
bool getUpdates()
{
return mUpdate;
}
};

View File

@@ -21,7 +21,8 @@
#define ENDLESS_TERRAIN_FILE_PREFIX Ogre::String("EndlessWorldTerrain")
#define ENDLESS_TERRAIN_FILE_SUFFIX Ogre::String("dat")
#define TERRAIN_WORLD_SIZE 4000.0f
#define TERRAIN_SIZE 513
// #define TERRAIN_SIZE 513
#define TERRAIN_SIZE 129
// #define HOLD_LOD_DISTANCE 3000.0
#define USE_PERLIN_DEFINER 0
template <typename T> T CLAMP(T value, T low, T high)

View File

@@ -3,6 +3,7 @@
#include <OgreMeshLodGenerator.h>
#include <OgreCompositorManager.h>
#include <OgreMaterialManager.h>
#include <OgreBullet.h>
#include "water.h"
/* TODO: use blender glb model for water shape.
@@ -20,12 +21,19 @@ Water::Water()
, mWindow(nullptr)
, mCameraNode(nullptr)
, mWaterPlane(Ogre::Vector3::UNIT_Y, 0)
, mReflectionPlane(Ogre::Vector3(0.0, 1.0, 0.0), 0.0f /* water height */)
, mReflectionClipPlaneAbove(Ogre::Vector3(0.0, 1.0, 0.0), 0.0f /* water height */ - 2.0f)
, mReflectionClipPlaneBelow(Ogre::Vector3(0.0, -1.0, 0.0), -(0.0f /* water height */ + 2.0))
, mRefractionClipPlaneAbove(Ogre::Vector3(0.0, -1.0, 0.0), -(0.0f /* water height */ + 2.0))
, mRefractionClipPlaneBelow(Ogre::Vector3(0.0, 1.0, 0.0), 0.0f /* water height */ - 2.0)
, mReflectionPlane(Ogre::Vector3(0.0, 1.0, 0.0),
0.0f /* water height */)
, mReflectionClipPlaneAbove(Ogre::Vector3(0.0, 1.0, 0.0),
0.0f /* water height */ - 2.0f)
, mReflectionClipPlaneBelow(Ogre::Vector3(0.0, -1.0, 0.0),
-(0.0f /* water height */ + 2.0))
, mRefractionClipPlaneAbove(Ogre::Vector3(0.0, -1.0, 0.0),
-(0.0f /* water height */ + 2.0))
, mRefractionClipPlaneBelow(Ogre::Vector3(0.0, 1.0, 0.0),
0.0f /* water height */ - 2.0)
, mAbove(true)
, mWaterBody(nullptr)
, mDynWorld(nullptr)
{
}
@@ -33,8 +41,16 @@ Water::~Water()
{
if (mWaterNode)
mScnMgr->destroySceneNode(mWaterNode);
if(mReflectionTexture)
if (mReflectionTexture)
mReflectionTexture->removeAllListeners();
if (mWaterBody) {
if (mWaterBody->getWorldArrayIndex() >= 0)
if (mDynWorld)
mDynWorld->getBtWorld()->removeCollisionObject(
mWaterBody);
delete mWaterBody;
mWaterBody = nullptr;
}
}
void Water::create_cameras()
@@ -48,9 +64,11 @@ void Water::create_cameras()
mReflectionCamera->enableCustomNearClipPlane(mReflectionClipPlaneAbove);
mReflectionCamera->enableReflection(mReflectionPlane);
Ogre::Viewport * reflectionViewport = mReflectionTexture->addViewport(mReflectionCamera, 0, 0, 0, 0.5f, 1.0f);
Ogre::Viewport *reflectionViewport = mReflectionTexture->addViewport(
mReflectionCamera, 0, 0, 0, 0.5f, 1.0f);
reflectionViewport->setClearEveryFrame(true);
reflectionViewport->setBackgroundColour(Ogre::ColourValue(0.0, 0.0, 1.0, 1.0));
reflectionViewport->setBackgroundColour(
Ogre::ColourValue(0.0, 0.0, 1.0, 1.0));
reflectionViewport->setOverlaysEnabled(false);
reflectionViewport->setSkiesEnabled(true);
reflectionViewport->setAutoUpdated(false);
@@ -63,9 +81,11 @@ void Water::create_cameras()
mRefractionCamera->setFarClipDistance(mCamera->getFarClipDistance());
mRefractionCamera->enableCustomNearClipPlane(mRefractionClipPlaneAbove);
Ogre::Viewport * refractionViewport = mReflectionTexture->addViewport(mRefractionCamera, 1, 0.5, 0, 0.5f, 1.0f);
Ogre::Viewport *refractionViewport = mReflectionTexture->addViewport(
mRefractionCamera, 1, 0.5, 0, 0.5f, 1.0f);
refractionViewport->setClearEveryFrame(true);
refractionViewport->setBackgroundColour(Ogre::ColourValue(0.0, 0.5, 1.0, 1.0));
refractionViewport->setBackgroundColour(
Ogre::ColourValue(0.0, 0.5, 1.0, 1.0));
refractionViewport->setOverlaysEnabled(false);
refractionViewport->setSkiesEnabled(false);
refractionViewport->setAutoUpdated(false);
@@ -74,13 +94,12 @@ void Water::create_cameras()
void Water::create_textures()
{
Ogre::TexturePtr reflectionTexture = Ogre::TextureManager::getSingleton().createManual(
"ReflectionRefractionTexture",
Ogre::ResourceGroupManager::DEFAULT_RESOURCE_GROUP_NAME,
Ogre::TEX_TYPE_2D, 512, 512,
0,
Ogre::PF_R8G8B8A8,
Ogre::TU_RENDERTARGET);
Ogre::TexturePtr reflectionTexture =
Ogre::TextureManager::getSingleton().createManual(
"ReflectionRefractionTexture",
Ogre::ResourceGroupManager::DEFAULT_RESOURCE_GROUP_NAME,
Ogre::TEX_TYPE_2D, 512, 512, 0, Ogre::PF_R8G8B8A8,
Ogre::TU_RENDERTARGET);
mReflectionTexture = reflectionTexture->getBuffer()->getRenderTarget();
mReflectionTexture->setAutoUpdated(false);
@@ -115,10 +134,12 @@ void Water::init()
{ -1, 0, 1 }, { 1, 0, -1 }, { 1, 0, 1 } };
mWaterNode = mScnMgr->getRootSceneNode()->createChildSceneNode("Water");
auto mat = Ogre::MaterialManager::getSingleton().getByName("Water/Above");
auto mat =
Ogre::MaterialManager::getSingleton().getByName("Water/Above");
mat->load();
mat->setReceiveShadows(false);
auto mat2 = Ogre::MaterialManager::getSingleton().getByName("Water/Below");
auto mat2 =
Ogre::MaterialManager::getSingleton().getByName("Water/Below");
mat2->load();
mat2->setReceiveShadows(false);
#if 0
@@ -146,9 +167,11 @@ void Water::init()
water_ent->setMaterial(mat);
mWaterNode->attachObject(water_ent);
mWaterMeshes.push_back(water_ent);
mDynWorld->attachCollisionObject(mWaterBody, water_ent, 1, 0x7FFFFFFF);
}
void Water::createWater(Ogre::RenderWindow * window, Ogre::Camera *camera)
void Water::createWater(Ogre::RenderWindow *window, Ogre::Camera *camera,
Ogre::Bullet::DynamicsWorld *world)
{
int i;
mCamera = camera;
@@ -158,6 +181,17 @@ void Water::createWater(Ogre::RenderWindow * window, Ogre::Camera *camera)
mWindow = window;
mCameraPosition = mCameraNode->getPosition();
create_textures();
mDynWorld = world;
mWaterBody = new btGhostObject;
btBoxShape *boxShape = new btBoxShape(btVector3(1000, 1000, 1000));
btCompoundShape *shape = new btCompoundShape;
shape->addChildShape(
btTransform(btQuaternion(), btVector3(0, -1000, 0)), boxShape);
mWaterBody->setCollisionShape(shape);
mWaterBody->setCollisionFlags(
mWaterBody->getCollisionFlags() |
btCollisionObject::CF_NO_CONTACT_RESPONSE |
btCollisionObject::CF_STATIC_OBJECT);
}
void Water::updateWater(float delta)

View File

@@ -2,37 +2,38 @@
#define MAT_WATER_H
#include <Ogre.h>
class App;
class btGhostObject;
class Water : public /* Ogre::FrameListener, */ Ogre::RenderTargetListener {
Ogre::SceneManager *mScnMgr;
Ogre::RenderWindow * mWindow;
Ogre::RenderWindow *mWindow;
Ogre::SceneNode *mWaterNode, *mCameraNode;
Ogre::Vector3 mCameraPosition;
Ogre::Camera *mCamera;
Ogre::Plane mWaterPlane,
mReflectionPlane,
mReflectionClipPlaneAbove,
mReflectionClipPlaneBelow,
mRefractionClipPlaneAbove,
Ogre::Plane mWaterPlane, mReflectionPlane, mReflectionClipPlaneAbove,
mReflectionClipPlaneBelow, mRefractionClipPlaneAbove,
mRefractionClipPlaneBelow;
bool mAbove;
std::vector<Ogre::Entity *> mWaterMeshes;
std::vector<Ogre::Viewport *> mViewports;
// Reflection
Ogre::RenderTexture * mReflectionTexture;
Ogre::Camera * mReflectionCamera;
Ogre::RenderTexture *mReflectionTexture;
Ogre::Camera *mReflectionCamera;
// Refraction
// Ogre::RenderTexture * mRefractionTexture;
Ogre::Camera * mRefractionCamera;
Ogre::Camera *mRefractionCamera;
bool mInRefTexUpdate;
Ogre::Timer mtexture_dump;
void create_cameras();
btGhostObject *mWaterBody;
Ogre::Bullet::DynamicsWorld *mDynWorld;
public:
Water();
virtual ~Water();
void create_textures();
void dump_textures();
void createWater(Ogre::RenderWindow * window, Ogre::Camera *camera);
void createWater(Ogre::RenderWindow *window, Ogre::Camera *camera,
Ogre::Bullet::DynamicsWorld *world);
void init();
void updateWater(float delta);
/* bool frameEnded(const Ogre::FrameEvent &evt) override; */

Binary file not shown.