X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e2414cbe8c21931afbb590132232553514da824c..8b21b87fe330378e8bc448eee2494e3dd2c97a37:/src/gtk1/dialog.cpp diff --git a/src/gtk1/dialog.cpp b/src/gtk1/dialog.cpp index f472f31e6c..6ce4890d79 100644 --- a/src/gtk1/dialog.cpp +++ b/src/gtk1/dialog.cpp @@ -36,14 +36,14 @@ bool gtk_dialog_delete_callback( GtkWidget *WXUNUSED(widget), GdkEvent *WXUNUSED win->Close(); return TRUE; -}; +} //----------------------------------------------------------------------------- // wxDialog //----------------------------------------------------------------------------- BEGIN_EVENT_TABLE(wxDialog,wxWindow) - EVT_BUTTON (wxID_OK, wxDialog::OnOk) + EVT_BUTTON (wxID_OK, wxDialog::OnOK) EVT_BUTTON (wxID_CANCEL, wxDialog::OnCancel) EVT_BUTTON (wxID_APPLY, wxDialog::OnApply) EVT_CLOSE (wxDialog::OnCloseWindow) @@ -54,18 +54,19 @@ IMPLEMENT_DYNAMIC_CLASS(wxDialog,wxWindow) wxDialog::wxDialog(void) { m_title = ""; - m_modalShowing = TRUE; + m_modalShowing = FALSE; wxTopLevelWindows.Insert( this ); -}; +} wxDialog::wxDialog( wxWindow *parent, wxWindowID id, const wxString &title, const wxPoint &pos, const wxSize &size, long style, const wxString &name ) { + m_modalShowing = FALSE; wxTopLevelWindows.Insert( this ); Create( parent, id, title, pos, size, style, name ); -}; +} bool wxDialog::Create( wxWindow *parent, wxWindowID id, const wxString &title, @@ -76,8 +77,6 @@ bool wxDialog::Create( wxWindow *parent, PreCreation( parent, id, pos, size, style, name ); - m_modalShowing = ((m_windowStyle & wxDIALOG_MODAL) == wxDIALOG_MODAL); - m_widget = gtk_window_new( GTK_WINDOW_TOPLEVEL ); GTK_WIDGET_UNSET_FLAGS( m_widget, GTK_CAN_FOCUS ); @@ -94,32 +93,38 @@ bool wxDialog::Create( wxWindow *parent, SetTitle( title ); + if ((m_x != -1) || (m_y != -1)) + gtk_widget_set_uposition( m_widget, m_x, m_y ); + + gtk_widget_set_usize( m_widget, m_width, m_height ); + PostCreation(); return TRUE; -}; +} wxDialog::~wxDialog(void) { wxTopLevelWindows.DeleteObject( this ); if (wxTopLevelWindows.Number() == 0) wxTheApp->ExitMainLoop(); -}; +} void wxDialog::SetTitle(const wxString& title ) { m_title = title; + if (m_title.IsNull()) m_title = ""; gtk_window_set_title( GTK_WINDOW(m_widget), m_title ); -}; +} wxString wxDialog::GetTitle(void) const { return (wxString&)m_title; -}; +} void wxDialog::OnApply( wxCommandEvent &WXUNUSED(event) ) { if (Validate()) TransferDataFromWindow(); -}; +} void wxDialog::OnCancel( wxCommandEvent &WXUNUSED(event) ) { @@ -131,10 +136,10 @@ void wxDialog::OnCancel( wxCommandEvent &WXUNUSED(event) ) { SetReturnCode(wxID_CANCEL); this->Show(FALSE); - }; -}; + } +} -void wxDialog::OnOk( wxCommandEvent &WXUNUSED(event) ) +void wxDialog::OnOK( wxCommandEvent &WXUNUSED(event) ) { if ( Validate() && TransferDataFromWindow()) { @@ -146,14 +151,14 @@ void wxDialog::OnOk( wxCommandEvent &WXUNUSED(event) ) { SetReturnCode(wxID_OK); this->Show(FALSE); - }; - }; -}; + } + } +} void wxDialog::OnPaint( wxPaintEvent& WXUNUSED(event) ) { // yes -}; +} bool wxDialog::OnClose(void) { @@ -184,44 +189,95 @@ void wxDialog::OnCloseWindow(wxCloseEvent& event) if (GetEventHandler()->OnClose() || event.GetForce()) { this->Destroy(); - }; -}; + } +} + +void wxDialog::ImplementSetPosition(void) +{ + if ((m_x != -1) || (m_y != -1)) + gtk_widget_set_uposition( m_widget, m_x, m_y ); +} + +void wxDialog::Centre( int direction ) +{ + if (direction & wxHORIZONTAL == wxHORIZONTAL) m_x = (gdk_screen_width () - m_width) / 2; + if (direction & wxVERTICAL == wxVERTICAL) m_y = (gdk_screen_height () - m_height) / 2; + ImplementSetPosition(); +} bool wxDialog::Show( bool show ) { - if (!show && m_modalShowing) + if (!show && IsModal() && m_modalShowing) { EndModal( wxID_CANCEL ); - }; + } wxWindow::Show( show ); if (show) InitDialog(); - if (show && m_modalShowing) - { - gtk_grab_add( m_widget ); - gtk_main(); - gtk_grab_remove( m_widget ); - }; - return TRUE; -}; +} + +void wxDialog::SetModal(bool flag) +{ + if (flag) + m_windowStyle |= wxDIALOG_MODAL; + else + if (m_windowStyle & wxDIALOG_MODAL) m_windowStyle -= wxDIALOG_MODAL; +} int wxDialog::ShowModal(void) { + if (m_modalShowing) return GetReturnCode(); + Show( TRUE ); + + m_modalShowing = TRUE; + + gtk_grab_add( m_widget ); + gtk_main(); + gtk_grab_remove( m_widget ); + return GetReturnCode(); -}; +} void wxDialog::EndModal( int retCode ) { SetReturnCode( retCode ); + + if (!m_modalShowing) + { + wxFAIL_MSG( "wxDialog: called EndModal twice" ); + return; + } + + m_modalShowing = FALSE; + gtk_main_quit(); -}; +} void wxDialog::InitDialog(void) { wxWindow::InitDialog(); -}; +} + +void wxDialog::SetSizeHints(int minW, int minH, int maxW, int maxH, int WXUNUSED(incW) ) +{ + gdk_window_set_hints( m_widget->window, -1, -1, + minW, minH, maxW, maxH, GDK_HINT_MIN_SIZE | GDK_HINT_MIN_SIZE ); +} + +void wxDialog::SetIcon( const wxIcon &icon ) +{ + m_icon = icon; + if (!icon.Ok()) return; + + wxMask *mask = icon.GetMask(); + GdkBitmap *bm = NULL; + if (mask) bm = mask->GetBitmap(); + + gdk_window_set_icon( m_widget->window, NULL, icon.GetPixmap(), bm ); +} +