Click here to Skip to main content
Click here to Skip to main content

OpenGL Win32 AppWizard

, 19 May 2003
Rate this:
Please Sign up or sign in to vote.
This Custom AppWizard for VC++ 6.0 or VC++.NET creates an OpenGL enabled Win32 application suitable for demos and simple games.

Sample Image - OGLWiz.gif
An example of a generated application

Installation (VC6 version)

Copy OGLWiz.awx and Oglwiz.hlp to your Custom AppWizard directory (probably "C:\Program Files\Microsoft Visual Studio\Common\MSDev98\Template").

Overview of the generated project (VC6 version)

Projects generated with this AppWizard contains two classes:
  • CApp
  • CMainWnd
There is a global instance of CApp (gApp) that owns an instance of CMainWnd (m_pMainWnd). CApp creates the main window, initializes OpenGL, maintains the message pump and manages screen updates. CMainWnd encapsulates the main window and its OpenGL rendering context. CApp notifies CMainWnd of different phases of the OpenGL RC life cycle (by calling CMainWnd::InitScene(), CMainWnd::KillScene() and CMainWnd::DrawScene()). CMainWnd::Tick() is called (by CApp) each time the windows message queue is empty.

This may not be the most elegant OO solution; some of the code in CApp really belongs in CMainWnd, like window creation and (some of the) message handling. But the idea is to let CApp do the grunt work of Win32API and OpenGL setup and leave CMainWnd free to concentrate on what's displayed in the client area.

Using the wizard

Chose to create a new project, selecting "OpenGL Win32 Application" from the list of project types, enter a project name and press OK.

The following options to customize the project are available:

Application

Menu: Check this box to add a menu to the main window.
Keyboard accelerator: Adds a keyboard accelerator resource and processes accelerator keys.
About box: Creates an about dialog and a dialog callback routine. Also adds an About command to the menu (if available).

Main window

Select appearance of the main window.

Window: Creates an overlapped main window with default size.
Fullscreen: Creates a topmost popup window that occupies the entire screen.
Both: Appearence is determined with a switch: If FULLSCREEN is not #defined, the application runs in a window.
Show FPS in caption: Adds code to show Frames Per Second on regular intervals. (Not available in fullscreen mode)

OpenGL Support

Use OpenGL: Adds code to initialize and maintain an OpenGL RC. If this box is not checked, a plain Win32 application is created.
Sample code: Adds code that renders a simple OpenGL scene (spinning cube).
Double buffering: Creates a double-buffered pixel buffer.
Color depth: Number of color bitplanes in each color buffer.
Z-buffer depth: Bit-depth of the Z-buffer.
Background color: Press the button to select background color for main window.

Notes on the VC++.NET appwizard

In VC++.NET, appwizards are no longer compiled plugins, but rather a collection of scripts and template files, with a HTML-based UI. See Readme.txt for installation instructions.

I took the opportunity to change the object model into something that, IMO, is a bit cleaner. Instead of having one class for the window and one class for the application, there is now one abstract base class, CApp, that takes care of window creation, OpenGL initialization etc. The "meat" of the generated app goes in a derived class that overrides a number of virtual functions of CApp. For example, InitScene(), DrawScene() and KillScene() are virtual.

Other than that, the VC++.NET version of the AppWizard behaves basically the same as the VC++6 version.

History

  • 20 May 2003 - Updated VS.NET download

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

Share

About the Author

Ulf Öhlén

Sweden Sweden
No Biography provided

Comments and Discussions

 
GeneralRe: VC++ appwizard?? Pinmemberolmec_the_holy11-Sep-03 23:57 
GeneralProblem... PinmemberAli Khanlarkhani12-Jan-03 21:30 
GeneralRe: Problem... PinmemberUlf Öhlén13-Jan-03 5:25 
Sounds like there's an incorrect ABSOLUTE_PATH in the file
"vcprojects\OGLWiz7.vsz". Make sure that ABSOLUTE_PATH points to the folder where you installed the wizard.
 
--------------
"Aagh!! I'm a victim of a Random Act of Management!"
GeneralRe: Problem... PinmemberJyrki Rasku23-Jan-03 2:09 
GeneralRe: Problem... Pinmemberhain18-Feb-03 12:30 
GeneralRe: Problem... PinmemberSynetech18-Feb-03 14:33 
GeneralRe: Problem... Pinmemberhain19-Feb-03 7:31 
GeneralRe: Problem... PinmemberUlf Öhlén20-Feb-03 3:40 
Generalerreur Pinmemberskysee2-Dec-02 23:03 
GeneralRe: erreur PinsussAnonymous3-Dec-02 0:04 
GeneralRe: erreur PinmemberNing Cao29-Aug-03 21:57 
GeneralNice tool! PinmemberMAJOR25-Sep-02 20:30 
Generalsome problems with it PinmemberSendel4-Jul-02 6:39 
GeneralRe: some problems with it PinmemberUlf Öhlén20-Feb-03 4:50 
GeneralRe: some problems with it PinmemberSendel20-Feb-03 8:47 
Generalreboot PinmemberAnonymous20-May-02 3:19 
GeneralRe: reboot PinmemberC++25-Feb-03 20:46 
GeneralGreat! Pinmemberrajbow30-Jan-02 1:32 
GeneralRe: Great! PinmemberSendel4-Jul-02 11:14 
GeneralRe: Great! PinsussAnonymous23-Sep-02 18:28 
GeneralRe: Great! Pinmembermyaniu1-Apr-03 2:15 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web03 | 2.8.1411022.1 | Last Updated 20 May 2003
Article Copyright 2001 by Ulf Öhlén
Everything else Copyright © CodeProject, 1999-2014
Layout: fixed | fluid