Mogre SDK development        
Print


This page should support the development of the Mogre SDK.

The SDK should be user friendly, especially for newcomers.

help For questions and suggestions use this forum thread(external link)

About the SDK

It should:

  • check for installed Mogre depencies
  • offer installation of needed depencies
  • install the Mogre SDK (in best case without need of manual system changes)
  • contain different libraries
  • contain sample applications

 
Currently related to Mogre 1.6.4

Download of the MOGRE SDK 1.6.4 Beta Installer in this forum post(external link).

Current Mogre maintainer: GantZ

Current SDK developer: kwertz

SVN

The SDK related stuff is available on this google code project(external link).

Direct SVN link: http://mogresdk.googlecode.com/svn/trunk/(external link)

It contains:

  • demo starter
  • depency checkers
  • installer
  • sdk_fs ??

 
Ask user Kwertz to get write access.

The installer

The SDK installer contains:

The installed folder contains the following files and folders:

  • D: bin - Contains the MOGRE binaries (debug and release)
  • D: includes - Contains the include files to compile plugins against MOGRE
  • D: Lib - Contains the static library files of MOGRE
  • D: Media - Contains the media files required to run the MOGRE demos which can be compiled with the "BuildSamples.cmd" command script (see below)
  • D: Samples - Contains the source code of the MOGRE samples
  • BuildSamples.cmd - Lets you build the MOGRE samples with only one click :-)
  • BuildSamplesX86.cmd - The same as above, but explicitly for 32-bit processors. Try this, if you get a "FileNotFoundException" or a "BadImageFormatException".
  • ChangeLog.txt - This is the change log
  • License.html - Contains the LGPL license text
  • MOGRE SDK.url - This is a link to the MOGRE homepage
  • MogreSamples.sln - The solution containing the sample projects
  • ReadMe.txt - This provides an overview of the MOGRE SDK. Read it!

 
If i install the SDK, then use the build.bat it builds everything, and i can then run the exe's directly from the release dir.

You can also download the installer script (Inno Setup, not NSIS) on this sourceforge page(external link).

Example applications

These example applications are currently included:

  • BSP
    • TODO: include a text that the user can move by WASD and turn by mouse
  • CameraTrack
  • CelShading
  • Compositor
  • Dot3Bump
  • EnvMapping
  • ExampleApplication
  • Fresnel
  • MogreForm
  • SkeletalAnimation
  • TextureFX
  • Transparency

 
TODO: Add Examples from wiki:

Good would be to add the Mogre wiki tutorials to the project, including

(And add a readme.txt file to inform the user about the related wiki page. And he should report problems in the forum)

All basic tutorials can be downloaded here(external link).

They are runnable for Mogre 1.4 (hosted by smiley80). Maybe it's easy to update them to Mogre 1.6.

TODO: Add examples of user smiley80:

Download here(external link)

  • BezierPatch
  • Lighting
  • ParticleFX
  • RenderToTexture
  • SkyBox
  • SkyDome
  • SkyPlane
  • Smoke
  • Terrain

 
TODO examples:

 

The demo starter

