Book Image

OGRE 3D 1.7 Beginner's Guide

Book Image

OGRE 3D 1.7 Beginner's Guide

Overview of this book

Want to make your own 3D applications, simulations, and games? OGRE 3D, an open source Object-Oriented 3D Graphics Rendering Engine written in C++, which can be utilized to create a variety of 3D applications and is commonly used in game creation, can help you to do so! OGRE 3D 1.7 Beginner's Guide, based on the latest version 1.7, makes it super easy for you to make your own monsters, spaceship shooters, weapons, enemies, and more!OGRE 3D 1.7 Beginner's Guide will teach you to develop 3D applications that are exciting and interesting and if used correctly can result in stunning games and simulations. You will start from the very beginning and then work your way up to complex scenes and stunning effects.In this book you will start with how to download and configure OGRE 3D, then create your first example scene. With the help of this sample scene, you will be introduced to several related topics each of which will be explained through several other examples and by do-it-yourself tasks. After each example there is a section that explains the theory behind the technique used for deeper understanding. You will also use what you learned in one example in another example and repeat each technique several times while learning new ones at the same time to strengthen the topics learned. Within no time you will master the art of game creation. Imagine how great you will feel when all your friends are playing the great-looking games you've created with OGRE 3D and this book.
Table of Contents (17 chapters)
Ogre 3D 1.7
Credits
About the Author
About the Reviewers
Preface
Index

Time for action — experimenting with the FrameListener implementation


Using the console printing we are going to inspect when the FrameListener is called.

  1. First let each function print a message to the console when it is called:

    bool frameStarted(const Ogre::FrameEvent& evt)
    {
    std::cout << «Frame started» << std::endl;
    return false;
    }
    bool frameEnded(const Ogre::FrameEvent& evt)
    {
    std::cout << «Frame ended» << std::endl;
    return false;
    }
    bool frameRenderingQueued(const Ogre::FrameEvent& evt)
    {
    std::cout << «Frame queued» << std::endl;
    return false;
    }
    
  2. Compile and run the application; in the console you should find the first string – Frame started.

What just happened?

We added a "debug" output to each of the FrameListener functions to see which function is getting called. Running the application, we noticed that only the first debug message is printed. The reason is that the frameStarted function returns false, which is a signal for the root instance...