Added new wxBitmapButton implementation
Build fixes in base classes git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@1001 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
940c60c813
commit
43a1889865
@ -40,36 +40,54 @@ class wxBitmapButton: public wxControl
|
|||||||
{
|
{
|
||||||
DECLARE_DYNAMIC_CLASS(wxBitmapButton)
|
DECLARE_DYNAMIC_CLASS(wxBitmapButton)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
wxBitmapButton();
|
||||||
wxBitmapButton(void);
|
inline wxBitmapButton( wxWindow *parent, wxWindowID id, const wxBitmap& bitmap,
|
||||||
inline wxBitmapButton(wxWindow *parent, wxWindowID id, const wxBitmap& bitmap,
|
const wxPoint& pos = wxDefaultPosition,
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW,
|
||||||
const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW,
|
const wxValidator& validator = wxDefaultValidator,
|
||||||
const wxValidator& validator = wxDefaultValidator,
|
const wxString& name = wxButtonNameStr )
|
||||||
const wxString& name = wxButtonNameStr)
|
{
|
||||||
{
|
|
||||||
Create(parent, id, bitmap, pos, size, style, validator, name);
|
Create(parent, id, bitmap, pos, size, style, validator, name);
|
||||||
}
|
}
|
||||||
bool Create(wxWindow *parent, wxWindowID id, const wxBitmap& bitmap,
|
bool Create( wxWindow *parent, wxWindowID id, const wxBitmap& bitmap,
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
const wxPoint& pos = wxDefaultPosition,
|
||||||
const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW,
|
const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW,
|
||||||
const wxValidator& validator = wxDefaultValidator,
|
const wxValidator& validator = wxDefaultValidator,
|
||||||
const wxString& name = wxButtonNameStr);
|
const wxString& name = wxButtonNameStr);
|
||||||
void SetDefault(void);
|
void SetDefault();
|
||||||
void SetLabel( const wxString &label );
|
|
||||||
wxString GetLabel(void) const;
|
|
||||||
virtual void SetLabel(const wxBitmap& bitmap) { SetBitmapLabel(bitmap); }
|
|
||||||
virtual void SetBitmapLabel( const wxBitmap& bitmap );
|
|
||||||
wxBitmap& GetBitmapLabel(void) const { return (wxBitmap&) m_bitmap; }
|
|
||||||
|
|
||||||
// implementation
|
void SetLabel( const wxString &label );
|
||||||
|
wxString GetLabel() const;
|
||||||
|
virtual void SetLabel( const wxBitmap& bitmap ) { SetBitmapLabel(bitmap); }
|
||||||
|
|
||||||
|
wxBitmap& GetBitmapDisabled() const { return (wxBitmap&) m_disabled; }
|
||||||
|
wxBitmap& GetBitmapFocus() const { return (wxBitmap&) m_focus; }
|
||||||
|
wxBitmap& GetBitmapLabel() const { return (wxBitmap&) m_bitmap; }
|
||||||
|
wxBitmap& GetBitmapSelected() const { return (wxBitmap&) m_selected; }
|
||||||
|
|
||||||
|
void SetBitmapDisabled( const wxBitmap& bitmap );
|
||||||
|
void SetBitmapFocus( const wxBitmap& bitmap );
|
||||||
|
void SetBitmapLabel( const wxBitmap& bitmap );
|
||||||
|
void SetBitmapSelected( const wxBitmap& bitmap );
|
||||||
|
|
||||||
|
virtual void Enable(const bool);
|
||||||
|
|
||||||
void ApplyWidgetStyle();
|
// implementation
|
||||||
|
|
||||||
public:
|
void HasFocus();
|
||||||
|
void NotFocus();
|
||||||
|
void StartSelect();
|
||||||
|
void EndSelect();
|
||||||
|
void SetBitmap();
|
||||||
|
void ApplyWidgetStyle();
|
||||||
|
|
||||||
wxBitmap m_bitmap;
|
bool m_hasFocus;
|
||||||
|
bool m_isSelected;
|
||||||
|
wxBitmap m_bitmap;
|
||||||
|
wxBitmap m_disabled;
|
||||||
|
wxBitmap m_focus;
|
||||||
|
wxBitmap m_selected;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // __BMPBUTTONH__
|
#endif // __BMPBUTTONH__
|
||||||
|
@ -2,13 +2,12 @@
|
|||||||
// Name: dialog.h
|
// Name: dialog.h
|
||||||
// Purpose:
|
// Purpose:
|
||||||
// Author: Robert Roebling
|
// Author: Robert Roebling
|
||||||
// Created: 01/02/97
|
// Created:
|
||||||
// Id: $Id$
|
// Id: $Id$
|
||||||
// Copyright: (c) 1998 Robert Roebling
|
// Copyright: (c) 1998 Robert Roebling
|
||||||
// Licence: wxWindows licence
|
// Licence: wxWindows licence
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
#ifndef __GTKDIALOGH__
|
#ifndef __GTKDIALOGH__
|
||||||
#define __GTKDIALOGH__
|
#define __GTKDIALOGH__
|
||||||
|
|
||||||
@ -20,12 +19,6 @@
|
|||||||
#include "wx/panel.h"
|
#include "wx/panel.h"
|
||||||
#include "wx/icon.h"
|
#include "wx/icon.h"
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// forward decls
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
class wxRadioBox;
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// classes
|
// classes
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -46,53 +39,65 @@ class wxDialog: public wxPanel
|
|||||||
{
|
{
|
||||||
DECLARE_DYNAMIC_CLASS(wxDialog)
|
DECLARE_DYNAMIC_CLASS(wxDialog)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
wxDialog();
|
||||||
wxDialog(void);
|
wxDialog( wxWindow *parent, wxWindowID id,
|
||||||
wxDialog( wxWindow *parent, wxWindowID id, const wxString &title,
|
const wxString &title,
|
||||||
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
|
const wxPoint &pos = wxDefaultPosition,
|
||||||
long style = wxDEFAULT_DIALOG_STYLE, const wxString &name = wxDialogNameStr );
|
const wxSize &size = wxDefaultSize,
|
||||||
bool Create( wxWindow *parent, wxWindowID id, const wxString &title,
|
long style = wxDEFAULT_DIALOG_STYLE,
|
||||||
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
|
const wxString &name = wxDialogNameStr );
|
||||||
long style = wxDEFAULT_DIALOG_STYLE, const wxString &name = wxDialogNameStr );
|
bool Create( wxWindow *parent, wxWindowID id,
|
||||||
~wxDialog(void);
|
const wxString &title,
|
||||||
void SetTitle(const wxString& title);
|
const wxPoint &pos = wxDefaultPosition,
|
||||||
wxString GetTitle(void) const;
|
const wxSize &size = wxDefaultSize,
|
||||||
bool OnClose(void);
|
long style = wxDEFAULT_DIALOG_STYLE,
|
||||||
void OnApply( wxCommandEvent &event );
|
const wxString &name = wxDialogNameStr );
|
||||||
void OnCancel( wxCommandEvent &event );
|
~wxDialog();
|
||||||
void OnOK( wxCommandEvent &event );
|
|
||||||
void OnPaint(wxPaintEvent& event);
|
|
||||||
bool Destroy(void);
|
|
||||||
void OnCloseWindow(wxCloseEvent& event);
|
|
||||||
/*
|
|
||||||
void OnCharHook(wxKeyEvent& event);
|
|
||||||
*/
|
|
||||||
virtual void SetSize( int x, int y, int width, int height,
|
|
||||||
int sizeFlags = wxSIZE_AUTO );
|
|
||||||
virtual bool Show( bool show );
|
|
||||||
virtual int ShowModal(void);
|
|
||||||
virtual void EndModal(int retCode);
|
|
||||||
virtual bool IsModal(void) const;
|
|
||||||
void SetModal( bool modal );
|
|
||||||
virtual void InitDialog(void);
|
|
||||||
virtual void Centre( int direction = wxHORIZONTAL );
|
|
||||||
|
|
||||||
virtual void SetIcon( const wxIcon &icon );
|
|
||||||
virtual void Iconize( bool WXUNUSED(iconize)) { }
|
|
||||||
virtual bool IsIconized(void) const { return FALSE; }
|
|
||||||
bool Iconized(void) const { return IsIconized(); }
|
|
||||||
virtual void Maximize(void) { }
|
|
||||||
virtual void Restore(void) { }
|
|
||||||
|
|
||||||
// implementation
|
|
||||||
|
|
||||||
bool m_modalShowing;
|
void SetTitle(const wxString& title);
|
||||||
wxString m_title;
|
wxString GetTitle() const;
|
||||||
wxIcon m_icon;
|
|
||||||
|
bool OnClose();
|
||||||
|
void OnApply( wxCommandEvent &event );
|
||||||
|
void OnCancel( wxCommandEvent &event );
|
||||||
|
void OnOK( wxCommandEvent &event );
|
||||||
|
void OnPaint(wxPaintEvent& event);
|
||||||
|
/*
|
||||||
|
void OnCharHook( wxKeyEvent& event );
|
||||||
|
*/
|
||||||
|
|
||||||
|
bool Destroy();
|
||||||
|
void OnCloseWindow( wxCloseEvent& event );
|
||||||
|
|
||||||
|
virtual void SetSize( int x, int y, int width, int height,
|
||||||
|
int sizeFlags = wxSIZE_AUTO );
|
||||||
|
virtual void SetSize( int width, int height );
|
||||||
|
|
||||||
|
virtual bool Show( bool show );
|
||||||
|
virtual int ShowModal();
|
||||||
|
virtual void EndModal( int retCode );
|
||||||
|
virtual bool IsModal() const;
|
||||||
|
void SetModal( bool modal );
|
||||||
|
|
||||||
|
virtual void InitDialog(void);
|
||||||
|
|
||||||
|
virtual void Centre( int direction = wxHORIZONTAL );
|
||||||
|
|
||||||
|
virtual void SetIcon( const wxIcon &icon );
|
||||||
|
virtual void Iconize( bool WXUNUSED(iconize)) { }
|
||||||
|
virtual bool IsIconized() const { return FALSE; }
|
||||||
|
bool Iconized() const { return IsIconized(); }
|
||||||
|
virtual void Maximize() { }
|
||||||
|
virtual void Restore() { }
|
||||||
|
|
||||||
|
// implementation
|
||||||
|
|
||||||
|
bool m_modalShowing;
|
||||||
|
wxString m_title;
|
||||||
|
wxIcon m_icon;
|
||||||
|
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // __GTKDIALOGH__
|
#endif // __GTKDIALOGH__
|
||||||
|
@ -66,6 +66,7 @@ public:
|
|||||||
|
|
||||||
virtual void SetSize( int x, int y, int width, int height,
|
virtual void SetSize( int x, int y, int width, int height,
|
||||||
int sizeFlags = wxSIZE_AUTO );
|
int sizeFlags = wxSIZE_AUTO );
|
||||||
|
virtual void SetSize( int width, int height );
|
||||||
|
|
||||||
virtual wxStatusBar* CreateStatusBar(int number=1, long style = wxST_SIZEGRIP, wxWindowID id = 0,
|
virtual wxStatusBar* CreateStatusBar(int number=1, long style = wxST_SIZEGRIP, wxWindowID id = 0,
|
||||||
const wxString& name = "statusBar");
|
const wxString& name = "statusBar");
|
||||||
|
@ -40,36 +40,54 @@ class wxBitmapButton: public wxControl
|
|||||||
{
|
{
|
||||||
DECLARE_DYNAMIC_CLASS(wxBitmapButton)
|
DECLARE_DYNAMIC_CLASS(wxBitmapButton)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
wxBitmapButton();
|
||||||
wxBitmapButton(void);
|
inline wxBitmapButton( wxWindow *parent, wxWindowID id, const wxBitmap& bitmap,
|
||||||
inline wxBitmapButton(wxWindow *parent, wxWindowID id, const wxBitmap& bitmap,
|
const wxPoint& pos = wxDefaultPosition,
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW,
|
||||||
const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW,
|
const wxValidator& validator = wxDefaultValidator,
|
||||||
const wxValidator& validator = wxDefaultValidator,
|
const wxString& name = wxButtonNameStr )
|
||||||
const wxString& name = wxButtonNameStr)
|
{
|
||||||
{
|
|
||||||
Create(parent, id, bitmap, pos, size, style, validator, name);
|
Create(parent, id, bitmap, pos, size, style, validator, name);
|
||||||
}
|
}
|
||||||
bool Create(wxWindow *parent, wxWindowID id, const wxBitmap& bitmap,
|
bool Create( wxWindow *parent, wxWindowID id, const wxBitmap& bitmap,
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
const wxPoint& pos = wxDefaultPosition,
|
||||||
const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW,
|
const wxSize& size = wxDefaultSize, long style = wxBU_AUTODRAW,
|
||||||
const wxValidator& validator = wxDefaultValidator,
|
const wxValidator& validator = wxDefaultValidator,
|
||||||
const wxString& name = wxButtonNameStr);
|
const wxString& name = wxButtonNameStr);
|
||||||
void SetDefault(void);
|
void SetDefault();
|
||||||
void SetLabel( const wxString &label );
|
|
||||||
wxString GetLabel(void) const;
|
|
||||||
virtual void SetLabel(const wxBitmap& bitmap) { SetBitmapLabel(bitmap); }
|
|
||||||
virtual void SetBitmapLabel( const wxBitmap& bitmap );
|
|
||||||
wxBitmap& GetBitmapLabel(void) const { return (wxBitmap&) m_bitmap; }
|
|
||||||
|
|
||||||
// implementation
|
void SetLabel( const wxString &label );
|
||||||
|
wxString GetLabel() const;
|
||||||
|
virtual void SetLabel( const wxBitmap& bitmap ) { SetBitmapLabel(bitmap); }
|
||||||
|
|
||||||
|
wxBitmap& GetBitmapDisabled() const { return (wxBitmap&) m_disabled; }
|
||||||
|
wxBitmap& GetBitmapFocus() const { return (wxBitmap&) m_focus; }
|
||||||
|
wxBitmap& GetBitmapLabel() const { return (wxBitmap&) m_bitmap; }
|
||||||
|
wxBitmap& GetBitmapSelected() const { return (wxBitmap&) m_selected; }
|
||||||
|
|
||||||
|
void SetBitmapDisabled( const wxBitmap& bitmap );
|
||||||
|
void SetBitmapFocus( const wxBitmap& bitmap );
|
||||||
|
void SetBitmapLabel( const wxBitmap& bitmap );
|
||||||
|
void SetBitmapSelected( const wxBitmap& bitmap );
|
||||||
|
|
||||||
|
virtual void Enable(const bool);
|
||||||
|
|
||||||
void ApplyWidgetStyle();
|
// implementation
|
||||||
|
|
||||||
public:
|
void HasFocus();
|
||||||
|
void NotFocus();
|
||||||
|
void StartSelect();
|
||||||
|
void EndSelect();
|
||||||
|
void SetBitmap();
|
||||||
|
void ApplyWidgetStyle();
|
||||||
|
|
||||||
wxBitmap m_bitmap;
|
bool m_hasFocus;
|
||||||
|
bool m_isSelected;
|
||||||
|
wxBitmap m_bitmap;
|
||||||
|
wxBitmap m_disabled;
|
||||||
|
wxBitmap m_focus;
|
||||||
|
wxBitmap m_selected;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // __BMPBUTTONH__
|
#endif // __BMPBUTTONH__
|
||||||
|
@ -2,13 +2,12 @@
|
|||||||
// Name: dialog.h
|
// Name: dialog.h
|
||||||
// Purpose:
|
// Purpose:
|
||||||
// Author: Robert Roebling
|
// Author: Robert Roebling
|
||||||
// Created: 01/02/97
|
// Created:
|
||||||
// Id: $Id$
|
// Id: $Id$
|
||||||
// Copyright: (c) 1998 Robert Roebling
|
// Copyright: (c) 1998 Robert Roebling
|
||||||
// Licence: wxWindows licence
|
// Licence: wxWindows licence
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
#ifndef __GTKDIALOGH__
|
#ifndef __GTKDIALOGH__
|
||||||
#define __GTKDIALOGH__
|
#define __GTKDIALOGH__
|
||||||
|
|
||||||
@ -20,12 +19,6 @@
|
|||||||
#include "wx/panel.h"
|
#include "wx/panel.h"
|
||||||
#include "wx/icon.h"
|
#include "wx/icon.h"
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// forward decls
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
class wxRadioBox;
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// classes
|
// classes
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -46,53 +39,65 @@ class wxDialog: public wxPanel
|
|||||||
{
|
{
|
||||||
DECLARE_DYNAMIC_CLASS(wxDialog)
|
DECLARE_DYNAMIC_CLASS(wxDialog)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
wxDialog();
|
||||||
wxDialog(void);
|
wxDialog( wxWindow *parent, wxWindowID id,
|
||||||
wxDialog( wxWindow *parent, wxWindowID id, const wxString &title,
|
const wxString &title,
|
||||||
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
|
const wxPoint &pos = wxDefaultPosition,
|
||||||
long style = wxDEFAULT_DIALOG_STYLE, const wxString &name = wxDialogNameStr );
|
const wxSize &size = wxDefaultSize,
|
||||||
bool Create( wxWindow *parent, wxWindowID id, const wxString &title,
|
long style = wxDEFAULT_DIALOG_STYLE,
|
||||||
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
|
const wxString &name = wxDialogNameStr );
|
||||||
long style = wxDEFAULT_DIALOG_STYLE, const wxString &name = wxDialogNameStr );
|
bool Create( wxWindow *parent, wxWindowID id,
|
||||||
~wxDialog(void);
|
const wxString &title,
|
||||||
void SetTitle(const wxString& title);
|
const wxPoint &pos = wxDefaultPosition,
|
||||||
wxString GetTitle(void) const;
|
const wxSize &size = wxDefaultSize,
|
||||||
bool OnClose(void);
|
long style = wxDEFAULT_DIALOG_STYLE,
|
||||||
void OnApply( wxCommandEvent &event );
|
const wxString &name = wxDialogNameStr );
|
||||||
void OnCancel( wxCommandEvent &event );
|
~wxDialog();
|
||||||
void OnOK( wxCommandEvent &event );
|
|
||||||
void OnPaint(wxPaintEvent& event);
|
|
||||||
bool Destroy(void);
|
|
||||||
void OnCloseWindow(wxCloseEvent& event);
|
|
||||||
/*
|
|
||||||
void OnCharHook(wxKeyEvent& event);
|
|
||||||
*/
|
|
||||||
virtual void SetSize( int x, int y, int width, int height,
|
|
||||||
int sizeFlags = wxSIZE_AUTO );
|
|
||||||
virtual bool Show( bool show );
|
|
||||||
virtual int ShowModal(void);
|
|
||||||
virtual void EndModal(int retCode);
|
|
||||||
virtual bool IsModal(void) const;
|
|
||||||
void SetModal( bool modal );
|
|
||||||
virtual void InitDialog(void);
|
|
||||||
virtual void Centre( int direction = wxHORIZONTAL );
|
|
||||||
|
|
||||||
virtual void SetIcon( const wxIcon &icon );
|
|
||||||
virtual void Iconize( bool WXUNUSED(iconize)) { }
|
|
||||||
virtual bool IsIconized(void) const { return FALSE; }
|
|
||||||
bool Iconized(void) const { return IsIconized(); }
|
|
||||||
virtual void Maximize(void) { }
|
|
||||||
virtual void Restore(void) { }
|
|
||||||
|
|
||||||
// implementation
|
|
||||||
|
|
||||||
bool m_modalShowing;
|
void SetTitle(const wxString& title);
|
||||||
wxString m_title;
|
wxString GetTitle() const;
|
||||||
wxIcon m_icon;
|
|
||||||
|
bool OnClose();
|
||||||
|
void OnApply( wxCommandEvent &event );
|
||||||
|
void OnCancel( wxCommandEvent &event );
|
||||||
|
void OnOK( wxCommandEvent &event );
|
||||||
|
void OnPaint(wxPaintEvent& event);
|
||||||
|
/*
|
||||||
|
void OnCharHook( wxKeyEvent& event );
|
||||||
|
*/
|
||||||
|
|
||||||
|
bool Destroy();
|
||||||
|
void OnCloseWindow( wxCloseEvent& event );
|
||||||
|
|
||||||
|
virtual void SetSize( int x, int y, int width, int height,
|
||||||
|
int sizeFlags = wxSIZE_AUTO );
|
||||||
|
virtual void SetSize( int width, int height );
|
||||||
|
|
||||||
|
virtual bool Show( bool show );
|
||||||
|
virtual int ShowModal();
|
||||||
|
virtual void EndModal( int retCode );
|
||||||
|
virtual bool IsModal() const;
|
||||||
|
void SetModal( bool modal );
|
||||||
|
|
||||||
|
virtual void InitDialog(void);
|
||||||
|
|
||||||
|
virtual void Centre( int direction = wxHORIZONTAL );
|
||||||
|
|
||||||
|
virtual void SetIcon( const wxIcon &icon );
|
||||||
|
virtual void Iconize( bool WXUNUSED(iconize)) { }
|
||||||
|
virtual bool IsIconized() const { return FALSE; }
|
||||||
|
bool Iconized() const { return IsIconized(); }
|
||||||
|
virtual void Maximize() { }
|
||||||
|
virtual void Restore() { }
|
||||||
|
|
||||||
|
// implementation
|
||||||
|
|
||||||
|
bool m_modalShowing;
|
||||||
|
wxString m_title;
|
||||||
|
wxIcon m_icon;
|
||||||
|
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // __GTKDIALOGH__
|
#endif // __GTKDIALOGH__
|
||||||
|
@ -66,6 +66,7 @@ public:
|
|||||||
|
|
||||||
virtual void SetSize( int x, int y, int width, int height,
|
virtual void SetSize( int x, int y, int width, int height,
|
||||||
int sizeFlags = wxSIZE_AUTO );
|
int sizeFlags = wxSIZE_AUTO );
|
||||||
|
virtual void SetSize( int width, int height );
|
||||||
|
|
||||||
virtual wxStatusBar* CreateStatusBar(int number=1, long style = wxST_SIZEGRIP, wxWindowID id = 0,
|
virtual wxStatusBar* CreateStatusBar(int number=1, long style = wxST_SIZEGRIP, wxWindowID id = 0,
|
||||||
const wxString& name = "statusBar");
|
const wxString& name = "statusBar");
|
||||||
|
@ -31,12 +31,60 @@ extern bool g_blockEventsOnDrag;
|
|||||||
|
|
||||||
static void gtk_bmpbutton_clicked_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
static void gtk_bmpbutton_clicked_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
{
|
{
|
||||||
if (!button->HasVMT()) return;
|
if (!button->HasVMT()) return;
|
||||||
if (g_blockEventsOnDrag) return;
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
wxCommandEvent event(wxEVT_COMMAND_BUTTON_CLICKED, button->GetId());
|
wxCommandEvent event(wxEVT_COMMAND_BUTTON_CLICKED, button->GetId());
|
||||||
event.SetEventObject(button);
|
event.SetEventObject(button);
|
||||||
button->GetEventHandler()->ProcessEvent(event);
|
button->GetEventHandler()->ProcessEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// "enter"
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void gtk_bmpbutton_enter_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
|
{
|
||||||
|
if (!button->HasVMT()) return;
|
||||||
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
|
button->HasFocus();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// "leave"
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void gtk_bmpbutton_leave_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
|
{
|
||||||
|
if (!button->HasVMT()) return;
|
||||||
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
|
button->NotFocus();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// "pressed"
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void gtk_bmpbutton_press_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
|
{
|
||||||
|
if (!button->HasVMT()) return;
|
||||||
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
|
button->StartSelect();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// "released"
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void gtk_bmpbutton_release_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
|
{
|
||||||
|
if (!button->HasVMT()) return;
|
||||||
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
|
button->EndSelect();
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -45,96 +93,198 @@ static void gtk_bmpbutton_clicked_callback( GtkWidget *WXUNUSED(widget), wxBitma
|
|||||||
|
|
||||||
IMPLEMENT_DYNAMIC_CLASS(wxBitmapButton,wxControl)
|
IMPLEMENT_DYNAMIC_CLASS(wxBitmapButton,wxControl)
|
||||||
|
|
||||||
wxBitmapButton::wxBitmapButton(void)
|
wxBitmapButton::wxBitmapButton()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxBitmapButton::Create( wxWindow *parent, wxWindowID id, const wxBitmap &bitmap,
|
bool wxBitmapButton::Create( wxWindow *parent, wxWindowID id, const wxBitmap &bitmap,
|
||||||
const wxPoint &pos, const wxSize &size,
|
const wxPoint &pos, const wxSize &size,
|
||||||
long style, const wxValidator& validator, const wxString &name )
|
long style, const wxValidator& validator, const wxString &name )
|
||||||
{
|
{
|
||||||
m_needParent = TRUE;
|
m_needParent = TRUE;
|
||||||
|
|
||||||
wxSize newSize = size;
|
wxSize newSize = size;
|
||||||
|
|
||||||
PreCreation( parent, id, pos, newSize, style, name );
|
PreCreation( parent, id, pos, newSize, style, name );
|
||||||
|
|
||||||
SetValidator( validator );
|
SetValidator( validator );
|
||||||
|
|
||||||
m_bitmap = bitmap;
|
m_bitmap = bitmap;
|
||||||
m_label = "";
|
m_disabled = bitmap;
|
||||||
|
m_focus = bitmap;
|
||||||
|
m_selected = bitmap;
|
||||||
|
|
||||||
m_widget = gtk_button_new();
|
m_label = "";
|
||||||
|
|
||||||
if (m_bitmap.Ok())
|
m_widget = gtk_button_new();
|
||||||
{
|
|
||||||
GdkBitmap *mask = (GdkBitmap *) NULL;
|
if (m_bitmap.Ok())
|
||||||
if (m_bitmap.GetMask()) mask = m_bitmap.GetMask()->GetBitmap();
|
{
|
||||||
GtkWidget *pixmap = gtk_pixmap_new( m_bitmap.GetPixmap(), mask );
|
GdkBitmap *mask = (GdkBitmap *) NULL;
|
||||||
|
if (m_bitmap.GetMask()) mask = m_bitmap.GetMask()->GetBitmap();
|
||||||
|
GtkWidget *pixmap = gtk_pixmap_new( m_bitmap.GetPixmap(), mask );
|
||||||
|
|
||||||
gtk_widget_show( pixmap );
|
gtk_widget_show( pixmap );
|
||||||
gtk_container_add( GTK_CONTAINER(m_widget), pixmap );
|
gtk_container_add( GTK_CONTAINER(m_widget), pixmap );
|
||||||
}
|
}
|
||||||
|
|
||||||
if (newSize.x == -1) newSize.x = m_bitmap.GetHeight()+10;
|
if (newSize.x == -1) newSize.x = m_bitmap.GetHeight()+10;
|
||||||
if (newSize.y == -1) newSize.y = m_bitmap.GetWidth()+10;
|
if (newSize.y == -1) newSize.y = m_bitmap.GetWidth()+10;
|
||||||
SetSize( newSize.x, newSize.y );
|
SetSize( newSize.x, newSize.y );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(m_widget), "clicked",
|
gtk_signal_connect( GTK_OBJECT(m_widget), "clicked",
|
||||||
GTK_SIGNAL_FUNC(gtk_bmpbutton_clicked_callback), (gpointer*)this );
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_clicked_callback), (gpointer*)this );
|
||||||
|
|
||||||
m_parent->AddChild( this );
|
gtk_signal_connect( GTK_OBJECT(m_widget), "enter",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_enter_callback), (gpointer*)this );
|
||||||
|
gtk_signal_connect( GTK_OBJECT(m_widget), "leave",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_leave_callback), (gpointer*)this );
|
||||||
|
gtk_signal_connect( GTK_OBJECT(m_widget), "pressed",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_press_callback), (gpointer*)this );
|
||||||
|
gtk_signal_connect( GTK_OBJECT(m_widget), "released",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_release_callback), (gpointer*)this );
|
||||||
|
|
||||||
|
m_parent->AddChild( this );
|
||||||
|
|
||||||
(m_parent->m_insertCallback)( m_parent, this );
|
(m_parent->m_insertCallback)( m_parent, this );
|
||||||
|
|
||||||
PostCreation();
|
PostCreation();
|
||||||
|
|
||||||
SetBackgroundColour( parent->GetBackgroundColour() );
|
SetBackgroundColour( parent->GetBackgroundColour() );
|
||||||
|
|
||||||
Show( TRUE );
|
Show( TRUE );
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxBitmapButton::SetDefault(void)
|
void wxBitmapButton::SetDefault()
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
GTK_WIDGET_SET_FLAGS( m_widget, GTK_CAN_DEFAULT );
|
GTK_WIDGET_SET_FLAGS( m_widget, GTK_CAN_DEFAULT );
|
||||||
gtk_widget_grab_default( m_widget );
|
gtk_widget_grab_default( m_widget );
|
||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxBitmapButton::SetLabel( const wxString &label )
|
void wxBitmapButton::SetLabel( const wxString &label )
|
||||||
{
|
{
|
||||||
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
wxControl::SetLabel( label );
|
wxControl::SetLabel( label );
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxBitmapButton::GetLabel(void) const
|
wxString wxBitmapButton::GetLabel() const
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( m_widget != NULL, "", "invalid button" );
|
wxCHECK_MSG( m_widget != NULL, "", "invalid button" );
|
||||||
|
|
||||||
return wxControl::GetLabel();
|
return wxControl::GetLabel();
|
||||||
}
|
|
||||||
|
|
||||||
void wxBitmapButton::SetBitmapLabel( const wxBitmap& bitmap )
|
|
||||||
{
|
|
||||||
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
|
||||||
|
|
||||||
m_bitmap = bitmap;
|
|
||||||
if (!m_bitmap.Ok()) return;
|
|
||||||
|
|
||||||
GtkButton *bin = GTK_BUTTON( m_widget );
|
|
||||||
GtkPixmap *g_pixmap = GTK_PIXMAP( bin->child );
|
|
||||||
|
|
||||||
GdkBitmap *mask = (GdkBitmap *) NULL;
|
|
||||||
if (m_bitmap.GetMask()) mask = m_bitmap.GetMask()->GetBitmap();
|
|
||||||
|
|
||||||
gtk_pixmap_set( g_pixmap, m_bitmap.GetPixmap(), mask );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxBitmapButton::ApplyWidgetStyle()
|
void wxBitmapButton::ApplyWidgetStyle()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmap()
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
wxBitmap the_one;
|
||||||
|
|
||||||
|
if ( ! m_isEnabled )
|
||||||
|
the_one = m_disabled;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( m_isSelected )
|
||||||
|
{
|
||||||
|
the_one = m_selected;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( m_hasFocus )
|
||||||
|
the_one = m_focus;
|
||||||
|
else
|
||||||
|
the_one = m_bitmap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! the_one.Ok() ) the_one = m_bitmap;
|
||||||
|
if ( ! the_one.Ok() ) return;
|
||||||
|
|
||||||
|
GtkButton *bin = GTK_BUTTON( m_widget );
|
||||||
|
GtkPixmap *g_pixmap = GTK_PIXMAP( bin->child );
|
||||||
|
|
||||||
|
GdkBitmap *mask = (GdkBitmap *) NULL;
|
||||||
|
if (the_one.GetMask()) mask = the_one.GetMask()->GetBitmap();
|
||||||
|
|
||||||
|
gtk_pixmap_set( g_pixmap, the_one.GetPixmap(), mask );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmapDisabled( const wxBitmap& bitmap )
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
if ( ! m_disabled.Ok() ) return;
|
||||||
|
m_disabled = bitmap;
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmapFocus( const wxBitmap& bitmap )
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
if ( ! m_focus.Ok() ) return;
|
||||||
|
m_focus = bitmap;
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmapLabel( const wxBitmap& bitmap )
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
if (!m_bitmap.Ok()) return;
|
||||||
|
m_bitmap = bitmap;
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmapSelected( const wxBitmap& bitmap )
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
if ( ! m_selected.Ok() ) return;
|
||||||
|
m_selected = bitmap;
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::Enable( const bool enable )
|
||||||
|
{
|
||||||
|
wxWindow::Enable(enable);
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::HasFocus()
|
||||||
|
{
|
||||||
|
m_hasFocus = TRUE;
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::NotFocus()
|
||||||
|
{
|
||||||
|
m_hasFocus = FALSE;
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::StartSelect()
|
||||||
|
{
|
||||||
|
m_isSelected = TRUE;
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::EndSelect()
|
||||||
|
{
|
||||||
|
m_isSelected = FALSE;
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
@ -51,7 +51,7 @@ END_EVENT_TABLE()
|
|||||||
|
|
||||||
IMPLEMENT_DYNAMIC_CLASS(wxDialog,wxPanel)
|
IMPLEMENT_DYNAMIC_CLASS(wxDialog,wxPanel)
|
||||||
|
|
||||||
wxDialog::wxDialog(void)
|
wxDialog::wxDialog()
|
||||||
{
|
{
|
||||||
m_title = "";
|
m_title = "";
|
||||||
m_modalShowing = FALSE;
|
m_modalShowing = FALSE;
|
||||||
@ -106,20 +106,20 @@ bool wxDialog::Create( wxWindow *parent,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxDialog::~wxDialog(void)
|
wxDialog::~wxDialog()
|
||||||
{
|
{
|
||||||
wxTopLevelWindows.DeleteObject( this );
|
wxTopLevelWindows.DeleteObject( this );
|
||||||
if (wxTopLevelWindows.Number() == 0) wxTheApp->ExitMainLoop();
|
if (wxTopLevelWindows.Number() == 0) wxTheApp->ExitMainLoop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialog::SetTitle(const wxString& title )
|
void wxDialog::SetTitle( const wxString& title )
|
||||||
{
|
{
|
||||||
m_title = title;
|
m_title = title;
|
||||||
if (m_title.IsNull()) m_title = "";
|
if (m_title.IsNull()) m_title = "";
|
||||||
gtk_window_set_title( GTK_WINDOW(m_widget), m_title );
|
gtk_window_set_title( GTK_WINDOW(m_widget), m_title );
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxDialog::GetTitle(void) const
|
wxString wxDialog::GetTitle() const
|
||||||
{
|
{
|
||||||
return (wxString&)m_title;
|
return (wxString&)m_title;
|
||||||
}
|
}
|
||||||
@ -163,7 +163,7 @@ void wxDialog::OnPaint( wxPaintEvent& WXUNUSED(event) )
|
|||||||
// yes
|
// yes
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxDialog::OnClose(void)
|
bool wxDialog::OnClose()
|
||||||
{
|
{
|
||||||
static wxList closing;
|
static wxList closing;
|
||||||
|
|
||||||
@ -179,14 +179,14 @@ bool wxDialog::OnClose(void)
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxDialog::Destroy(void)
|
bool wxDialog::Destroy()
|
||||||
{
|
{
|
||||||
if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
|
if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialog::OnCloseWindow(wxCloseEvent& event)
|
void wxDialog::OnCloseWindow( wxCloseEvent& event )
|
||||||
{
|
{
|
||||||
if (GetEventHandler()->OnClose() || event.GetForce())
|
if (GetEventHandler()->OnClose() || event.GetForce())
|
||||||
{
|
{
|
||||||
@ -259,11 +259,17 @@ void wxDialog::SetSize( int x, int y, int width, int height, int sizeFlags )
|
|||||||
m_resizing = FALSE;
|
m_resizing = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxDialog::SetSize( int width, int height )
|
||||||
|
{
|
||||||
|
SetSize( -1, -1, width, height, wxSIZE_USE_EXISTING );
|
||||||
|
}
|
||||||
|
|
||||||
void wxDialog::Centre( int direction )
|
void wxDialog::Centre( int direction )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
||||||
|
|
||||||
int x,y;
|
int x = 0;
|
||||||
|
int y = 0;
|
||||||
|
|
||||||
if (direction & wxHORIZONTAL == wxHORIZONTAL) x = (gdk_screen_width () - m_width) / 2;
|
if (direction & wxHORIZONTAL == wxHORIZONTAL) x = (gdk_screen_width () - m_width) / 2;
|
||||||
if (direction & wxVERTICAL == wxVERTICAL) y = (gdk_screen_height () - m_height) / 2;
|
if (direction & wxVERTICAL == wxVERTICAL) y = (gdk_screen_height () - m_height) / 2;
|
||||||
@ -285,7 +291,7 @@ bool wxDialog::Show( bool show )
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxDialog::IsModal(void) const
|
bool wxDialog::IsModal() const
|
||||||
{
|
{
|
||||||
return m_modalShowing;
|
return m_modalShowing;
|
||||||
}
|
}
|
||||||
@ -301,7 +307,7 @@ void wxDialog::SetModal( bool WXUNUSED(flag) )
|
|||||||
wxFAIL_MSG( "wxDialog:SetModal obsolete now" );
|
wxFAIL_MSG( "wxDialog:SetModal obsolete now" );
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxDialog::ShowModal(void)
|
int wxDialog::ShowModal()
|
||||||
{
|
{
|
||||||
if (IsModal())
|
if (IsModal())
|
||||||
{
|
{
|
||||||
@ -337,7 +343,7 @@ void wxDialog::EndModal( int retCode )
|
|||||||
Show( FALSE );
|
Show( FALSE );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialog::InitDialog(void)
|
void wxDialog::InitDialog()
|
||||||
{
|
{
|
||||||
wxWindow::InitDialog();
|
wxWindow::InitDialog();
|
||||||
}
|
}
|
||||||
|
@ -284,11 +284,17 @@ void wxFrame::SetSize( int x, int y, int width, int height, int sizeFlags )
|
|||||||
m_resizing = FALSE;
|
m_resizing = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxFrame::SetSize( int width, int height )
|
||||||
|
{
|
||||||
|
SetSize( -1, -1, width, height, wxSIZE_USE_EXISTING );
|
||||||
|
}
|
||||||
|
|
||||||
void wxFrame::Centre( int direction )
|
void wxFrame::Centre( int direction )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
||||||
|
|
||||||
int x,y;
|
int x = 0;
|
||||||
|
int y = 0;
|
||||||
|
|
||||||
if (direction & wxHORIZONTAL == wxHORIZONTAL) x = (gdk_screen_width () - m_width) / 2;
|
if (direction & wxHORIZONTAL == wxHORIZONTAL) x = (gdk_screen_width () - m_width) / 2;
|
||||||
if (direction & wxVERTICAL == wxVERTICAL) y = (gdk_screen_height () - m_height) / 2;
|
if (direction & wxVERTICAL == wxVERTICAL) y = (gdk_screen_height () - m_height) / 2;
|
||||||
@ -348,10 +354,6 @@ void wxFrame::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int height
|
|||||||
if ((m_maxWidth != -1) && (m_width > m_maxWidth)) m_width = m_minWidth;
|
if ((m_maxWidth != -1) && (m_width > m_maxWidth)) m_width = m_minWidth;
|
||||||
if ((m_maxHeight != -1) && (m_height > m_maxHeight)) m_height = m_minHeight;
|
if ((m_maxHeight != -1) && (m_height > m_maxHeight)) m_height = m_minHeight;
|
||||||
|
|
||||||
wxSizeEvent event( wxSize(m_width,m_height), GetId() );
|
|
||||||
event.SetEventObject( this );
|
|
||||||
ProcessEvent( event );
|
|
||||||
|
|
||||||
gtk_widget_set_usize( m_widget, m_width, m_height );
|
gtk_widget_set_usize( m_widget, m_width, m_height );
|
||||||
|
|
||||||
// This emulates the new wxMSW behaviour
|
// This emulates the new wxMSW behaviour
|
||||||
@ -390,6 +392,10 @@ void wxFrame::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int height
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_sizeSet = TRUE;
|
m_sizeSet = TRUE;
|
||||||
|
|
||||||
|
wxSizeEvent event( wxSize(m_width,m_height), GetId() );
|
||||||
|
event.SetEventObject( this );
|
||||||
|
ProcessEvent( event );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
||||||
|
@ -1092,248 +1092,248 @@ bool wxWindow::Create( wxWindow *parent, wxWindowID id,
|
|||||||
|
|
||||||
wxWindow::~wxWindow()
|
wxWindow::~wxWindow()
|
||||||
{
|
{
|
||||||
m_hasVMT = FALSE;
|
m_hasVMT = FALSE;
|
||||||
|
|
||||||
if (m_dropTarget) delete m_dropTarget;
|
if (m_dropTarget) delete m_dropTarget;
|
||||||
|
|
||||||
if (m_parent) m_parent->RemoveChild( this );
|
if (m_parent) m_parent->RemoveChild( this );
|
||||||
if (m_widget) Show( FALSE );
|
if (m_widget) Show( FALSE );
|
||||||
|
|
||||||
DestroyChildren();
|
DestroyChildren();
|
||||||
|
|
||||||
if (m_widgetStyle) gtk_style_unref( m_widgetStyle );
|
if (m_widgetStyle) gtk_style_unref( m_widgetStyle );
|
||||||
|
|
||||||
if (m_scrollGC) gdk_gc_unref( m_scrollGC );
|
if (m_scrollGC) gdk_gc_unref( m_scrollGC );
|
||||||
|
|
||||||
if (m_wxwindow) gtk_widget_destroy( m_wxwindow );
|
if (m_wxwindow) gtk_widget_destroy( m_wxwindow );
|
||||||
|
|
||||||
if (m_widget) gtk_widget_destroy( m_widget );
|
if (m_widget) gtk_widget_destroy( m_widget );
|
||||||
|
|
||||||
wxDELETE(m_cursor);
|
if (m_cursor) delete m_cursor;
|
||||||
|
|
||||||
DeleteRelatedConstraints();
|
DeleteRelatedConstraints();
|
||||||
if (m_constraints)
|
if (m_constraints)
|
||||||
{
|
{
|
||||||
// This removes any dangling pointers to this window
|
// This removes any dangling pointers to this window
|
||||||
// in other windows' constraintsInvolvedIn lists.
|
// in other windows' constraintsInvolvedIn lists.
|
||||||
UnsetConstraints(m_constraints);
|
UnsetConstraints(m_constraints);
|
||||||
delete m_constraints;
|
delete m_constraints;
|
||||||
m_constraints = (wxLayoutConstraints *) NULL;
|
m_constraints = (wxLayoutConstraints *) NULL;
|
||||||
}
|
}
|
||||||
if (m_windowSizer)
|
if (m_windowSizer)
|
||||||
{
|
{
|
||||||
delete m_windowSizer;
|
delete m_windowSizer;
|
||||||
m_windowSizer = (wxSizer *) NULL;
|
m_windowSizer = (wxSizer *) NULL;
|
||||||
}
|
}
|
||||||
// If this is a child of a sizer, remove self from parent
|
// If this is a child of a sizer, remove self from parent
|
||||||
if (m_sizerParent) m_sizerParent->RemoveChild((wxWindow *)this);
|
if (m_sizerParent) m_sizerParent->RemoveChild((wxWindow *)this);
|
||||||
|
|
||||||
// Just in case the window has been Closed, but
|
// Just in case the window has been Closed, but
|
||||||
// we're then deleting immediately: don't leave
|
// we're then deleting immediately: don't leave
|
||||||
// dangling pointers.
|
// dangling pointers.
|
||||||
wxPendingDelete.DeleteObject(this);
|
wxPendingDelete.DeleteObject(this);
|
||||||
|
|
||||||
// Just in case we've loaded a top-level window via
|
// Just in case we've loaded a top-level window via
|
||||||
// wxWindow::LoadNativeDialog but we weren't a dialog
|
// wxWindow::LoadNativeDialog but we weren't a dialog
|
||||||
// class
|
// class
|
||||||
wxTopLevelWindows.DeleteObject(this);
|
wxTopLevelWindows.DeleteObject(this);
|
||||||
|
|
||||||
if (m_windowValidator) delete m_windowValidator;
|
if (m_windowValidator) delete m_windowValidator;
|
||||||
|
|
||||||
if (m_clientObject) delete m_clientObject;
|
if (m_clientObject) delete m_clientObject;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::PreCreation( wxWindow *parent, wxWindowID id,
|
void wxWindow::PreCreation( wxWindow *parent, wxWindowID id,
|
||||||
const wxPoint &pos, const wxSize &size,
|
const wxPoint &pos, const wxSize &size,
|
||||||
long style, const wxString &name )
|
long style, const wxString &name )
|
||||||
{
|
{
|
||||||
if (m_needParent && (parent == NULL))
|
if (m_needParent && (parent == NULL))
|
||||||
wxFatalError( "Need complete parent.", name );
|
wxFatalError( "Need complete parent.", name );
|
||||||
|
|
||||||
m_widget = (GtkWidget*) NULL;
|
m_widget = (GtkWidget*) NULL;
|
||||||
m_wxwindow = (GtkWidget*) NULL;
|
m_wxwindow = (GtkWidget*) NULL;
|
||||||
m_hasVMT = FALSE;
|
m_hasVMT = FALSE;
|
||||||
m_parent = parent;
|
m_parent = parent;
|
||||||
m_children.DeleteContents( FALSE );
|
m_children.DeleteContents( FALSE );
|
||||||
|
|
||||||
m_width = size.x;
|
m_width = size.x;
|
||||||
if (m_width == -1) m_width = 20;
|
if (m_width == -1) m_width = 20;
|
||||||
m_height = size.y;
|
m_height = size.y;
|
||||||
if (m_height == -1) m_height = 20;
|
if (m_height == -1) m_height = 20;
|
||||||
|
|
||||||
m_x = (int)pos.x;
|
m_x = (int)pos.x;
|
||||||
m_y = (int)pos.y;
|
m_y = (int)pos.y;
|
||||||
|
|
||||||
if (!m_needParent) // some reasonable defaults
|
if (!m_needParent) // some reasonable defaults
|
||||||
{
|
|
||||||
if (m_x == -1)
|
|
||||||
{
|
{
|
||||||
m_x = (gdk_screen_width () - m_width) / 2;
|
if (m_x == -1)
|
||||||
if (m_x < 10) m_x = 10;
|
{
|
||||||
|
m_x = (gdk_screen_width () - m_width) / 2;
|
||||||
|
if (m_x < 10) m_x = 10;
|
||||||
|
}
|
||||||
|
if (m_y == -1)
|
||||||
|
{
|
||||||
|
m_y = (gdk_screen_height () - m_height) / 2;
|
||||||
|
if (m_y < 10) m_y = 10;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (m_y == -1)
|
|
||||||
{
|
|
||||||
m_y = (gdk_screen_height () - m_height) / 2;
|
|
||||||
if (m_y < 10) m_y = 10;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
m_minWidth = -1;
|
m_minWidth = -1;
|
||||||
m_minHeight = -1;
|
m_minHeight = -1;
|
||||||
m_maxWidth = -1;
|
m_maxWidth = -1;
|
||||||
m_maxHeight = -1;
|
m_maxHeight = -1;
|
||||||
|
|
||||||
m_retCode = 0;
|
m_retCode = 0;
|
||||||
|
|
||||||
m_eventHandler = this;
|
m_eventHandler = this;
|
||||||
|
|
||||||
m_windowId = id;
|
m_windowId = id;
|
||||||
|
|
||||||
m_sizeSet = FALSE;
|
m_sizeSet = FALSE;
|
||||||
|
|
||||||
m_cursor = new wxCursor( wxCURSOR_ARROW );
|
m_cursor = new wxCursor( wxCURSOR_ARROW );
|
||||||
m_font = *wxSWISS_FONT;
|
m_font = *wxSWISS_FONT;
|
||||||
// m_backgroundColour = wxWHITE;
|
// m_backgroundColour = wxWHITE;
|
||||||
// m_foregroundColour = wxBLACK;
|
// m_foregroundColour = wxBLACK;
|
||||||
m_windowStyle = style;
|
m_windowStyle = style;
|
||||||
m_windowName = name;
|
m_windowName = name;
|
||||||
|
|
||||||
m_constraints = (wxLayoutConstraints *) NULL;
|
m_constraints = (wxLayoutConstraints *) NULL;
|
||||||
m_constraintsInvolvedIn = (wxList *) NULL;
|
m_constraintsInvolvedIn = (wxList *) NULL;
|
||||||
m_windowSizer = (wxSizer *) NULL;
|
m_windowSizer = (wxSizer *) NULL;
|
||||||
m_sizerParent = (wxWindow *) NULL;
|
m_sizerParent = (wxWindow *) NULL;
|
||||||
m_autoLayout = FALSE;
|
m_autoLayout = FALSE;
|
||||||
|
|
||||||
m_hasScrolling = FALSE;
|
m_hasScrolling = FALSE;
|
||||||
m_isScrolling = FALSE;
|
m_isScrolling = FALSE;
|
||||||
m_hAdjust = (GtkAdjustment *) NULL;
|
m_hAdjust = (GtkAdjustment *) NULL;
|
||||||
m_vAdjust = (GtkAdjustment *) NULL;
|
m_vAdjust = (GtkAdjustment *) NULL;
|
||||||
m_oldHorizontalPos = 0.0;
|
m_oldHorizontalPos = 0.0;
|
||||||
m_oldVerticalPos = 0.0;
|
m_oldVerticalPos = 0.0;
|
||||||
|
|
||||||
m_isShown = FALSE;
|
m_isShown = FALSE;
|
||||||
m_isEnabled = TRUE;
|
m_isEnabled = TRUE;
|
||||||
|
|
||||||
m_dropTarget = (wxDropTarget *) NULL;
|
m_dropTarget = (wxDropTarget *) NULL;
|
||||||
m_resizing = FALSE;
|
m_resizing = FALSE;
|
||||||
m_windowValidator = (wxValidator *) NULL;
|
m_windowValidator = (wxValidator *) NULL;
|
||||||
m_scrollGC = (GdkGC*) NULL;
|
m_scrollGC = (GdkGC*) NULL;
|
||||||
m_widgetStyle = (GtkStyle*) NULL;
|
m_widgetStyle = (GtkStyle*) NULL;
|
||||||
|
|
||||||
m_clientObject = (wxClientData*)NULL;
|
m_clientObject = (wxClientData*)NULL;
|
||||||
m_clientData = NULL;
|
m_clientData = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::PostCreation()
|
void wxWindow::PostCreation()
|
||||||
{
|
{
|
||||||
if (m_wxwindow)
|
if (m_wxwindow)
|
||||||
{
|
{
|
||||||
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "expose_event",
|
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "expose_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_expose_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_expose_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "draw",
|
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "draw",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_draw_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_draw_callback), (gpointer)this );
|
||||||
}
|
}
|
||||||
|
|
||||||
ConnectWidget( GetConnectWidget() );
|
ConnectWidget( GetConnectWidget() );
|
||||||
|
|
||||||
if (m_widget && m_parent) gtk_widget_realize( m_widget );
|
if (m_widget && m_parent) gtk_widget_realize( m_widget );
|
||||||
|
|
||||||
if (m_wxwindow) gtk_widget_realize( m_wxwindow );
|
if (m_wxwindow) gtk_widget_realize( m_wxwindow );
|
||||||
|
|
||||||
SetCursor( *wxSTANDARD_CURSOR );
|
SetCursor( *wxSTANDARD_CURSOR );
|
||||||
|
|
||||||
m_hasVMT = TRUE;
|
m_hasVMT = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::ConnectWidget( GtkWidget *widget )
|
void wxWindow::ConnectWidget( GtkWidget *widget )
|
||||||
{
|
{
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "key_press_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "key_press_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_key_press_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_key_press_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "button_press_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "button_press_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_button_press_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_button_press_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "button_release_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "button_release_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_button_release_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_button_release_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "motion_notify_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "motion_notify_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_motion_notify_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_motion_notify_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "focus_in_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "focus_in_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_focus_in_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_focus_in_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "focus_out_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "focus_out_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_focus_out_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_focus_out_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "enter_notify_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "enter_notify_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_enter_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_enter_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "leave_notify_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "leave_notify_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_leave_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_leave_callback), (gpointer)this );
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWindow::HasVMT()
|
bool wxWindow::HasVMT()
|
||||||
{
|
{
|
||||||
return m_hasVMT;
|
return m_hasVMT;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWindow::Close( bool force )
|
bool wxWindow::Close( bool force )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
||||||
|
|
||||||
wxCloseEvent event(wxEVT_CLOSE_WINDOW, m_windowId);
|
wxCloseEvent event(wxEVT_CLOSE_WINDOW, m_windowId);
|
||||||
event.SetEventObject(this);
|
event.SetEventObject(this);
|
||||||
event.SetForce(force);
|
event.SetForce(force);
|
||||||
|
|
||||||
return GetEventHandler()->ProcessEvent(event);
|
return GetEventHandler()->ProcessEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWindow::Destroy()
|
bool wxWindow::Destroy()
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
||||||
|
|
||||||
m_hasVMT = FALSE;
|
m_hasVMT = FALSE;
|
||||||
delete this;
|
delete this;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWindow::DestroyChildren()
|
bool wxWindow::DestroyChildren()
|
||||||
{
|
{
|
||||||
if (GetChildren())
|
if (GetChildren())
|
||||||
{
|
|
||||||
wxNode *node;
|
|
||||||
while ((node = GetChildren()->First()) != (wxNode *)NULL)
|
|
||||||
{
|
{
|
||||||
wxWindow *child;
|
wxNode *node;
|
||||||
if ((child = (wxWindow *)node->Data()) != (wxWindow *)NULL)
|
while ((node = GetChildren()->First()) != (wxNode *)NULL)
|
||||||
{
|
{
|
||||||
delete child;
|
wxWindow *child;
|
||||||
if (GetChildren()->Member(child)) delete node;
|
if ((child = (wxWindow *)node->Data()) != (wxWindow *)NULL)
|
||||||
}
|
{
|
||||||
|
delete child;
|
||||||
|
if (GetChildren()->Member(child)) delete node;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
return TRUE;
|
||||||
return TRUE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::PrepareDC( wxDC &WXUNUSED(dc) )
|
void wxWindow::PrepareDC( wxDC &WXUNUSED(dc) )
|
||||||
{
|
{
|
||||||
// are we to set fonts here ?
|
// are we to set fonts here ?
|
||||||
}
|
}
|
||||||
|
|
||||||
wxPoint wxWindow::GetClientAreaOrigin() const
|
wxPoint wxWindow::GetClientAreaOrigin() const
|
||||||
{
|
{
|
||||||
return wxPoint(0,0);
|
return wxPoint(0,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::AdjustForParentClientOrigin( int& x, int& y, int sizeFlags )
|
void wxWindow::AdjustForParentClientOrigin( int& x, int& y, int sizeFlags )
|
||||||
{
|
{
|
||||||
if (((sizeFlags & wxSIZE_NO_ADJUSTMENTS) == 0) && GetParent())
|
if (((sizeFlags & wxSIZE_NO_ADJUSTMENTS) == 0) && GetParent())
|
||||||
{
|
{
|
||||||
wxPoint pt(GetParent()->GetClientAreaOrigin());
|
wxPoint pt(GetParent()->GetClientAreaOrigin());
|
||||||
x += pt.x;
|
x += pt.x;
|
||||||
y += pt.y;
|
y += pt.y;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::SetSize( int x, int y, int width, int height, int sizeFlags )
|
void wxWindow::SetSize( int x, int y, int width, int height, int sizeFlags )
|
||||||
@ -1537,41 +1537,41 @@ void wxWindow::GetClientSize( int *width, int *height ) const
|
|||||||
|
|
||||||
void wxWindow::GetPosition( int *x, int *y ) const
|
void wxWindow::GetPosition( int *x, int *y ) const
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
||||||
|
|
||||||
if (x) (*x) = m_x;
|
if (x) (*x) = m_x;
|
||||||
if (y) (*y) = m_y;
|
if (y) (*y) = m_y;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::ClientToScreen( int *x, int *y )
|
void wxWindow::ClientToScreen( int *x, int *y )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
||||||
|
|
||||||
GdkWindow *source = (GdkWindow *) NULL;
|
GdkWindow *source = (GdkWindow *) NULL;
|
||||||
if (m_wxwindow)
|
if (m_wxwindow)
|
||||||
source = m_wxwindow->window;
|
source = m_wxwindow->window;
|
||||||
else
|
else
|
||||||
source = m_widget->window;
|
source = m_widget->window;
|
||||||
|
|
||||||
int org_x = 0;
|
int org_x = 0;
|
||||||
int org_y = 0;
|
int org_y = 0;
|
||||||
gdk_window_get_origin( source, &org_x, &org_y );
|
gdk_window_get_origin( source, &org_x, &org_y );
|
||||||
|
|
||||||
if (!m_wxwindow)
|
if (!m_wxwindow)
|
||||||
{
|
|
||||||
if (GTK_WIDGET_NO_WINDOW (m_widget))
|
|
||||||
{
|
{
|
||||||
org_x += m_widget->allocation.x;
|
if (GTK_WIDGET_NO_WINDOW (m_widget))
|
||||||
org_y += m_widget->allocation.y;
|
{
|
||||||
|
org_x += m_widget->allocation.x;
|
||||||
|
org_y += m_widget->allocation.y;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
wxPoint pt(GetClientAreaOrigin());
|
wxPoint pt(GetClientAreaOrigin());
|
||||||
org_x += pt.x;
|
org_x += pt.x;
|
||||||
org_y += pt.y;
|
org_y += pt.y;
|
||||||
|
|
||||||
if (x) *x += org_x;
|
if (x) *x += org_x;
|
||||||
if (y) *y += org_y;
|
if (y) *y += org_y;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::ScreenToClient( int *x, int *y )
|
void wxWindow::ScreenToClient( int *x, int *y )
|
||||||
|
@ -31,12 +31,60 @@ extern bool g_blockEventsOnDrag;
|
|||||||
|
|
||||||
static void gtk_bmpbutton_clicked_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
static void gtk_bmpbutton_clicked_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
{
|
{
|
||||||
if (!button->HasVMT()) return;
|
if (!button->HasVMT()) return;
|
||||||
if (g_blockEventsOnDrag) return;
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
wxCommandEvent event(wxEVT_COMMAND_BUTTON_CLICKED, button->GetId());
|
wxCommandEvent event(wxEVT_COMMAND_BUTTON_CLICKED, button->GetId());
|
||||||
event.SetEventObject(button);
|
event.SetEventObject(button);
|
||||||
button->GetEventHandler()->ProcessEvent(event);
|
button->GetEventHandler()->ProcessEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// "enter"
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void gtk_bmpbutton_enter_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
|
{
|
||||||
|
if (!button->HasVMT()) return;
|
||||||
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
|
button->HasFocus();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// "leave"
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void gtk_bmpbutton_leave_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
|
{
|
||||||
|
if (!button->HasVMT()) return;
|
||||||
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
|
button->NotFocus();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// "pressed"
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void gtk_bmpbutton_press_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
|
{
|
||||||
|
if (!button->HasVMT()) return;
|
||||||
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
|
button->StartSelect();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// "released"
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static void gtk_bmpbutton_release_callback( GtkWidget *WXUNUSED(widget), wxBitmapButton *button )
|
||||||
|
{
|
||||||
|
if (!button->HasVMT()) return;
|
||||||
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
|
button->EndSelect();
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -45,96 +93,198 @@ static void gtk_bmpbutton_clicked_callback( GtkWidget *WXUNUSED(widget), wxBitma
|
|||||||
|
|
||||||
IMPLEMENT_DYNAMIC_CLASS(wxBitmapButton,wxControl)
|
IMPLEMENT_DYNAMIC_CLASS(wxBitmapButton,wxControl)
|
||||||
|
|
||||||
wxBitmapButton::wxBitmapButton(void)
|
wxBitmapButton::wxBitmapButton()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxBitmapButton::Create( wxWindow *parent, wxWindowID id, const wxBitmap &bitmap,
|
bool wxBitmapButton::Create( wxWindow *parent, wxWindowID id, const wxBitmap &bitmap,
|
||||||
const wxPoint &pos, const wxSize &size,
|
const wxPoint &pos, const wxSize &size,
|
||||||
long style, const wxValidator& validator, const wxString &name )
|
long style, const wxValidator& validator, const wxString &name )
|
||||||
{
|
{
|
||||||
m_needParent = TRUE;
|
m_needParent = TRUE;
|
||||||
|
|
||||||
wxSize newSize = size;
|
wxSize newSize = size;
|
||||||
|
|
||||||
PreCreation( parent, id, pos, newSize, style, name );
|
PreCreation( parent, id, pos, newSize, style, name );
|
||||||
|
|
||||||
SetValidator( validator );
|
SetValidator( validator );
|
||||||
|
|
||||||
m_bitmap = bitmap;
|
m_bitmap = bitmap;
|
||||||
m_label = "";
|
m_disabled = bitmap;
|
||||||
|
m_focus = bitmap;
|
||||||
|
m_selected = bitmap;
|
||||||
|
|
||||||
m_widget = gtk_button_new();
|
m_label = "";
|
||||||
|
|
||||||
if (m_bitmap.Ok())
|
m_widget = gtk_button_new();
|
||||||
{
|
|
||||||
GdkBitmap *mask = (GdkBitmap *) NULL;
|
if (m_bitmap.Ok())
|
||||||
if (m_bitmap.GetMask()) mask = m_bitmap.GetMask()->GetBitmap();
|
{
|
||||||
GtkWidget *pixmap = gtk_pixmap_new( m_bitmap.GetPixmap(), mask );
|
GdkBitmap *mask = (GdkBitmap *) NULL;
|
||||||
|
if (m_bitmap.GetMask()) mask = m_bitmap.GetMask()->GetBitmap();
|
||||||
|
GtkWidget *pixmap = gtk_pixmap_new( m_bitmap.GetPixmap(), mask );
|
||||||
|
|
||||||
gtk_widget_show( pixmap );
|
gtk_widget_show( pixmap );
|
||||||
gtk_container_add( GTK_CONTAINER(m_widget), pixmap );
|
gtk_container_add( GTK_CONTAINER(m_widget), pixmap );
|
||||||
}
|
}
|
||||||
|
|
||||||
if (newSize.x == -1) newSize.x = m_bitmap.GetHeight()+10;
|
if (newSize.x == -1) newSize.x = m_bitmap.GetHeight()+10;
|
||||||
if (newSize.y == -1) newSize.y = m_bitmap.GetWidth()+10;
|
if (newSize.y == -1) newSize.y = m_bitmap.GetWidth()+10;
|
||||||
SetSize( newSize.x, newSize.y );
|
SetSize( newSize.x, newSize.y );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(m_widget), "clicked",
|
gtk_signal_connect( GTK_OBJECT(m_widget), "clicked",
|
||||||
GTK_SIGNAL_FUNC(gtk_bmpbutton_clicked_callback), (gpointer*)this );
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_clicked_callback), (gpointer*)this );
|
||||||
|
|
||||||
m_parent->AddChild( this );
|
gtk_signal_connect( GTK_OBJECT(m_widget), "enter",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_enter_callback), (gpointer*)this );
|
||||||
|
gtk_signal_connect( GTK_OBJECT(m_widget), "leave",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_leave_callback), (gpointer*)this );
|
||||||
|
gtk_signal_connect( GTK_OBJECT(m_widget), "pressed",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_press_callback), (gpointer*)this );
|
||||||
|
gtk_signal_connect( GTK_OBJECT(m_widget), "released",
|
||||||
|
GTK_SIGNAL_FUNC(gtk_bmpbutton_release_callback), (gpointer*)this );
|
||||||
|
|
||||||
|
m_parent->AddChild( this );
|
||||||
|
|
||||||
(m_parent->m_insertCallback)( m_parent, this );
|
(m_parent->m_insertCallback)( m_parent, this );
|
||||||
|
|
||||||
PostCreation();
|
PostCreation();
|
||||||
|
|
||||||
SetBackgroundColour( parent->GetBackgroundColour() );
|
SetBackgroundColour( parent->GetBackgroundColour() );
|
||||||
|
|
||||||
Show( TRUE );
|
Show( TRUE );
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxBitmapButton::SetDefault(void)
|
void wxBitmapButton::SetDefault()
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
GTK_WIDGET_SET_FLAGS( m_widget, GTK_CAN_DEFAULT );
|
GTK_WIDGET_SET_FLAGS( m_widget, GTK_CAN_DEFAULT );
|
||||||
gtk_widget_grab_default( m_widget );
|
gtk_widget_grab_default( m_widget );
|
||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxBitmapButton::SetLabel( const wxString &label )
|
void wxBitmapButton::SetLabel( const wxString &label )
|
||||||
{
|
{
|
||||||
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
wxControl::SetLabel( label );
|
wxControl::SetLabel( label );
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxBitmapButton::GetLabel(void) const
|
wxString wxBitmapButton::GetLabel() const
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( m_widget != NULL, "", "invalid button" );
|
wxCHECK_MSG( m_widget != NULL, "", "invalid button" );
|
||||||
|
|
||||||
return wxControl::GetLabel();
|
return wxControl::GetLabel();
|
||||||
}
|
|
||||||
|
|
||||||
void wxBitmapButton::SetBitmapLabel( const wxBitmap& bitmap )
|
|
||||||
{
|
|
||||||
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
|
||||||
|
|
||||||
m_bitmap = bitmap;
|
|
||||||
if (!m_bitmap.Ok()) return;
|
|
||||||
|
|
||||||
GtkButton *bin = GTK_BUTTON( m_widget );
|
|
||||||
GtkPixmap *g_pixmap = GTK_PIXMAP( bin->child );
|
|
||||||
|
|
||||||
GdkBitmap *mask = (GdkBitmap *) NULL;
|
|
||||||
if (m_bitmap.GetMask()) mask = m_bitmap.GetMask()->GetBitmap();
|
|
||||||
|
|
||||||
gtk_pixmap_set( g_pixmap, m_bitmap.GetPixmap(), mask );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxBitmapButton::ApplyWidgetStyle()
|
void wxBitmapButton::ApplyWidgetStyle()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmap()
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
wxBitmap the_one;
|
||||||
|
|
||||||
|
if ( ! m_isEnabled )
|
||||||
|
the_one = m_disabled;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( m_isSelected )
|
||||||
|
{
|
||||||
|
the_one = m_selected;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( m_hasFocus )
|
||||||
|
the_one = m_focus;
|
||||||
|
else
|
||||||
|
the_one = m_bitmap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! the_one.Ok() ) the_one = m_bitmap;
|
||||||
|
if ( ! the_one.Ok() ) return;
|
||||||
|
|
||||||
|
GtkButton *bin = GTK_BUTTON( m_widget );
|
||||||
|
GtkPixmap *g_pixmap = GTK_PIXMAP( bin->child );
|
||||||
|
|
||||||
|
GdkBitmap *mask = (GdkBitmap *) NULL;
|
||||||
|
if (the_one.GetMask()) mask = the_one.GetMask()->GetBitmap();
|
||||||
|
|
||||||
|
gtk_pixmap_set( g_pixmap, the_one.GetPixmap(), mask );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmapDisabled( const wxBitmap& bitmap )
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
if ( ! m_disabled.Ok() ) return;
|
||||||
|
m_disabled = bitmap;
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmapFocus( const wxBitmap& bitmap )
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
if ( ! m_focus.Ok() ) return;
|
||||||
|
m_focus = bitmap;
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmapLabel( const wxBitmap& bitmap )
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
if (!m_bitmap.Ok()) return;
|
||||||
|
m_bitmap = bitmap;
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::SetBitmapSelected( const wxBitmap& bitmap )
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_widget != NULL, "invalid button" );
|
||||||
|
|
||||||
|
if ( ! m_selected.Ok() ) return;
|
||||||
|
m_selected = bitmap;
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::Enable( const bool enable )
|
||||||
|
{
|
||||||
|
wxWindow::Enable(enable);
|
||||||
|
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::HasFocus()
|
||||||
|
{
|
||||||
|
m_hasFocus = TRUE;
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::NotFocus()
|
||||||
|
{
|
||||||
|
m_hasFocus = FALSE;
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::StartSelect()
|
||||||
|
{
|
||||||
|
m_isSelected = TRUE;
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxBitmapButton::EndSelect()
|
||||||
|
{
|
||||||
|
m_isSelected = FALSE;
|
||||||
|
SetBitmap();
|
||||||
|
}
|
||||||
|
@ -51,7 +51,7 @@ END_EVENT_TABLE()
|
|||||||
|
|
||||||
IMPLEMENT_DYNAMIC_CLASS(wxDialog,wxPanel)
|
IMPLEMENT_DYNAMIC_CLASS(wxDialog,wxPanel)
|
||||||
|
|
||||||
wxDialog::wxDialog(void)
|
wxDialog::wxDialog()
|
||||||
{
|
{
|
||||||
m_title = "";
|
m_title = "";
|
||||||
m_modalShowing = FALSE;
|
m_modalShowing = FALSE;
|
||||||
@ -106,20 +106,20 @@ bool wxDialog::Create( wxWindow *parent,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxDialog::~wxDialog(void)
|
wxDialog::~wxDialog()
|
||||||
{
|
{
|
||||||
wxTopLevelWindows.DeleteObject( this );
|
wxTopLevelWindows.DeleteObject( this );
|
||||||
if (wxTopLevelWindows.Number() == 0) wxTheApp->ExitMainLoop();
|
if (wxTopLevelWindows.Number() == 0) wxTheApp->ExitMainLoop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialog::SetTitle(const wxString& title )
|
void wxDialog::SetTitle( const wxString& title )
|
||||||
{
|
{
|
||||||
m_title = title;
|
m_title = title;
|
||||||
if (m_title.IsNull()) m_title = "";
|
if (m_title.IsNull()) m_title = "";
|
||||||
gtk_window_set_title( GTK_WINDOW(m_widget), m_title );
|
gtk_window_set_title( GTK_WINDOW(m_widget), m_title );
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxDialog::GetTitle(void) const
|
wxString wxDialog::GetTitle() const
|
||||||
{
|
{
|
||||||
return (wxString&)m_title;
|
return (wxString&)m_title;
|
||||||
}
|
}
|
||||||
@ -163,7 +163,7 @@ void wxDialog::OnPaint( wxPaintEvent& WXUNUSED(event) )
|
|||||||
// yes
|
// yes
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxDialog::OnClose(void)
|
bool wxDialog::OnClose()
|
||||||
{
|
{
|
||||||
static wxList closing;
|
static wxList closing;
|
||||||
|
|
||||||
@ -179,14 +179,14 @@ bool wxDialog::OnClose(void)
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxDialog::Destroy(void)
|
bool wxDialog::Destroy()
|
||||||
{
|
{
|
||||||
if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
|
if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialog::OnCloseWindow(wxCloseEvent& event)
|
void wxDialog::OnCloseWindow( wxCloseEvent& event )
|
||||||
{
|
{
|
||||||
if (GetEventHandler()->OnClose() || event.GetForce())
|
if (GetEventHandler()->OnClose() || event.GetForce())
|
||||||
{
|
{
|
||||||
@ -259,11 +259,17 @@ void wxDialog::SetSize( int x, int y, int width, int height, int sizeFlags )
|
|||||||
m_resizing = FALSE;
|
m_resizing = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxDialog::SetSize( int width, int height )
|
||||||
|
{
|
||||||
|
SetSize( -1, -1, width, height, wxSIZE_USE_EXISTING );
|
||||||
|
}
|
||||||
|
|
||||||
void wxDialog::Centre( int direction )
|
void wxDialog::Centre( int direction )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
||||||
|
|
||||||
int x,y;
|
int x = 0;
|
||||||
|
int y = 0;
|
||||||
|
|
||||||
if (direction & wxHORIZONTAL == wxHORIZONTAL) x = (gdk_screen_width () - m_width) / 2;
|
if (direction & wxHORIZONTAL == wxHORIZONTAL) x = (gdk_screen_width () - m_width) / 2;
|
||||||
if (direction & wxVERTICAL == wxVERTICAL) y = (gdk_screen_height () - m_height) / 2;
|
if (direction & wxVERTICAL == wxVERTICAL) y = (gdk_screen_height () - m_height) / 2;
|
||||||
@ -285,7 +291,7 @@ bool wxDialog::Show( bool show )
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxDialog::IsModal(void) const
|
bool wxDialog::IsModal() const
|
||||||
{
|
{
|
||||||
return m_modalShowing;
|
return m_modalShowing;
|
||||||
}
|
}
|
||||||
@ -301,7 +307,7 @@ void wxDialog::SetModal( bool WXUNUSED(flag) )
|
|||||||
wxFAIL_MSG( "wxDialog:SetModal obsolete now" );
|
wxFAIL_MSG( "wxDialog:SetModal obsolete now" );
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxDialog::ShowModal(void)
|
int wxDialog::ShowModal()
|
||||||
{
|
{
|
||||||
if (IsModal())
|
if (IsModal())
|
||||||
{
|
{
|
||||||
@ -337,7 +343,7 @@ void wxDialog::EndModal( int retCode )
|
|||||||
Show( FALSE );
|
Show( FALSE );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxDialog::InitDialog(void)
|
void wxDialog::InitDialog()
|
||||||
{
|
{
|
||||||
wxWindow::InitDialog();
|
wxWindow::InitDialog();
|
||||||
}
|
}
|
||||||
|
@ -284,11 +284,17 @@ void wxFrame::SetSize( int x, int y, int width, int height, int sizeFlags )
|
|||||||
m_resizing = FALSE;
|
m_resizing = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxFrame::SetSize( int width, int height )
|
||||||
|
{
|
||||||
|
SetSize( -1, -1, width, height, wxSIZE_USE_EXISTING );
|
||||||
|
}
|
||||||
|
|
||||||
void wxFrame::Centre( int direction )
|
void wxFrame::Centre( int direction )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
||||||
|
|
||||||
int x,y;
|
int x = 0;
|
||||||
|
int y = 0;
|
||||||
|
|
||||||
if (direction & wxHORIZONTAL == wxHORIZONTAL) x = (gdk_screen_width () - m_width) / 2;
|
if (direction & wxHORIZONTAL == wxHORIZONTAL) x = (gdk_screen_width () - m_width) / 2;
|
||||||
if (direction & wxVERTICAL == wxVERTICAL) y = (gdk_screen_height () - m_height) / 2;
|
if (direction & wxVERTICAL == wxVERTICAL) y = (gdk_screen_height () - m_height) / 2;
|
||||||
@ -348,10 +354,6 @@ void wxFrame::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int height
|
|||||||
if ((m_maxWidth != -1) && (m_width > m_maxWidth)) m_width = m_minWidth;
|
if ((m_maxWidth != -1) && (m_width > m_maxWidth)) m_width = m_minWidth;
|
||||||
if ((m_maxHeight != -1) && (m_height > m_maxHeight)) m_height = m_minHeight;
|
if ((m_maxHeight != -1) && (m_height > m_maxHeight)) m_height = m_minHeight;
|
||||||
|
|
||||||
wxSizeEvent event( wxSize(m_width,m_height), GetId() );
|
|
||||||
event.SetEventObject( this );
|
|
||||||
ProcessEvent( event );
|
|
||||||
|
|
||||||
gtk_widget_set_usize( m_widget, m_width, m_height );
|
gtk_widget_set_usize( m_widget, m_width, m_height );
|
||||||
|
|
||||||
// This emulates the new wxMSW behaviour
|
// This emulates the new wxMSW behaviour
|
||||||
@ -390,6 +392,10 @@ void wxFrame::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int height
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_sizeSet = TRUE;
|
m_sizeSet = TRUE;
|
||||||
|
|
||||||
|
wxSizeEvent event( wxSize(m_width,m_height), GetId() );
|
||||||
|
event.SetEventObject( this );
|
||||||
|
ProcessEvent( event );
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
||||||
|
@ -1092,248 +1092,248 @@ bool wxWindow::Create( wxWindow *parent, wxWindowID id,
|
|||||||
|
|
||||||
wxWindow::~wxWindow()
|
wxWindow::~wxWindow()
|
||||||
{
|
{
|
||||||
m_hasVMT = FALSE;
|
m_hasVMT = FALSE;
|
||||||
|
|
||||||
if (m_dropTarget) delete m_dropTarget;
|
if (m_dropTarget) delete m_dropTarget;
|
||||||
|
|
||||||
if (m_parent) m_parent->RemoveChild( this );
|
if (m_parent) m_parent->RemoveChild( this );
|
||||||
if (m_widget) Show( FALSE );
|
if (m_widget) Show( FALSE );
|
||||||
|
|
||||||
DestroyChildren();
|
DestroyChildren();
|
||||||
|
|
||||||
if (m_widgetStyle) gtk_style_unref( m_widgetStyle );
|
if (m_widgetStyle) gtk_style_unref( m_widgetStyle );
|
||||||
|
|
||||||
if (m_scrollGC) gdk_gc_unref( m_scrollGC );
|
if (m_scrollGC) gdk_gc_unref( m_scrollGC );
|
||||||
|
|
||||||
if (m_wxwindow) gtk_widget_destroy( m_wxwindow );
|
if (m_wxwindow) gtk_widget_destroy( m_wxwindow );
|
||||||
|
|
||||||
if (m_widget) gtk_widget_destroy( m_widget );
|
if (m_widget) gtk_widget_destroy( m_widget );
|
||||||
|
|
||||||
wxDELETE(m_cursor);
|
if (m_cursor) delete m_cursor;
|
||||||
|
|
||||||
DeleteRelatedConstraints();
|
DeleteRelatedConstraints();
|
||||||
if (m_constraints)
|
if (m_constraints)
|
||||||
{
|
{
|
||||||
// This removes any dangling pointers to this window
|
// This removes any dangling pointers to this window
|
||||||
// in other windows' constraintsInvolvedIn lists.
|
// in other windows' constraintsInvolvedIn lists.
|
||||||
UnsetConstraints(m_constraints);
|
UnsetConstraints(m_constraints);
|
||||||
delete m_constraints;
|
delete m_constraints;
|
||||||
m_constraints = (wxLayoutConstraints *) NULL;
|
m_constraints = (wxLayoutConstraints *) NULL;
|
||||||
}
|
}
|
||||||
if (m_windowSizer)
|
if (m_windowSizer)
|
||||||
{
|
{
|
||||||
delete m_windowSizer;
|
delete m_windowSizer;
|
||||||
m_windowSizer = (wxSizer *) NULL;
|
m_windowSizer = (wxSizer *) NULL;
|
||||||
}
|
}
|
||||||
// If this is a child of a sizer, remove self from parent
|
// If this is a child of a sizer, remove self from parent
|
||||||
if (m_sizerParent) m_sizerParent->RemoveChild((wxWindow *)this);
|
if (m_sizerParent) m_sizerParent->RemoveChild((wxWindow *)this);
|
||||||
|
|
||||||
// Just in case the window has been Closed, but
|
// Just in case the window has been Closed, but
|
||||||
// we're then deleting immediately: don't leave
|
// we're then deleting immediately: don't leave
|
||||||
// dangling pointers.
|
// dangling pointers.
|
||||||
wxPendingDelete.DeleteObject(this);
|
wxPendingDelete.DeleteObject(this);
|
||||||
|
|
||||||
// Just in case we've loaded a top-level window via
|
// Just in case we've loaded a top-level window via
|
||||||
// wxWindow::LoadNativeDialog but we weren't a dialog
|
// wxWindow::LoadNativeDialog but we weren't a dialog
|
||||||
// class
|
// class
|
||||||
wxTopLevelWindows.DeleteObject(this);
|
wxTopLevelWindows.DeleteObject(this);
|
||||||
|
|
||||||
if (m_windowValidator) delete m_windowValidator;
|
if (m_windowValidator) delete m_windowValidator;
|
||||||
|
|
||||||
if (m_clientObject) delete m_clientObject;
|
if (m_clientObject) delete m_clientObject;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::PreCreation( wxWindow *parent, wxWindowID id,
|
void wxWindow::PreCreation( wxWindow *parent, wxWindowID id,
|
||||||
const wxPoint &pos, const wxSize &size,
|
const wxPoint &pos, const wxSize &size,
|
||||||
long style, const wxString &name )
|
long style, const wxString &name )
|
||||||
{
|
{
|
||||||
if (m_needParent && (parent == NULL))
|
if (m_needParent && (parent == NULL))
|
||||||
wxFatalError( "Need complete parent.", name );
|
wxFatalError( "Need complete parent.", name );
|
||||||
|
|
||||||
m_widget = (GtkWidget*) NULL;
|
m_widget = (GtkWidget*) NULL;
|
||||||
m_wxwindow = (GtkWidget*) NULL;
|
m_wxwindow = (GtkWidget*) NULL;
|
||||||
m_hasVMT = FALSE;
|
m_hasVMT = FALSE;
|
||||||
m_parent = parent;
|
m_parent = parent;
|
||||||
m_children.DeleteContents( FALSE );
|
m_children.DeleteContents( FALSE );
|
||||||
|
|
||||||
m_width = size.x;
|
m_width = size.x;
|
||||||
if (m_width == -1) m_width = 20;
|
if (m_width == -1) m_width = 20;
|
||||||
m_height = size.y;
|
m_height = size.y;
|
||||||
if (m_height == -1) m_height = 20;
|
if (m_height == -1) m_height = 20;
|
||||||
|
|
||||||
m_x = (int)pos.x;
|
m_x = (int)pos.x;
|
||||||
m_y = (int)pos.y;
|
m_y = (int)pos.y;
|
||||||
|
|
||||||
if (!m_needParent) // some reasonable defaults
|
if (!m_needParent) // some reasonable defaults
|
||||||
{
|
|
||||||
if (m_x == -1)
|
|
||||||
{
|
{
|
||||||
m_x = (gdk_screen_width () - m_width) / 2;
|
if (m_x == -1)
|
||||||
if (m_x < 10) m_x = 10;
|
{
|
||||||
|
m_x = (gdk_screen_width () - m_width) / 2;
|
||||||
|
if (m_x < 10) m_x = 10;
|
||||||
|
}
|
||||||
|
if (m_y == -1)
|
||||||
|
{
|
||||||
|
m_y = (gdk_screen_height () - m_height) / 2;
|
||||||
|
if (m_y < 10) m_y = 10;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (m_y == -1)
|
|
||||||
{
|
|
||||||
m_y = (gdk_screen_height () - m_height) / 2;
|
|
||||||
if (m_y < 10) m_y = 10;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
m_minWidth = -1;
|
m_minWidth = -1;
|
||||||
m_minHeight = -1;
|
m_minHeight = -1;
|
||||||
m_maxWidth = -1;
|
m_maxWidth = -1;
|
||||||
m_maxHeight = -1;
|
m_maxHeight = -1;
|
||||||
|
|
||||||
m_retCode = 0;
|
m_retCode = 0;
|
||||||
|
|
||||||
m_eventHandler = this;
|
m_eventHandler = this;
|
||||||
|
|
||||||
m_windowId = id;
|
m_windowId = id;
|
||||||
|
|
||||||
m_sizeSet = FALSE;
|
m_sizeSet = FALSE;
|
||||||
|
|
||||||
m_cursor = new wxCursor( wxCURSOR_ARROW );
|
m_cursor = new wxCursor( wxCURSOR_ARROW );
|
||||||
m_font = *wxSWISS_FONT;
|
m_font = *wxSWISS_FONT;
|
||||||
// m_backgroundColour = wxWHITE;
|
// m_backgroundColour = wxWHITE;
|
||||||
// m_foregroundColour = wxBLACK;
|
// m_foregroundColour = wxBLACK;
|
||||||
m_windowStyle = style;
|
m_windowStyle = style;
|
||||||
m_windowName = name;
|
m_windowName = name;
|
||||||
|
|
||||||
m_constraints = (wxLayoutConstraints *) NULL;
|
m_constraints = (wxLayoutConstraints *) NULL;
|
||||||
m_constraintsInvolvedIn = (wxList *) NULL;
|
m_constraintsInvolvedIn = (wxList *) NULL;
|
||||||
m_windowSizer = (wxSizer *) NULL;
|
m_windowSizer = (wxSizer *) NULL;
|
||||||
m_sizerParent = (wxWindow *) NULL;
|
m_sizerParent = (wxWindow *) NULL;
|
||||||
m_autoLayout = FALSE;
|
m_autoLayout = FALSE;
|
||||||
|
|
||||||
m_hasScrolling = FALSE;
|
m_hasScrolling = FALSE;
|
||||||
m_isScrolling = FALSE;
|
m_isScrolling = FALSE;
|
||||||
m_hAdjust = (GtkAdjustment *) NULL;
|
m_hAdjust = (GtkAdjustment *) NULL;
|
||||||
m_vAdjust = (GtkAdjustment *) NULL;
|
m_vAdjust = (GtkAdjustment *) NULL;
|
||||||
m_oldHorizontalPos = 0.0;
|
m_oldHorizontalPos = 0.0;
|
||||||
m_oldVerticalPos = 0.0;
|
m_oldVerticalPos = 0.0;
|
||||||
|
|
||||||
m_isShown = FALSE;
|
m_isShown = FALSE;
|
||||||
m_isEnabled = TRUE;
|
m_isEnabled = TRUE;
|
||||||
|
|
||||||
m_dropTarget = (wxDropTarget *) NULL;
|
m_dropTarget = (wxDropTarget *) NULL;
|
||||||
m_resizing = FALSE;
|
m_resizing = FALSE;
|
||||||
m_windowValidator = (wxValidator *) NULL;
|
m_windowValidator = (wxValidator *) NULL;
|
||||||
m_scrollGC = (GdkGC*) NULL;
|
m_scrollGC = (GdkGC*) NULL;
|
||||||
m_widgetStyle = (GtkStyle*) NULL;
|
m_widgetStyle = (GtkStyle*) NULL;
|
||||||
|
|
||||||
m_clientObject = (wxClientData*)NULL;
|
m_clientObject = (wxClientData*)NULL;
|
||||||
m_clientData = NULL;
|
m_clientData = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::PostCreation()
|
void wxWindow::PostCreation()
|
||||||
{
|
{
|
||||||
if (m_wxwindow)
|
if (m_wxwindow)
|
||||||
{
|
{
|
||||||
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "expose_event",
|
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "expose_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_expose_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_expose_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "draw",
|
gtk_signal_connect( GTK_OBJECT(m_wxwindow), "draw",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_draw_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_draw_callback), (gpointer)this );
|
||||||
}
|
}
|
||||||
|
|
||||||
ConnectWidget( GetConnectWidget() );
|
ConnectWidget( GetConnectWidget() );
|
||||||
|
|
||||||
if (m_widget && m_parent) gtk_widget_realize( m_widget );
|
if (m_widget && m_parent) gtk_widget_realize( m_widget );
|
||||||
|
|
||||||
if (m_wxwindow) gtk_widget_realize( m_wxwindow );
|
if (m_wxwindow) gtk_widget_realize( m_wxwindow );
|
||||||
|
|
||||||
SetCursor( *wxSTANDARD_CURSOR );
|
SetCursor( *wxSTANDARD_CURSOR );
|
||||||
|
|
||||||
m_hasVMT = TRUE;
|
m_hasVMT = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::ConnectWidget( GtkWidget *widget )
|
void wxWindow::ConnectWidget( GtkWidget *widget )
|
||||||
{
|
{
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "key_press_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "key_press_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_key_press_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_key_press_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "button_press_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "button_press_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_button_press_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_button_press_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "button_release_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "button_release_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_button_release_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_button_release_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "motion_notify_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "motion_notify_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_motion_notify_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_motion_notify_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "focus_in_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "focus_in_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_focus_in_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_focus_in_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "focus_out_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "focus_out_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_focus_out_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_focus_out_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "enter_notify_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "enter_notify_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_enter_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_enter_callback), (gpointer)this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "leave_notify_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "leave_notify_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_leave_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_leave_callback), (gpointer)this );
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWindow::HasVMT()
|
bool wxWindow::HasVMT()
|
||||||
{
|
{
|
||||||
return m_hasVMT;
|
return m_hasVMT;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWindow::Close( bool force )
|
bool wxWindow::Close( bool force )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
||||||
|
|
||||||
wxCloseEvent event(wxEVT_CLOSE_WINDOW, m_windowId);
|
wxCloseEvent event(wxEVT_CLOSE_WINDOW, m_windowId);
|
||||||
event.SetEventObject(this);
|
event.SetEventObject(this);
|
||||||
event.SetForce(force);
|
event.SetForce(force);
|
||||||
|
|
||||||
return GetEventHandler()->ProcessEvent(event);
|
return GetEventHandler()->ProcessEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWindow::Destroy()
|
bool wxWindow::Destroy()
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
||||||
|
|
||||||
m_hasVMT = FALSE;
|
m_hasVMT = FALSE;
|
||||||
delete this;
|
delete this;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxWindow::DestroyChildren()
|
bool wxWindow::DestroyChildren()
|
||||||
{
|
{
|
||||||
if (GetChildren())
|
if (GetChildren())
|
||||||
{
|
|
||||||
wxNode *node;
|
|
||||||
while ((node = GetChildren()->First()) != (wxNode *)NULL)
|
|
||||||
{
|
{
|
||||||
wxWindow *child;
|
wxNode *node;
|
||||||
if ((child = (wxWindow *)node->Data()) != (wxWindow *)NULL)
|
while ((node = GetChildren()->First()) != (wxNode *)NULL)
|
||||||
{
|
{
|
||||||
delete child;
|
wxWindow *child;
|
||||||
if (GetChildren()->Member(child)) delete node;
|
if ((child = (wxWindow *)node->Data()) != (wxWindow *)NULL)
|
||||||
}
|
{
|
||||||
|
delete child;
|
||||||
|
if (GetChildren()->Member(child)) delete node;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
return TRUE;
|
||||||
return TRUE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::PrepareDC( wxDC &WXUNUSED(dc) )
|
void wxWindow::PrepareDC( wxDC &WXUNUSED(dc) )
|
||||||
{
|
{
|
||||||
// are we to set fonts here ?
|
// are we to set fonts here ?
|
||||||
}
|
}
|
||||||
|
|
||||||
wxPoint wxWindow::GetClientAreaOrigin() const
|
wxPoint wxWindow::GetClientAreaOrigin() const
|
||||||
{
|
{
|
||||||
return wxPoint(0,0);
|
return wxPoint(0,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::AdjustForParentClientOrigin( int& x, int& y, int sizeFlags )
|
void wxWindow::AdjustForParentClientOrigin( int& x, int& y, int sizeFlags )
|
||||||
{
|
{
|
||||||
if (((sizeFlags & wxSIZE_NO_ADJUSTMENTS) == 0) && GetParent())
|
if (((sizeFlags & wxSIZE_NO_ADJUSTMENTS) == 0) && GetParent())
|
||||||
{
|
{
|
||||||
wxPoint pt(GetParent()->GetClientAreaOrigin());
|
wxPoint pt(GetParent()->GetClientAreaOrigin());
|
||||||
x += pt.x;
|
x += pt.x;
|
||||||
y += pt.y;
|
y += pt.y;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::SetSize( int x, int y, int width, int height, int sizeFlags )
|
void wxWindow::SetSize( int x, int y, int width, int height, int sizeFlags )
|
||||||
@ -1537,41 +1537,41 @@ void wxWindow::GetClientSize( int *width, int *height ) const
|
|||||||
|
|
||||||
void wxWindow::GetPosition( int *x, int *y ) const
|
void wxWindow::GetPosition( int *x, int *y ) const
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
||||||
|
|
||||||
if (x) (*x) = m_x;
|
if (x) (*x) = m_x;
|
||||||
if (y) (*y) = m_y;
|
if (y) (*y) = m_y;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::ClientToScreen( int *x, int *y )
|
void wxWindow::ClientToScreen( int *x, int *y )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid window" );
|
||||||
|
|
||||||
GdkWindow *source = (GdkWindow *) NULL;
|
GdkWindow *source = (GdkWindow *) NULL;
|
||||||
if (m_wxwindow)
|
if (m_wxwindow)
|
||||||
source = m_wxwindow->window;
|
source = m_wxwindow->window;
|
||||||
else
|
else
|
||||||
source = m_widget->window;
|
source = m_widget->window;
|
||||||
|
|
||||||
int org_x = 0;
|
int org_x = 0;
|
||||||
int org_y = 0;
|
int org_y = 0;
|
||||||
gdk_window_get_origin( source, &org_x, &org_y );
|
gdk_window_get_origin( source, &org_x, &org_y );
|
||||||
|
|
||||||
if (!m_wxwindow)
|
if (!m_wxwindow)
|
||||||
{
|
|
||||||
if (GTK_WIDGET_NO_WINDOW (m_widget))
|
|
||||||
{
|
{
|
||||||
org_x += m_widget->allocation.x;
|
if (GTK_WIDGET_NO_WINDOW (m_widget))
|
||||||
org_y += m_widget->allocation.y;
|
{
|
||||||
|
org_x += m_widget->allocation.x;
|
||||||
|
org_y += m_widget->allocation.y;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
wxPoint pt(GetClientAreaOrigin());
|
wxPoint pt(GetClientAreaOrigin());
|
||||||
org_x += pt.x;
|
org_x += pt.x;
|
||||||
org_y += pt.y;
|
org_y += pt.y;
|
||||||
|
|
||||||
if (x) *x += org_x;
|
if (x) *x += org_x;
|
||||||
if (y) *y += org_y;
|
if (y) *y += org_y;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::ScreenToClient( int *x, int *y )
|
void wxWindow::ScreenToClient( int *x, int *y )
|
||||||
|
Loading…
Reference in New Issue
Block a user