User Beauty suggest to create the demo starter like this:

  • each sample is a stand alone application with its own subdirectory
  • the dll files (Mogre and Add-ons) are only in MogreSDK/bin (instead of the sample directories)
  • we use a starter application for the demos
    • Button for checking the Mogre depencies (but don't check for .NET - so we can write the starter in C# - The .NET check should only be done by the SDK installer, not by the demo starter)
    • Button for compile the demos
    • List with all available demos (including Mogre tutorial projects)
    • Short description for the selected demo (e.g. what it shows and which keys can be used)
    • Preview picture (nice to have, but not needed. Can be stored in an image file of the demo subdirectory.)
    • Links (e.g. to Mogre forum, Mogre wiki page, Mogre tutorials)
  • use an XML config file for the demo starter
    • XML is easy to parse with XML libraries of .NET
    • contains all informations about each demo

 
Here is my proposal for the config file:
(in an editor with syntax highlighting its looking nicer)

<demoStarter>
    <demo>
        <name>Fog demo</name>
        <directory>fog</directory>
        <description>Demostrate fog modes. Use space to switch.</description>
        <previewPic>fog/thumbnail.png</previewPic>
        <binary>fog/bin/release/fog.exe</binary>
        <more>...</more>
    </demo>
    <demo>
        <name>...</name>
        <directory>...</directory>
        <description>...</description>
        <previewPic>...</previewPic>
        <binary>...</binary>
        <more>...</more>
    </demo>
</demoStarter>

 

Mogre dependencies

Needed downloads for Mogre 1.6.x:

 

  • Special runtime libraries are needed. Install one of these downloads:

 
In the binary directory of your application you need:

... TODO: improve text ...

  • VC++ 2008 redist + OgreMain.dll
  • RenderSystem_Direct3D9.dll needs the DirectX 9.0c redist (I believe, March 2009 is sufficient)
  • RenderSystem_GL.dll needs some -OpenGL dlls which should come with the driver of your graphics card
  • Plugin_CgProgramManager.dll needs cg.dll
  • Microsoft .NET 2.0

 
Find unknown dependencies:

You can use Reflector(external link) for managed and Dependency Walker(external link) for native dependencies.

The Assembly Binding Log Viewer(external link) should show any bind failures (at least for managed assemblies).

TODO

make lists for

  • dependencies for developers (Visual Studio with all updates etc.)
  • dependencies for end users (vcredist instead of VS - works only for bin/release)
  • dependencies for building Mogre

 
also update the dependencies on related pages:

 
Here are possibly needed download links:
links:

 

Known problems

...

Building

Building Mogre

Sll you need to wrap ogre and build mogre is on the svn.

Follow the instructions of this forum thread(external link). Also look to Building MOGRE 1.6 from source.

Set the "Platform target" to "Any CPU" and the "Output Path" to "..\..\bin\release\"

Building the SDK

  • autowrap Ogre
  • use of the Mogre XML commentation tool to create Mogre comments for Visual Studio
  • maybe by existence of a specific dll file?

 

Todo list

  • How to find out if a DirectX Redistributable package is installed? (and which version)
    • dxdiag.exe shows no information about (Microsoft DirectX diagnosis programm, is included by WinXP (Vista/7?))
    • Maybe include the DirectX web installer(external link)

 

Dependency checker/installer

About

 


It would be nice to have a C++ application that checks which dependencies are still installed and which ones are missing.

The application should show an overview to the user and offer the possiblility to install them (or show download links for it).

The advantage of a plain C++ application is: It shurely can be run, because all dependencies are still in Windows.

This checker application could be used for:

  • including to the SDK
  • including to shipped Ogre applications (end user installer)
  • help to solve problems if Mogre applications doesn't work

 

Useful things


Graphic card drivers

The installer should remind to update the driver of graphic card (and show links of related download pages):

 
Visual C++ 200x Redistributable

Check if vcredist is installed:

Search in this path of registry
HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Installer\UserDate\...
name
DisplayName
value
Microsoft Visual C++ 2008 Redistributable - x86 9.0.21022 (ignore version number on search)
value
Microsoft Visual C++ 2005 Redistributable

 
Maybe on other Windows versions it's different.

.NET Framework Installer for InnoSetup

Look to this page(external link) on codeproject.com.

DotNetInstaller

dotnetinstaller.codeplex.com(external link)

A boostrapper doesn't replace tools like InstallShield, Wise, Visual Studio Setup and Deployment Project or Wix. The goal is to create an application to help users with installing the correct prerequisites. Most real world applications need to install several components to work properly, including Windows Service Packs, Internet Explorer, MDAC or .NET Framework. This kind of applications are most commonly known as bootstrappers. dotNetInstaller is such a bootstrapper.

This is also interesting for shipping Mogre applications.

Solutions


checker by user smiley80

Command line tool, written with FreeBasic.

It does:

  • registry check for .NET
  • file check for DirectX
  • file check for VCRedist (VC++ 2008 SP1 Redist)

 
Tested with:

  • Win XP, 32bit
  • Win 7, 64bit

 
Download: check.zip(external link) (source, exe)

Example output:
.Net Framework 2.0 found.
DirectX 9.0c (March 2009) found.
VC++ 2008 SP1 Redist not found.
Press any key to continue.

checker by user kwertz

Command line tool, written with C++.

It does:

  • check for the .NET Framework 2.0.50727.
  • If .NET is installed, the managed C# GUI application is called.
  • If .NET is not installed, the application will show a Windows message box asking the user if he would like to install .NET. If he clicks 'Yes', the .NET Framework installer is called. (see source code)

 
Download: mogre_net_checker.zip(external link)
(source, exe)

Usage:
netchecker.exe

checker 2 by user kwertz

Full dependency checker, written with PureBasic.

It does:

  • Check for Mogre 1.6.x depencies
  • If one dependency is missing, a message box is shown asking the user if he likes to download the dependency.
  • It takes the path to the managed executable as the only command line parameter.

 
Download: mogre_dependency_checker.zip(external link)
(source, exe)

 


Alias: Mogre_SDK_development


Contributors to this page: Beauty10198 points  and jacmoe133512 points  .
Page last modified on Wednesday 28 of July, 2010 18:43:46 UTC by Beauty10198 points .


The content on this page is licensed under the terms of the Creative Commons Attribution-ShareAlike License.
As an exception, any source code contributed within the content is released into the Public Domain.