X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/da1bd25f2991b3075d311c29ee9d76a751a69346..16a6b53ddc74d62fd1b6b82651d0e3859580c48a:/include/wx/gtk/window.h diff --git a/include/wx/gtk/window.h b/include/wx/gtk/window.h index 5bcfb26b5c..2a623ee0c1 100644 --- a/include/wx/gtk/window.h +++ b/include/wx/gtk/window.h @@ -18,13 +18,6 @@ struct wxGtkIMData; WX_DEFINE_EXPORTED_ARRAY_PTR(GdkWindow *, wxArrayGdkWindows); -//----------------------------------------------------------------------------- -// callback definition for inserting a window (internal) -//----------------------------------------------------------------------------- - -class WXDLLIMPEXP_CORE wxWindowGTK; -typedef void (*wxInsertChildFunction)( wxWindowGTK*, wxWindowGTK* ); - //----------------------------------------------------------------------------- // wxWindowGTK //----------------------------------------------------------------------------- @@ -61,13 +54,13 @@ public: virtual void Lower(); virtual bool Show( bool show = true ); - virtual void DoEnable( bool enable ); virtual void SetWindowStyleFlag( long style ); virtual bool IsRetained() const; virtual void SetFocus(); + virtual void SetFocusIgnoringChildren(); virtual void SetCanFocus(bool canFocus); virtual bool Reparent( wxWindowBase *newParent ); @@ -186,6 +179,10 @@ public: // there is also the exception of wxMenuBar) virtual bool GTKNeedsParent() const { return !IsTopLevel(); } + // This is called when capture is taken from the window. It will + // fire off capture lost events. + void GTKReleaseMouseAndNotify(); + protected: // Override GTKWidgetNeedsMnemonic and return true if your // needs to set its mnemonic widget, such as for a @@ -217,15 +214,10 @@ public: PangoContext *GtkGetPangoDefaultContext(); #if wxUSE_TOOLTIPS - virtual void ApplyToolTip( GtkTooltips *tips, const wxChar *tip ); + // applies tooltip to the widget (tip must be UTF-8 encoded) + virtual void ApplyToolTip( GtkTooltips *tips, const gchar *tip ); #endif // wxUSE_TOOLTIPS - // Called from GTK signal handlers. it indicates that - // the layouting functions have to be called later on - // (i.e. in idle time, implemented in OnInternalIdle() ). - void GtkUpdateSize() { m_sizeSet = false; } - - // Called when a window should delay showing itself // until idle time. This partly mimmicks defered // sizing under MSW. @@ -248,9 +240,6 @@ public: // Common scroll event handling code for wxWindow and wxScrollBar wxEventType GetScrollEventType(GtkRange* range); - void BlockScrollEvent(); - void UnblockScrollEvent(); - // position and size of the window int m_x, m_y; int m_width, m_height; @@ -278,10 +267,6 @@ public: // horizontal/vertical scroll position double m_scrollPos[ScrollDir_Max]; - // if true, don't notify about adjustment change (without resetting the - // flag, so this has to be done manually) - bool m_blockValueChanged[ScrollDir_Max]; - // return the scroll direction index corresponding to the given orientation // (which is wxVERTICAL or wxHORIZONTAL) static ScrollDir ScrollDirFromOrient(int orient) @@ -304,7 +289,6 @@ public: bool m_nativeSizeEvent:1; // wxGLCanvas sends wxSizeEvent upon "alloc_size" bool m_hasScrolling:1; bool m_hasVMT:1; - bool m_sizeSet:1; bool m_resizing:1; bool m_hasFocus:1; // true if == FindFocus() bool m_isScrolling:1; // dragging scrollbar thumb? @@ -315,16 +299,16 @@ public: bool m_needsStyleChange:1; // May not be able to change // background style until OnIdle bool m_mouseButtonDown:1; - bool m_blockScrollEvent:1; bool m_showOnIdle:1; // postpone showing the window until idle +protected: // C++ has no virtual methods in the constrcutor of any class but we need // different methods of inserting a child window into a wxFrame, // wxMDIFrame, wxNotebook etc. this is the callback that will get used. - wxInsertChildFunction m_insertCallback; + typedef void (*InsertChildFunction)(wxWindowGTK*, wxWindowGTK*); + InsertChildFunction m_insertCallback; -protected: // implement the base class pure virtuals virtual void DoClientToScreen( int *x, int *y ) const; virtual void DoScreenToClient( int *x, int *y ) const; @@ -336,6 +320,7 @@ protected: int sizeFlags = wxSIZE_AUTO); virtual void DoSetClientSize(int width, int height); virtual void DoMoveWindow(int x, int y, int width, int height); + virtual void DoEnable(bool enable); #if wxUSE_MENUS_NATIVE virtual bool DoPopupMenu( wxMenu *menu, int x, int y );