wxControl and wxDialog coded.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@9786 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -23,96 +23,126 @@ class WXDLLEXPORT wxControl : public wxControlBase
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
wxControl();
|
wxControl();
|
||||||
wxControl(wxWindow *parent,
|
wxControl( wxWindow* pParent
|
||||||
wxWindowID id,
|
,wxWindowID vId
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
,const wxPoint& rPos = wxDefaultPosition
|
||||||
const wxSize& size = wxDefaultSize,
|
,const wxSize& rSize = wxDefaultSize
|
||||||
long style = 0,
|
,long lStyle = 0
|
||||||
#if wxUSE_VALIDATORS
|
#if wxUSE_VALIDATORS
|
||||||
const wxValidator& validator = wxDefaultValidator,
|
,const wxValidator& rValidator = wxDefaultValidator
|
||||||
#endif
|
#endif
|
||||||
const wxString& name = wxControlNameStr)
|
,const wxString& rsName = wxControlNameStr
|
||||||
|
)
|
||||||
{
|
{
|
||||||
Create(parent, id, pos, size, style, validator, name);
|
Create( pParent
|
||||||
|
,vId
|
||||||
|
,rPos
|
||||||
|
,rSize
|
||||||
|
,lStyle
|
||||||
|
,rValidator
|
||||||
|
,rsName
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Create(wxWindow *parent, wxWindowID id,
|
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
|
||||||
const wxSize& size = wxDefaultSize, long style = 0,
|
|
||||||
#if wxUSE_VALIDATORS
|
|
||||||
const wxValidator& validator = wxDefaultValidator,
|
|
||||||
#endif
|
|
||||||
const wxString& name = wxControlNameStr);
|
|
||||||
virtual ~wxControl();
|
virtual ~wxControl();
|
||||||
|
|
||||||
// Simulates an event
|
bool Create( wxWindow* pParent
|
||||||
virtual void Command(wxCommandEvent& event) { ProcessCommand(event); }
|
,wxWindowID vId
|
||||||
|
,const wxPoint& rPos = wxDefaultPosition
|
||||||
|
,const wxSize& rSize = wxDefaultSize
|
||||||
|
,long lStyle = 0
|
||||||
|
#if wxUSE_VALIDATORS
|
||||||
|
,const wxValidator& rValidator = wxDefaultValidator
|
||||||
|
#endif
|
||||||
|
,const wxString& rsName = wxControlNameStr
|
||||||
|
);
|
||||||
|
|
||||||
// implementation from now on
|
//
|
||||||
// --------------------------
|
// Simulates an event
|
||||||
|
//
|
||||||
|
virtual void Command(wxCommandEvent& rEvent) { ProcessCommand(rEvent); }
|
||||||
|
|
||||||
// Calls the callback and appropriate event handlers
|
//
|
||||||
bool ProcessCommand(wxCommandEvent& event);
|
// Implementation from now on
|
||||||
|
// --------------------------
|
||||||
|
//
|
||||||
|
|
||||||
// OS2-specific
|
//
|
||||||
virtual bool OS2OnNotify(int idCtrl, WXLPARAM lParam, WXLPARAM *result);
|
// Calls the callback and appropriate event handlers
|
||||||
|
//
|
||||||
|
bool ProcessCommand(wxCommandEvent& rEvent);
|
||||||
|
|
||||||
// For ownerdraw items
|
//
|
||||||
virtual bool OS2OnDraw(WXDRAWITEMSTRUCT *WXUNUSED(item)) { return FALSE; };
|
// For ownerdraw items
|
||||||
virtual bool OS2OnMeasure(WXMEASUREITEMSTRUCT *WXUNUSED(item)) { return FALSE; };
|
//
|
||||||
|
virtual bool OS2OnDraw(WXDRAWITEMSTRUCT* WXUNUSED(pItem)) { return FALSE; };
|
||||||
|
virtual bool OS2OnMeasure(WXMEASUREITEMSTRUCT* WXUNUSED(pItem)) { return FALSE; };
|
||||||
|
|
||||||
wxArrayLong& GetSubcontrols() { return m_subControls; }
|
wxArrayLong& GetSubcontrols() { return m_aSubControls; }
|
||||||
|
void OnEraseBackground(wxEraseEvent& rEvent);
|
||||||
void OnEraseBackground(wxEraseEvent& event);
|
virtual WXHBRUSH OnCtlColor( WXHDC hDC
|
||||||
|
,WXHWND pWnd
|
||||||
|
,WXUINT nCtlColor
|
||||||
|
,WXUINT uMessage
|
||||||
|
,WXWPARAM wParam
|
||||||
|
,WXLPARAM lParam
|
||||||
|
);
|
||||||
|
|
||||||
#if WXWIN_COMPATIBILITY
|
#if WXWIN_COMPATIBILITY
|
||||||
virtual void SetButtonColour(const wxColour& WXUNUSED(col)) { }
|
virtual void SetButtonColour(const wxColour& WXUNUSED(rCol)) { }
|
||||||
wxColour* GetButtonColour() const { return NULL; }
|
wxColour* GetButtonColour(void) const { return NULL; }
|
||||||
|
|
||||||
inline virtual void SetLabelFont(const wxFont& font);
|
inline virtual void SetLabelFont(const wxFont& rFont);
|
||||||
inline virtual void SetButtonFont(const wxFont& font);
|
inline virtual void SetButtonFont(const wxFont& rFont);
|
||||||
inline wxFont& GetLabelFont() const;
|
inline wxFont& GetLabelFont(void) const;
|
||||||
inline wxFont& GetButtonFont() const;
|
inline wxFont& GetButtonFont(void) const;
|
||||||
|
|
||||||
// Adds callback
|
//
|
||||||
inline void Callback(const wxFunction function);
|
// Adds callback
|
||||||
|
//
|
||||||
wxFunction GetCallback() { return m_callback; }
|
inline void Callback(const wxFunction function);
|
||||||
|
wxFunction GetCallback(void) { return m_callback; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
wxFunction m_callback; // Callback associated with the window
|
wxFunction m_callback; // Callback associated with the window
|
||||||
#endif // WXWIN_COMPATIBILITY
|
#endif // WXWIN_COMPATIBILITY
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// For controls like radiobuttons which are really composite
|
//
|
||||||
wxArrayLong m_subControls;
|
// For controls like radiobuttons which are really composite
|
||||||
|
//
|
||||||
|
wxArrayLong m_aSubControls;
|
||||||
|
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize(void) const;
|
||||||
|
|
||||||
// create the control of the given class with the given style, returns FALSE
|
//
|
||||||
// if creation failed
|
// Create the control of the given class with the given style, returns FALSE
|
||||||
bool OS2CreateControl(const wxChar *classname, WXDWORD style,
|
// if creation failed.
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
//
|
||||||
const wxSize& size = wxDefaultSize,
|
bool OS2CreateControl( const wxChar* zClassname
|
||||||
const wxString& label = wxEmptyString,
|
,WXDWORD dwStyle
|
||||||
WXDWORD exstyle = (WXDWORD)-1);
|
,const wxPoint& rPos = wxDefaultPosition
|
||||||
|
,const wxSize& rSize = wxDefaultSize
|
||||||
|
,const wxString& rsLabel = wxEmptyString
|
||||||
|
,WXDWORD dwExstyle = (WXDWORD)-1
|
||||||
|
);
|
||||||
|
|
||||||
// determine the extended styles combination for this window (may slightly
|
//
|
||||||
// modify styl parameter)
|
// Determine the extended styles combination for this window (may slightly
|
||||||
WXDWORD GetExStyle(WXDWORD& style) const;
|
// modify styl parameter)
|
||||||
|
//
|
||||||
|
WXDWORD GetExStyle(WXDWORD& rStyle) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
};
|
}; // end of wxControl
|
||||||
|
|
||||||
|
|
||||||
#if WXWIN_COMPATIBILITY
|
#if WXWIN_COMPATIBILITY
|
||||||
inline void wxControl::Callback(const wxFunction f) { m_callback = f; };
|
inline void wxControl::Callback(const wxFunction f) { m_callback = f; };
|
||||||
inline wxFont& wxControl::GetLabelFont() const { return GetFont(); }
|
inline wxFont& wxControl::GetLabelFont(void) const { return GetFont(); }
|
||||||
inline wxFont& wxControl::GetButtonFont() const { return GetFont(); }
|
inline wxFont& wxControl::GetButtonFont(void) const { return GetFont(); }
|
||||||
inline void wxControl::SetLabelFont(const wxFont& font) { SetFont(font); }
|
inline void wxControl::SetLabelFont(const wxFont& rFont) { SetFont(rFont); }
|
||||||
inline void wxControl::SetButtonFont(const wxFont& font) { SetFont(font); }
|
inline void wxControl::SetButtonFont(const wxFont& rFont) { SetFont(rFont); }
|
||||||
#endif // WXWIN_COMPATIBILITY
|
#endif // WXWIN_COMPATIBILITY
|
||||||
|
|
||||||
#endif
|
#endif // _WX_CONTROL_H_
|
||||||
// _WX_CONTROL_H_
|
|
||||||
|
@@ -16,126 +16,165 @@
|
|||||||
|
|
||||||
WXDLLEXPORT_DATA(extern const char*) wxDialogNameStr;
|
WXDLLEXPORT_DATA(extern const char*) wxDialogNameStr;
|
||||||
|
|
||||||
|
//
|
||||||
// Dialog boxes
|
// Dialog boxes
|
||||||
|
//
|
||||||
class WXDLLEXPORT wxDialog: public wxDialogBase
|
class WXDLLEXPORT wxDialog: public wxDialogBase
|
||||||
{
|
{
|
||||||
DECLARE_DYNAMIC_CLASS(wxDialog)
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
wxDialog();
|
inline wxDialog() { Init(); }
|
||||||
|
|
||||||
|
//
|
||||||
// Constructor with a modal flag, but no window id - the old convention
|
// Constructor with a modal flag, but no window id - the old convention
|
||||||
inline wxDialog( wxWindow* parent
|
//
|
||||||
,const wxString& title
|
inline wxDialog( wxWindow* pParent
|
||||||
,bool modal
|
,const wxString& rsTitle
|
||||||
,int x = -1
|
,bool bModal
|
||||||
,int y = -1
|
,int nX = -1
|
||||||
,int width = 500
|
,int nY = -1
|
||||||
,int height = 500
|
,int nWidth = 500
|
||||||
,long style = wxDEFAULT_DIALOG_STYLE
|
,int nHeight = 500
|
||||||
,const wxString& name = wxDialogNameStr
|
,long lStyle = wxDEFAULT_DIALOG_STYLE
|
||||||
|
,const wxString& rsName = wxDialogNameStr
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
long modalStyle = modal ? wxDIALOG_MODAL : wxDIALOG_MODELESS ;
|
long lModalStyle = lStyle ? wxDIALOG_MODAL : wxDIALOG_MODELESS ;
|
||||||
Create(parent, -1, title, wxPoint(x, y), wxSize(width, height), style|modalStyle, name);
|
|
||||||
|
Create( pParent
|
||||||
|
,-1
|
||||||
|
,rsTitle
|
||||||
|
,wxPoint(nX, nY)
|
||||||
|
,wxSize(nWidth, nHeight)
|
||||||
|
,lStyle | lModalStyle
|
||||||
|
,rsName
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
// Constructor with no modal flag - the new convention.
|
// Constructor with no modal flag - the new convention.
|
||||||
inline wxDialog( wxWindow* parent
|
//
|
||||||
,wxWindowID id
|
inline wxDialog( wxWindow* pParent
|
||||||
,const wxString& title
|
,wxWindowID vId
|
||||||
,const wxPoint& pos = wxDefaultPosition
|
,const wxString& rsTitle
|
||||||
,const wxSize& size = wxDefaultSize
|
,const wxPoint& rPos = wxDefaultPosition
|
||||||
,long style = wxDEFAULT_DIALOG_STYLE
|
,const wxSize& rSize = wxDefaultSize
|
||||||
,const wxString& name = wxDialogNameStr
|
,long lStyle = wxDEFAULT_DIALOG_STYLE
|
||||||
|
,const wxString& rsName = wxDialogNameStr
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
Create(parent, id, title, pos, size, style, name);
|
Create( pParent
|
||||||
|
,vId
|
||||||
|
,rsTitle
|
||||||
|
,rPos
|
||||||
|
,rSize
|
||||||
|
,lStyle
|
||||||
|
,rsName
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Create( wxWindow* parent
|
bool Create( wxWindow* pParent
|
||||||
,wxWindowID id
|
,wxWindowID vId
|
||||||
,const wxString& title
|
,const wxString& rsTitle
|
||||||
, // bool modal = FALSE, // TODO make this a window style?
|
,const wxPoint& rPos = wxDefaultPosition
|
||||||
const wxPoint& pos = wxDefaultPosition
|
,const wxSize& rSize = wxDefaultSize
|
||||||
,const wxSize& size = wxDefaultSize
|
,long lStyle = wxDEFAULT_DIALOG_STYLE
|
||||||
,long style = wxDEFAULT_DIALOG_STYLE
|
,const wxString& rsName = wxDialogNameStr
|
||||||
,const wxString& name = wxDialogNameStr
|
|
||||||
);
|
);
|
||||||
|
|
||||||
~wxDialog();
|
~wxDialog();
|
||||||
|
|
||||||
virtual bool Destroy();
|
virtual bool Destroy(void);
|
||||||
|
virtual bool Show(bool bShow);
|
||||||
|
virtual void Iconize(bool bIconize);
|
||||||
|
virtual bool IsIconized(void) const;
|
||||||
|
|
||||||
virtual void DoSetClientSize(int width, int height);
|
virtual bool IsTopLevel(void) const { return TRUE; }
|
||||||
|
|
||||||
virtual void GetPosition(int *x, int *y) const;
|
void SetModal(bool bFlag);
|
||||||
|
virtual bool IsModal(void) const;
|
||||||
|
|
||||||
bool Show(bool show);
|
//
|
||||||
bool IsShown() const;
|
// For now, same as Show(TRUE) but returns return code
|
||||||
void Iconize(bool iconize);
|
//
|
||||||
|
virtual int ShowModal(void);
|
||||||
|
virtual void EndModal(int nRetCode);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Returns TRUE if we're in a modal loop
|
||||||
|
//
|
||||||
|
bool IsModalShowing() const;
|
||||||
|
|
||||||
#if WXWIN_COMPATIBILITY
|
#if WXWIN_COMPATIBILITY
|
||||||
bool Iconized() const { return IsIconized(); };
|
bool Iconized() const { return IsIconized(); };
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
virtual bool IsIconized() const;
|
//
|
||||||
void Fit();
|
// Implementation only from now on
|
||||||
|
// -------------------------------
|
||||||
|
//
|
||||||
|
|
||||||
void SetTitle(const wxString& title);
|
//
|
||||||
wxString GetTitle() const ;
|
// Event handlers
|
||||||
|
//
|
||||||
|
bool OnClose(void);
|
||||||
|
void OnCharHook(wxKeyEvent& rEvent);
|
||||||
|
void OnCloseWindow(wxCloseEvent& rEvent);
|
||||||
|
|
||||||
void OnSize(wxSizeEvent& event);
|
//
|
||||||
bool OnClose();
|
// May be called to terminate the dialog with the given return code
|
||||||
void OnCharHook(wxKeyEvent& event);
|
//
|
||||||
void OnPaint(wxPaintEvent& event);
|
|
||||||
void OnCloseWindow(wxCloseEvent& event);
|
|
||||||
|
|
||||||
void SetModal(bool flag);
|
|
||||||
|
|
||||||
virtual void Centre(int direction = wxBOTH);
|
|
||||||
virtual bool IsModal() const;
|
|
||||||
|
|
||||||
// For now, same as Show(TRUE) but returns return code
|
|
||||||
virtual int ShowModal();
|
|
||||||
virtual void EndModal(int retCode);
|
|
||||||
|
|
||||||
|
//
|
||||||
// Standard buttons
|
// Standard buttons
|
||||||
void OnOK(wxCommandEvent& event);
|
//
|
||||||
void OnApply(wxCommandEvent& event);
|
void OnOK(wxCommandEvent& rEvent);
|
||||||
void OnCancel(wxCommandEvent& event);
|
void OnApply(wxCommandEvent& rEvent);
|
||||||
|
void OnCancel(wxCommandEvent& rEvent);
|
||||||
|
|
||||||
|
//
|
||||||
// Responds to colour changes
|
// Responds to colour changes
|
||||||
void OnSysColourChanged(wxSysColourChangedEvent& event);
|
//
|
||||||
|
void OnSysColourChanged(wxSysColourChangedEvent& rEvent);
|
||||||
// implementation
|
|
||||||
// --------------
|
|
||||||
virtual MRESULT OS2WindowProc(WXUINT message, WXWPARAM wParam, WXLPARAM lParam);
|
|
||||||
|
|
||||||
virtual WXHBRUSH OnCtlColor(WXHDC pDC, WXHWND pWnd, WXUINT nCtlColor,
|
|
||||||
WXUINT message, WXWPARAM wParam, WXLPARAM lParam);
|
|
||||||
|
|
||||||
bool IsModalShowing() const { return m_modalShowing; }
|
|
||||||
|
|
||||||
// tooltip management
|
|
||||||
#if wxUSE_TOOLTIPS
|
|
||||||
WXHWND GetToolTipCtrl() const { return m_hwndToolTip; }
|
|
||||||
void SetToolTipCtrl(WXHWND hwndTT) { m_hwndToolTip = hwndTT; }
|
|
||||||
#endif // tooltips
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Callbacks
|
||||||
|
//
|
||||||
|
virtual MRESULT OS2WindowProc( WXUINT uMessage
|
||||||
|
,WXWPARAM wParam
|
||||||
|
,WXLPARAM lParam
|
||||||
|
);
|
||||||
protected:
|
protected:
|
||||||
bool m_modalShowing;
|
//
|
||||||
WXHWND m_hwndOldFocus; // the window which had focus before we were shown
|
// Override more base class virtuals
|
||||||
|
//
|
||||||
|
virtual void DoSetClientSize( int nWidth
|
||||||
|
,int nHeight
|
||||||
|
);
|
||||||
|
virtual void DoGetPosition( int* pnX
|
||||||
|
,int* pnY
|
||||||
|
) const;
|
||||||
|
//
|
||||||
|
// Show modal dialog and enter modal loop
|
||||||
|
//
|
||||||
|
void DoShowModal(void);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Common part of all ctors
|
||||||
|
//
|
||||||
|
void Init();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
#if wxUSE_TOOLTIPS
|
wxWindow* m_pOldFocus;
|
||||||
WXHWND m_hwndToolTip;
|
|
||||||
#endif // tooltips
|
|
||||||
|
|
||||||
private:
|
//
|
||||||
|
// While we are showing a modal dialog we disable the other windows using
|
||||||
|
// this object
|
||||||
|
//
|
||||||
|
class wxWindowDisabler* m_pWindowDisabler;
|
||||||
|
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_DYNAMIC_CLASS(wxDialog)
|
||||||
};
|
DECLARE_EVENT_TABLE()
|
||||||
|
}; // end of CLASS wxDialog
|
||||||
|
|
||||||
|
#endif // _WX_DIALOG_H_
|
||||||
|
|
||||||
#endif
|
|
||||||
// _WX_DIALOG_H_
|
|
||||||
|
Reference in New Issue
Block a user