135 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        wx/msw/app.h
 | |
| // Purpose:     wxApp class
 | |
| // Author:      Julian Smart
 | |
| // Modified by:
 | |
| // Created:     01/02/97
 | |
| // Copyright:   (c) Julian Smart
 | |
| // Licence:     wxWindows licence
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #ifndef _WX_APP_H_
 | |
| #define _WX_APP_H_
 | |
| 
 | |
| #include "wx/event.h"
 | |
| #include "wx/icon.h"
 | |
| 
 | |
| class WXDLLIMPEXP_FWD_CORE wxFrame;
 | |
| class WXDLLIMPEXP_FWD_CORE wxWindow;
 | |
| class WXDLLIMPEXP_FWD_CORE wxApp;
 | |
| class WXDLLIMPEXP_FWD_CORE wxKeyEvent;
 | |
| class WXDLLIMPEXP_FWD_BASE wxLog;
 | |
| 
 | |
| // Represents the application. Derive OnInit and declare
 | |
| // a new App object to start application
 | |
| class WXDLLIMPEXP_CORE wxApp : public wxAppBase
 | |
| {
 | |
| public:
 | |
|     wxApp();
 | |
|     virtual ~wxApp();
 | |
| 
 | |
|     // override base class (pure) virtuals
 | |
|     virtual bool Initialize(int& argc, wxChar **argv) wxOVERRIDE;
 | |
|     virtual void CleanUp() wxOVERRIDE;
 | |
| 
 | |
|     virtual void WakeUpIdle() wxOVERRIDE;
 | |
| 
 | |
|     virtual void SetPrintMode(int mode) wxOVERRIDE { m_printMode = mode; }
 | |
|     virtual int GetPrintMode() const { return m_printMode; }
 | |
| 
 | |
|     // implementation only
 | |
|     void OnIdle(wxIdleEvent& event);
 | |
|     void OnEndSession(wxCloseEvent& event);
 | |
|     void OnQueryEndSession(wxCloseEvent& event);
 | |
| 
 | |
| #if wxUSE_EXCEPTIONS
 | |
|     virtual bool OnExceptionInMainLoop() wxOVERRIDE;
 | |
| #endif // wxUSE_EXCEPTIONS
 | |
| 
 | |
|     // MSW-specific from now on
 | |
|     // ------------------------
 | |
| 
 | |
|     // this suffix should be appended to all our Win32 class names to obtain a
 | |
|     // variant registered without CS_[HV]REDRAW styles
 | |
|     static const wxChar *GetNoRedrawClassSuffix() { return wxT("NR"); }
 | |
| 
 | |
|     // Flags for GetRegisteredClassName()
 | |
|     enum
 | |
|     {
 | |
|         // Just a symbolic name indicating absence of any special flags.
 | |
|         RegClass_Default = 0,
 | |
| 
 | |
|         // Return the name with the GetNoRedrawClassSuffix() appended to it.
 | |
|         RegClass_ReturnNR = 1,
 | |
| 
 | |
|         // Don't register the class with CS_[HV]REDRAW styles. This is useful
 | |
|         // for internal windows for which we can guarantee that they will be
 | |
|         // never created with wxFULL_REPAINT_ON_RESIZE flag.
 | |
|         //
 | |
|         // Notice that this implies RegClass_ReturnNR.
 | |
|         RegClass_OnlyNR = 3
 | |
|     };
 | |
| 
 | |
|     // get the name of the registered Win32 class with the given (unique) base
 | |
|     // name: this function constructs the unique class name using this name as
 | |
|     // prefix, checks if the class is already registered and registers it if it
 | |
|     // isn't and returns the name it was registered under (or NULL if it failed)
 | |
|     //
 | |
|     // the registered class will always have CS_[HV]REDRAW and CS_DBLCLKS
 | |
|     // styles as well as any additional styles specified as arguments here; and
 | |
|     // there will be also a companion registered class identical to this one
 | |
|     // but without CS_[HV]REDRAW whose name will be the same one but with
 | |
|     // GetNoRedrawClassSuffix()
 | |
|     //
 | |
|     // the background brush argument must be either a COLOR_XXX standard value
 | |
|     // or (default) -1 meaning that the class paints its background itself
 | |
|     static const wxChar *GetRegisteredClassName(const wxChar *name,
 | |
|                                                 int bgBrushCol = -1,
 | |
|                                                 int extraStyles = 0,
 | |
|                                                 int flags = RegClass_Default);
 | |
| 
 | |
|     // return true if this name corresponds to one of the classes we registered
 | |
|     // in the previous GetRegisteredClassName() calls
 | |
|     static bool IsRegisteredClassName(const wxString& name);
 | |
| 
 | |
|     // Return the layout direction to use for a window by default.
 | |
|     //
 | |
|     // If the parent is specified, use the same layout direction as it uses.
 | |
|     // Otherwise use the default global layout, either from wxTheApp, if it
 | |
|     // exists, or Windows itself.
 | |
|     //
 | |
|     // Notice that this normally should not be used for the child windows as
 | |
|     // they already inherit, just dialogs such as wxMessageDialog may want to
 | |
|     // use it.
 | |
|     static wxLayoutDirection MSWGetDefaultLayout(wxWindow* parent = NULL);
 | |
| 
 | |
| protected:
 | |
|     int    m_printMode; // wxPRINT_WINDOWS, wxPRINT_POSTSCRIPT
 | |
| 
 | |
| public:
 | |
|     // unregister any window classes registered by GetRegisteredClassName()
 | |
|     static void UnregisterWindowClasses();
 | |
| 
 | |
| #if wxUSE_RICHEDIT
 | |
|     // initialize the richedit DLL of (at least) given version, return true if
 | |
|     // ok
 | |
|     static bool InitRichEdit(int version = 2);
 | |
| #endif // wxUSE_RICHEDIT
 | |
| 
 | |
|     // returns 400, 470, 471 for comctl32.dll 4.00, 4.70, 4.71 or 0 if it
 | |
|     // wasn't found at all
 | |
|     static int GetComCtl32Version();
 | |
| 
 | |
|     // the SW_XXX value to be used for the frames opened by the application
 | |
|     // (currently seems unused which is a bug -- TODO)
 | |
|     static int m_nCmdShow;
 | |
| 
 | |
| protected:
 | |
|     wxDECLARE_EVENT_TABLE();
 | |
|     wxDECLARE_NO_COPY_CLASS(wxApp);
 | |
|     wxDECLARE_DYNAMIC_CLASS(wxApp);
 | |
| };
 | |
| 
 | |
| #endif // _WX_APP_H_
 | |
| 
 |