Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/OgreMain/include/gtk/OgreConfigDialogImp.h @ 1

Last change on this file since 1 was 1, checked in by landauf, 17 years ago
File size: 3.6 KB
Line 
1/*
2-----------------------------------------------------------------------------
3This source file is part of OGRE
4    (Object-oriented Graphics Rendering Engine)
5For the latest info, see http://www.ogre3d.org/
6
7Copyright (c) 2000-2006 Torus Knot Software Ltd
8Also see acknowledgements in Readme.html
9
10This program is free software; you can redistribute it and/or modify it under
11the terms of the GNU Lesser General Public License as published by the Free Software
12Foundation; either version 2 of the License, or (at your option) any later
13version.
14
15This program is distributed in the hope that it will be useful, but WITHOUT
16ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
17FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
18
19You should have received a copy of the GNU Lesser General Public License along with
20this program; if not, write to the Free Software Foundation, Inc., 59 Temple
21Place - Suite 330, Boston, MA 02111-1307, USA, or go to
22http://www.gnu.org/copyleft/lesser.txt.
23
24You may alternatively use this source under the terms of a specific version of
25the OGRE Unrestricted License provided you have obtained such a license from
26Torus Knot Software Ltd.
27-----------------------------------------------------------------------------
28*/
29
30#ifndef __GLXCONFIGDIALOG_H__
31#define __GLXCONFIGDIALOG_H__
32
33#include "OgrePrerequisites.h"
34#include "OgreRoot.h"
35#include "OgreRenderSystem.h"
36
37#include <gtk/gtk.h>
38
39namespace Ogre
40{
41    /**
42    Defines the behaviour of an automatic renderer configuration dialog.
43    @remarks
44        OGRE comes with it's own renderer configuration dialog, which
45        applications can use to easily allow the user to configure the
46        settings appropriate to their machine. This class defines the
47        interface to this standard dialog. Because dialogs are inherently
48        tied to a particular platform's windowing system, there will be a
49        different subclass for each platform.
50    @author
51        Andrew Zabolotny <zap@homelink.ru>
52    */
53    class _OgreExport ConfigDialog
54    {
55    public:
56        ConfigDialog();
57
58        /**
59        Displays the dialog.
60        @remarks
61            This method displays the dialog and from then on the dialog
62            interacts with the user independently. The dialog will be
63            calling the relevant OGRE rendering systems to query them for
64            options and to set the options the user selects. The method
65            returns when the user closes the dialog.
66        @returns
67            If the user accepted the dialog, <b>true</b> is returned.
68        @par
69            If the user cancelled the dialog (indicating the application
70            should probably terminate), <b>false</b> is returned.
71        @see
72            RenderSystem
73        */
74        bool display ();
75
76    protected:
77        /// The rendersystem selected by user
78        RenderSystem *mSelectedRenderSystem;
79        /// The dialog window
80        GtkWidget *mDialog;
81        /// The table with renderer parameters
82        GtkWidget *mParamTable;
83
84        /// Create the gtk+ dialog window
85        bool createWindow ();
86        /// Get parameters from selected renderer and fill the dialog
87        void setupRendererParams ();
88        /// Callback function for renderer select combobox
89        static void rendererChanged (GtkComboBox *widget, gpointer data);
90        /// Callback function to change a renderer option
91        static void optionChanged (GtkComboBox *widget, gpointer data);
92    };
93}
94#endif
Note: See TracBrowser for help on using the repository browser.