Game Creation with XNA/3D Development/3D Engines

3D Engines
Examples for engines allowing to simplify creation of 3D games. Should include a short intro of the engine, its capabilities, its support, maybe example projects that use it. Example for 3D engines can be found here: http://forums.create.msdn.com/forums/t/12882.aspx

QuickStart Engine
QuickStart Engine is a 3D Game Engine for XNA that allows developers to get started with 3D game programming as quickly as possible.

The current version is 0.262. It is still in an beta state. The Engine is published under the Ms-PL, which makes it free to use.

Includes a physics engine, in-game GUI framework, shadow mapping, normal mapping, multi-texture splatting for terrain, and more.

Pre-Requirements

 * Visual Studio 2010
 * XNA Game Studio 4.0

How to get started
The concept of the QuickStart Engine is easy to understand.

A game is made out of scenes. Those scenes are stored in the SceneManager, which is part of the game class "QSGame". The SceneManager is responsible for loading and holding the current scene.

A scene is made out of entities. Every object in a scene is an entity! It can be a camera, terrain, light, player and anything else.

An entity only contains basic information like position and rotation. To give it something like a model or camera you have to add Components.

Components are bound to entities and are responsible for things like holding the model, handling input or emitting light.

Another important fact is that each entity has to be added manually to the SceneManager of your game!

The engine has also a message system, which allows every part of the game to send and listen to requests. Those requests can include things like a change of the current camera an input or a movement.

How to implement the Engine in your Project


 * 1) Go to http://quickstartengine.codeplex.com/ and download the latest version (this tutorial is based on V0.26).
 * 2) As you may wish to make changes to the engine (mind the licence!) you should copy the folder "QuickStart Engine v0.26\framework\code" into your project folder.
 * 3) For a better understanding rename "code" to something like "QS" or "QuickStart"
 * 4) Now open your projects solution file with VS2010
 * 5) Open the Solutions-Explorer, right-click your solution and click "add existing project".
 * 6) Depending on the platform you are planning to program for, choose from each folder in "QS" the csproj/vsproj-file (if there is no specific Windows/XBox project file take the general one.
 * 7) Now do the following in your XNA project
 * 8) Go to ' -> references' and add references to all projects of your solution
 * 9) In the references at 'Content' add "QuickStart_>Windows/XBox>" and "QuickStart.ContentPipeline"
 * 10) In your Game.cs ...
 * 11) add "using QuickStart;"
 * 12) make your game to a subclass of QSGame.

Et voilá! Your game is now based on the QuickStart Engine!

How to Create a Scene:

While the game gets initialised all scenes have to be created and added to the SceneManager. You have to do that in the LoadContent method of your game.

When a scene gets initialized it can load everything it might need later, including models, textures, images, etc. Although, assets can be loaded at any time if you'd like.

UPDATE: It should be noted that loading entities into your scene has been greatly simplified since this review was originally done. Here's documentation on how to load entities and components without using any C# code, you can now define your entities entirely from XML. http://quickstartengine.codeplex.com/wikipage?title=Creating%20Entities%20and%20Components%20with%20XML

How to Create a Terrain:

This one is a bit tricky.

Make sure to have in your Content folder a "Material\Terrain.qsm". The best is to get the file from the test project, which came with the engine. You can find it at this path: "QuickStart Engine v0.22\framework\test\QuickStartSampleGame\Content\Material".

When you have added the file to the Project, you might have to change the Importer and Processor in Properties to "QuickStart Material Importer/Processor".

We'll have another look at this file later.

To create a terrain you will need a grey scale heightmap. It has to be quadratic and the length of a side must be a power of 2 (2,4,8,16,32,64,...).

Now it is quite easy to create the terrain in a scene:

Now there is only one thing missing! You have to add a texture map for your terrain. This map has to be of the same size as the height map and uses three colors to define the textures for the ground. red  (255,0,0) = rocks green (0,255,0) = grass blue (0,0,255) = water Have a closer look at the "Terrain.qsm". You will find a path for the "TEXTURE_MAP". Change it to where ever you put your image. To create the map you can use any image processing software. Save it in a lossless format like "png".

How to create an Entity:

Everything in your scene is derived from BaseEntity. Whenever you want to create an object you have to start by creating a BaseEntity-object.

The entity for itself is nothing visible. You have to add a RenderComponent where you set the model and a material. In case you want collision detection and/or physics for your entity you can add a PhysicsComponent. Here is an example for a simple sphere.

How to add a third person Camera:

Every object can be used as a camera, which is useful for things like first person views or security cameras.

For the third person view we need a new BaseEntity and add a CameraComponent to it. We also add the ArcBallCameraInputComponent to it, which allows us to rotate the camera later. After this you have to add the camera to the SceneManager, because we have to send some messages, which will just work, when the camera is already known by the game. Finally you have your camera always in a third person view behind your player!
 * The first message is, to say, that this is from now on the main camera
 * The second message sets the player object as the parent
 * The third message is to say that the player rotates with the camera

How to create a Character Object

The third person camera has no use as long as we don't have a player. Most of the script you will already recognize from the examples before.

How to create a Light:

The last thing we need for a basic scene is a light. Every Entity can emit light. Therefore you just have to create the lights settings, a LightEmitterComponent and initialise it after adding it to the SceneManager. This could look like this:

Review
The QuickStart Engine has potential but it takes some time to understand what's going on. In some points it is a bit to static and needs to be improved.

The engine was updated to work with XNA 4.0, also loading of entities and components is much simpler now and can be done entirely through XML. Also other features like texture mapping for models and in-game GUI have been added since this review was done.

Authors
juliusse