Get/SetTitle only for wxTopLevelWindow (wxMotif part).

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@36079 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Włodzimierz Skiba
2005-11-03 20:58:02 +00:00
parent 7996ff8038
commit 34097680c0
4 changed files with 81 additions and 79 deletions

View File

@@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
// Name: window.h // Name: wx/motif/window.h
// Purpose: wxWindow class // Purpose: wxWindow class
// Author: Julian Smart // Author: Julian Smart
// Modified by: // Modified by:
@@ -22,53 +22,53 @@ class WXDLLIMPEXP_CORE wxWindow : public wxWindowBase
{ {
friend class WXDLLEXPORT wxDC; friend class WXDLLEXPORT wxDC;
friend class WXDLLEXPORT wxWindowDC; friend class WXDLLEXPORT wxWindowDC;
public: public:
wxWindow() { Init(); } wxWindow() { Init(); }
wxWindow(wxWindow *parent, wxWindow(wxWindow *parent,
wxWindowID id, wxWindowID id,
const wxPoint& pos = wxDefaultPosition, const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize, const wxSize& size = wxDefaultSize,
long style = 0, long style = 0,
const wxString& name = wxPanelNameStr) const wxString& name = wxPanelNameStr)
{ {
Init(); Init();
Create(parent, id, pos, size, style, name); Create(parent, id, pos, size, style, name);
} }
virtual ~wxWindow(); virtual ~wxWindow();
bool Create(wxWindow *parent, bool Create(wxWindow *parent,
wxWindowID id, wxWindowID id,
const wxPoint& pos = wxDefaultPosition, const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize, const wxSize& size = wxDefaultSize,
long style = 0, long style = 0,
const wxString& name = wxPanelNameStr); const wxString& name = wxPanelNameStr);
// implement base class pure virtuals // implement base class pure virtuals
virtual void SetTitle( const wxString& title); virtual void SetLabel(const wxString& label);
virtual wxString GetTitle() const; virtual wxString GetLabel() const;
virtual void Raise(); virtual void Raise();
virtual void Lower(); virtual void Lower();
virtual bool Show( bool show = true ); virtual bool Show( bool show = true );
virtual bool Enable( bool enable = true ); virtual bool Enable( bool enable = true );
virtual void SetFocus(); virtual void SetFocus();
virtual void WarpPointer(int x, int y); virtual void WarpPointer(int x, int y);
virtual void Refresh( bool eraseBackground = true, virtual void Refresh( bool eraseBackground = true,
const wxRect *rect = (const wxRect *) NULL ); const wxRect *rect = (const wxRect *) NULL );
virtual bool SetBackgroundColour( const wxColour &colour ); virtual bool SetBackgroundColour( const wxColour &colour );
virtual bool SetForegroundColour( const wxColour &colour ); virtual bool SetForegroundColour( const wxColour &colour );
virtual bool SetCursor( const wxCursor &cursor ); virtual bool SetCursor( const wxCursor &cursor );
virtual bool SetFont( const wxFont &font ); virtual bool SetFont( const wxFont &font );
virtual int GetCharHeight() const; virtual int GetCharHeight() const;
virtual int GetCharWidth() const; virtual int GetCharWidth() const;
virtual void GetTextExtent(const wxString& string, virtual void GetTextExtent(const wxString& string,
@@ -77,7 +77,7 @@ public:
int *externalLeading = (int *) NULL, int *externalLeading = (int *) NULL,
const wxFont *theFont = (const wxFont *) NULL) const wxFont *theFont = (const wxFont *) NULL)
const; const;
virtual void SetScrollbar( int orient, int pos, int thumbVisible, virtual void SetScrollbar( int orient, int pos, int thumbVisible,
int range, bool refresh = true ); int range, bool refresh = true );
virtual void SetScrollPos( int orient, int pos, bool refresh = true ); virtual void SetScrollPos( int orient, int pos, bool refresh = true );
@@ -86,23 +86,23 @@ public:
virtual int GetScrollRange( int orient ) const; virtual int GetScrollRange( int orient ) const;
virtual void ScrollWindow( int dx, int dy, virtual void ScrollWindow( int dx, int dy,
const wxRect* rect = (wxRect *) NULL ); const wxRect* rect = (wxRect *) NULL );
#if wxUSE_DRAG_AND_DROP #if wxUSE_DRAG_AND_DROP
virtual void SetDropTarget( wxDropTarget *dropTarget ); virtual void SetDropTarget( wxDropTarget *dropTarget );
#endif // wxUSE_DRAG_AND_DROP #endif // wxUSE_DRAG_AND_DROP
// Accept files for dragging // Accept files for dragging
virtual void DragAcceptFiles(bool accept); virtual void DragAcceptFiles(bool accept);
// Get the unique identifier of a window // Get the unique identifier of a window
virtual WXWidget GetHandle() const { return GetMainWidget(); } virtual WXWidget GetHandle() const { return GetMainWidget(); }
// implementation from now on // implementation from now on
// -------------------------- // --------------------------
// accessors // accessors
// --------- // ---------
// Get main widget for this window, e.g. a text widget // Get main widget for this window, e.g. a text widget
virtual WXWidget GetMainWidget() const; virtual WXWidget GetMainWidget() const;
// Get the widget that corresponds to the label (for font setting, // Get the widget that corresponds to the label (for font setting,
@@ -115,46 +115,46 @@ public:
// multi-line text widget. Top means, top in the window hierarchy that // multi-line text widget. Top means, top in the window hierarchy that
// implements this window. // implements this window.
virtual WXWidget GetTopWidget() const; virtual WXWidget GetTopWidget() const;
// Get the underlying X window and display // Get the underlying X window and display
WXWindow GetClientXWindow() const; WXWindow GetClientXWindow() const;
WXWindow GetXWindow() const; WXWindow GetXWindow() const;
WXDisplay *GetXDisplay() const; WXDisplay *GetXDisplay() const;
void SetLastClick(int button, long timestamp) void SetLastClick(int button, long timestamp)
{ m_lastButton = button; m_lastTS = timestamp; } { m_lastButton = button; m_lastTS = timestamp; }
int GetLastClickedButton() const { return m_lastButton; } int GetLastClickedButton() const { return m_lastButton; }
long GetLastClickTime() const { return m_lastTS; } long GetLastClickTime() const { return m_lastTS; }
// Gives window a chance to do something in response to a size message, // Gives window a chance to do something in response to a size message,
// e.g. arrange status bar, toolbar etc. // e.g. arrange status bar, toolbar etc.
virtual bool PreResize(); virtual bool PreResize();
// Generates a paint event // Generates a paint event
virtual void DoPaint(); virtual void DoPaint();
// update rectangle/region manipulation // update rectangle/region manipulation
// (for wxWindowDC and Motif callbacks only) // (for wxWindowDC and Motif callbacks only)
// ----------------------------------------- // -----------------------------------------
// Adds a recangle to the updates list // Adds a recangle to the updates list
void AddUpdateRect(int x, int y, int w, int h); void AddUpdateRect(int x, int y, int w, int h);
void ClearUpdateRegion() { m_updateRegion.Clear(); } void ClearUpdateRegion() { m_updateRegion.Clear(); }
void SetUpdateRegion(const wxRegion& region) { m_updateRegion = region; } void SetUpdateRegion(const wxRegion& region) { m_updateRegion = region; }
// Process idle (send update events) // Process idle (send update events)
void OnInternalIdle(); void OnInternalIdle();
protected: protected:
// Responds to colour changes: passes event on to children. // Responds to colour changes: passes event on to children.
void OnSysColourChanged(wxSysColourChangedEvent& event); void OnSysColourChanged(wxSysColourChangedEvent& event);
// Motif-specific // Motif-specific
void SetMainWidget(WXWidget w) { m_mainWidget = w; } void SetMainWidget(WXWidget w) { m_mainWidget = w; }
// See src/motif/window.cpp, near the top, for an explanation // See src/motif/window.cpp, near the top, for an explanation
// why this is necessary // why this is necessary
void CanvasSetSizeIntr(int x, int y, int width, int height, void CanvasSetSizeIntr(int x, int y, int width, int height,
@@ -185,23 +185,23 @@ public:
int GetPixmapHeight() const { return m_pixmapHeight; } int GetPixmapHeight() const { return m_pixmapHeight; }
void SetPixmapWidth(int w) { m_pixmapWidth = w; } void SetPixmapWidth(int w) { m_pixmapWidth = w; }
void SetPixmapHeight(int h) { m_pixmapHeight = h; } void SetPixmapHeight(int h) { m_pixmapHeight = h; }
// Change properties // Change properties
// Change to the current font (often overridden) // Change to the current font (often overridden)
virtual void ChangeFont(bool keepOriginalSize = true); virtual void ChangeFont(bool keepOriginalSize = true);
// Change background and foreground colour using current background colour // Change background and foreground colour using current background colour
// setting (Motif generates foreground based on background) // setting (Motif generates foreground based on background)
virtual void ChangeBackgroundColour(); virtual void ChangeBackgroundColour();
// Change foreground colour using current foreground colour setting // Change foreground colour using current foreground colour setting
virtual void ChangeForegroundColour(); virtual void ChangeForegroundColour();
protected: protected:
// Adds the widget to the hash table and adds event handlers. // Adds the widget to the hash table and adds event handlers.
bool AttachWidget(wxWindow* parent, WXWidget mainWidget, bool AttachWidget(wxWindow* parent, WXWidget mainWidget,
WXWidget formWidget, int x, int y, int width, int height); WXWidget formWidget, int x, int y, int width, int height);
bool DetachWidget(WXWidget widget); bool DetachWidget(WXWidget widget);
// How to implement accelerators. If we find a key event, translate to // How to implement accelerators. If we find a key event, translate to
// wxWidgets wxKeyEvent form. Find a widget for the window. Now find a // wxWidgets wxKeyEvent form. Find a widget for the window. Now find a
// wxWindow for the widget. If there isn't one, go up the widget hierarchy // wxWindow for the widget. If there isn't one, go up the widget hierarchy
@@ -216,26 +216,26 @@ protected:
// event and send it. // event and send it.
public: public:
virtual bool ProcessAccelerator(wxKeyEvent& event); virtual bool ProcessAccelerator(wxKeyEvent& event);
protected: protected:
// unmanage and destroy an X widget f it's !NULL (passing NULL is ok) // unmanage and destroy an X widget f it's !NULL (passing NULL is ok)
void UnmanageAndDestroy(WXWidget widget); void UnmanageAndDestroy(WXWidget widget);
// map or unmap an X widget (passing NULL is ok), // map or unmap an X widget (passing NULL is ok),
// returns true if widget was mapped/unmapped // returns true if widget was mapped/unmapped
bool MapOrUnmap(WXWidget widget, bool map); bool MapOrUnmap(WXWidget widget, bool map);
// scrolling stuff // scrolling stuff
// --------------- // ---------------
// create/destroy window scrollbars // create/destroy window scrollbars
void CreateScrollbar(wxOrientation orientation); void CreateScrollbar(wxOrientation orientation);
void DestroyScrollbar(wxOrientation orientation); void DestroyScrollbar(wxOrientation orientation);
// get either hor or vert scrollbar widget // get either hor or vert scrollbar widget
WXWidget GetScrollbar(wxOrientation orient) const WXWidget GetScrollbar(wxOrientation orient) const
{ return orient == wxHORIZONTAL ? m_hScrollBar : m_vScrollBar; } { return orient == wxHORIZONTAL ? m_hScrollBar : m_vScrollBar; }
// set the scroll pos // set the scroll pos
void SetInternalScrollPos(wxOrientation orient, int pos) void SetInternalScrollPos(wxOrientation orient, int pos)
{ {
@@ -244,16 +244,16 @@ protected:
else else
m_scrollPosY = pos; m_scrollPosY = pos;
} }
// Motif-specific flags // Motif-specific flags
// -------------------- // --------------------
bool m_needsRefresh:1; // repaint backing store? bool m_needsRefresh:1; // repaint backing store?
// For double-click detection // For double-click detection
long m_lastTS; // last timestamp long m_lastTS; // last timestamp
unsigned m_lastButton:2; // last pressed button unsigned m_lastButton:2; // last pressed button
protected: protected:
WXWidget m_mainWidget; WXWidget m_mainWidget;
WXWidget m_hScrollBar; WXWidget m_hScrollBar;
@@ -267,12 +267,12 @@ protected:
int m_pixmapHeight; int m_pixmapHeight;
int m_pixmapOffsetX; int m_pixmapOffsetX;
int m_pixmapOffsetY; int m_pixmapOffsetY;
// Store the last scroll pos, since in wxWin the pos isn't set // Store the last scroll pos, since in wxWin the pos isn't set
// automatically by system // automatically by system
int m_scrollPosX; int m_scrollPosX;
int m_scrollPosY; int m_scrollPosY;
// implement the base class pure virtuals // implement the base class pure virtuals
virtual void DoClientToScreen( int *x, int *y ) const; virtual void DoClientToScreen( int *x, int *y ) const;
virtual void DoScreenToClient( int *x, int *y ) const; virtual void DoScreenToClient( int *x, int *y ) const;
@@ -291,11 +291,11 @@ protected:
#if wxUSE_TOOLTIPS #if wxUSE_TOOLTIPS
virtual void DoSetToolTip( wxToolTip *tip ); virtual void DoSetToolTip( wxToolTip *tip );
#endif // wxUSE_TOOLTIPS #endif // wxUSE_TOOLTIPS
private: private:
// common part of all ctors // common part of all ctors
void Init(); void Init();
DECLARE_DYNAMIC_CLASS(wxWindow) DECLARE_DYNAMIC_CLASS(wxWindow)
DECLARE_NO_COPY_CLASS(wxWindow) DECLARE_NO_COPY_CLASS(wxWindow)
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
@@ -318,12 +318,11 @@ class WXDLLEXPORT wxNoOptimize
public: public:
wxNoOptimize() { ms_count++; } wxNoOptimize() { ms_count++; }
~wxNoOptimize() { ms_count--; } ~wxNoOptimize() { ms_count--; }
static bool CanOptimize() { return ms_count == 0; } static bool CanOptimize() { return ms_count == 0; }
protected: protected:
static int ms_count; static int ms_count;
}; };
#endif #endif // _WX_WINDOW_H_
// _WX_WINDOW_H_

View File

@@ -154,7 +154,9 @@ public:
// return true if the frame is in fullscreen mode // return true if the frame is in fullscreen mode
virtual bool IsFullScreen() const = 0; virtual bool IsFullScreen() const = 0;
#ifdef __WXMSW__ #if !defined(__WXMSW__) && \
!defined(__WXMOTIF__)
// FIXME: This is work in progress about moving SetTitle/GetTitle from wxWindow // FIXME: This is work in progress about moving SetTitle/GetTitle from wxWindow
// to wxTopLevelWindow so initially enabled in wxMSW only to observe results // to wxTopLevelWindow so initially enabled in wxMSW only to observe results
// and continue on other platforms // and continue on other platforms

View File

@@ -168,7 +168,9 @@ public:
// window attributes // window attributes
// ----------------- // -----------------
#ifndef __WXMSW__ #if !defined(__WXMSW__) && \
!defined(__WXMOTIF__)
// FIXME: This is work in progress about moving SetTitle/GetTitle from wxWindow // FIXME: This is work in progress about moving SetTitle/GetTitle from wxWindow
// to wxTopLevelWindow so initially enabled in wxMSW only to observe results // to wxTopLevelWindow so initially enabled in wxMSW only to observe results
// and continue on other platforms // and continue on other platforms

View File

@@ -632,17 +632,17 @@ void wxWindow::Lower()
XLowerWindow(XtDisplay(wTop), window); XLowerWindow(XtDisplay(wTop), window);
} }
void wxWindow::SetTitle(const wxString& title) void wxWindow::SetLabel(const wxString& label)
{ {
XtVaSetValues((Widget)GetMainWidget(), XmNtitle, title.c_str(), NULL); XtVaSetValues((Widget)GetMainWidget(), XmNtitle, label.c_str(), NULL);
} }
wxString wxWindow::GetTitle() const wxString wxWindow::GetLabel() const
{ {
char *title; char *label;
XtVaGetValues((Widget)GetMainWidget(), XmNtitle, &title, NULL); XtVaGetValues((Widget)GetMainWidget(), XmNtitle, &label, NULL);
return wxString(title); return wxString(label);
} }
void wxWindow::DoCaptureMouse() void wxWindow::DoCaptureMouse()
@@ -852,7 +852,7 @@ void wxWindow::SetScrollbar(int orient, int pos, int thumbVisible,
// Adjusting scrollbars can resize the canvas accidentally // Adjusting scrollbars can resize the canvas accidentally
if (newW != oldW || newH != oldH) if (newW != oldW || newH != oldH)
SetSize(-1, -1, oldW, oldH); SetSize(wxDefaultCoord, wxDefaultCoord, oldW, oldH);
} }
// Does a physical scroll // Does a physical scroll
@@ -1065,7 +1065,7 @@ void wxWindow::DoSetToolTip(wxToolTip * WXUNUSED(tooltip))
bool wxWindow::DoPopupMenu(wxMenu *menu, int x, int y) bool wxWindow::DoPopupMenu(wxMenu *menu, int x, int y)
{ {
if ( x == -1 && y == -1 ) if ( x == wxDefaultCoord && y == wxDefaultCoord )
{ {
wxPoint mouse = ScreenToClient(wxGetMousePosition()); wxPoint mouse = ScreenToClient(wxGetMousePosition());
x = mouse.x; y = mouse.y; x = mouse.x; y = mouse.y;
@@ -1262,7 +1262,7 @@ void wxWindow::DoSetSizeIntr(int x, int y, int width, int height,
y = oldY; y = oldY;
} }
wxSize size(-1, -1); wxSize size(wxDefaultSize);
if ( width <= 0 ) if ( width <= 0 )
{ {
if ( ( sizeFlags & wxSIZE_AUTO_WIDTH ) && !fromCtor ) if ( ( sizeFlags & wxSIZE_AUTO_WIDTH ) && !fromCtor )
@@ -2546,4 +2546,3 @@ wxPoint wxGetMousePosition()
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
int wxNoOptimize::ms_count = 0; int wxNoOptimize::ms_count = 0;