Re-Added wxStream::StreamSize()

Added in-place editting to wxTreeCtrl,
    modified wxListCtrl in-place editting
  Corrected behaviour of wxToolBar::Toggle() to not
    send messages and to report the correct state
  Removed many #include "wx/wx.h" to speed up
   compilation
 Some more compile fixes and tests.


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@3132 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robert Roebling 1999-07-25 12:59:58 +00:00
parent a76015e6eb
commit e179bd6537
15 changed files with 388 additions and 148 deletions

View File

@ -16,6 +16,7 @@
#endif #endif
#include "wx/helpbase.h" #include "wx/helpbase.h"
#include "wx/frame.h"
/// Name for map file. /// Name for map file.
#define WXEXTHELP_MAPFILE "wxhelp.map" #define WXEXTHELP_MAPFILE "wxhelp.map"
@ -132,7 +133,7 @@ DECLARE_ABSTRACT_CLASS(wxHTMLHelpControllerBase)
wxPoint *pos = NULL, wxPoint *pos = NULL,
bool *newFrameEachTime = NULL) bool *newFrameEachTime = NULL)
{ {
return NULL;// does nothing by default return (wxFrame*) NULL;// does nothing by default
} }
protected: protected:

View File

@ -49,7 +49,7 @@ class WXDLLEXPORT wxListHeaderWindow;
class WXDLLEXPORT wxListMainWindow; class WXDLLEXPORT wxListMainWindow;
class WXDLLEXPORT wxListRenameTimer; class WXDLLEXPORT wxListRenameTimer;
//class wxListTextCtrl; class WXDLLEXPORT wxListTextCtrl;
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// types // types
@ -439,6 +439,7 @@ class WXDLLEXPORT wxListMainWindow: public wxScrolledWindow
wxList m_lines; wxList m_lines;
wxList m_columns; wxList m_columns;
wxListLineData *m_current; wxListLineData *m_current;
wxListLineData *m_currentEdit;
int m_visibleLines; int m_visibleLines;
wxBrush *m_hilightBrush; wxBrush *m_hilightBrush;
wxColour *m_hilightColour; wxColour *m_hilightColour;
@ -452,18 +453,17 @@ class WXDLLEXPORT wxListMainWindow: public wxScrolledWindow
bool m_usedKeys; bool m_usedKeys;
bool m_lastOnSame; bool m_lastOnSame;
wxTimer *m_renameTimer; wxTimer *m_renameTimer;
// wxListTextCtrl *m_text;
bool m_renameAccept; bool m_renameAccept;
wxString m_renameRes; wxString m_renameRes;
bool m_isCreated; bool m_isCreated;
int m_dragCount; int m_dragCount;
public: public:
wxListMainWindow(void); wxListMainWindow();
wxListMainWindow( wxWindow *parent, wxWindowID id, wxListMainWindow( wxWindow *parent, wxWindowID id,
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
long style = 0, const wxString &name = "listctrl" ); long style = 0, const wxString &name = "listctrl" );
~wxListMainWindow(void); ~wxListMainWindow();
void RefreshLine( wxListLineData *line ); void RefreshLine( wxListLineData *line );
void OnPaint( wxPaintEvent &event ); void OnPaint( wxPaintEvent &event );
void HilightAll( bool on ); void HilightAll( bool on );
@ -473,18 +473,20 @@ class WXDLLEXPORT wxListMainWindow: public wxScrolledWindow
void SelectLine( wxListLineData *line ); void SelectLine( wxListLineData *line );
void DeselectLine( wxListLineData *line ); void DeselectLine( wxListLineData *line );
void DeleteLine( wxListLineData *line ); void DeleteLine( wxListLineData *line );
void RenameLine( wxListLineData *line, const wxString &newName );
void StartLabelEdit( wxListLineData *line ); void Edit( long item );
void OnRenameTimer(void); void OnRenameTimer();
void OnRenameAccept(void); void OnRenameAccept();
void OnMouse( wxMouseEvent &event ); void OnMouse( wxMouseEvent &event );
void MoveToFocus( void ); void MoveToFocus();
void OnArrowChar( wxListLineData *newCurrent, bool shiftDown ); void OnArrowChar( wxListLineData *newCurrent, bool shiftDown );
void OnChar( wxKeyEvent &event ); void OnChar( wxKeyEvent &event );
void OnKeyDown( wxKeyEvent &event ); void OnKeyDown( wxKeyEvent &event );
void OnSetFocus( wxFocusEvent &event ); void OnSetFocus( wxFocusEvent &event );
void OnKillFocus( wxFocusEvent &event ); void OnKillFocus( wxFocusEvent &event );
void OnSize( wxSizeEvent &event ); void OnSize( wxSizeEvent &event );
void DrawImage( int index, wxDC *dc, int x, int y ); void DrawImage( int index, wxDC *dc, int x, int y );
void GetImageSize( int index, int &width, int &height ); void GetImageSize( int index, int &width, int &height );
int GetIndexOfLine( const wxListLineData *line ); int GetIndexOfLine( const wxListLineData *line );
@ -497,28 +499,28 @@ class WXDLLEXPORT wxListMainWindow: public wxScrolledWindow
void SetColumnWidth( int col, int width ); void SetColumnWidth( int col, int width );
void GetColumn( int col, wxListItem &item ); void GetColumn( int col, wxListItem &item );
int GetColumnWidth( int vol ); int GetColumnWidth( int vol );
int GetColumnCount( void ); int GetColumnCount();
int GetCountPerPage( void ); int GetCountPerPage();
void SetItem( wxListItem &item ); void SetItem( wxListItem &item );
void GetItem( wxListItem &item ); void GetItem( wxListItem &item );
void SetItemState( long item, long state, long stateMask ); void SetItemState( long item, long state, long stateMask );
int GetItemState( long item, long stateMask ); int GetItemState( long item, long stateMask );
int GetItemCount( void ); int GetItemCount();
void GetItemRect( long index, wxRect &rect ); void GetItemRect( long index, wxRect &rect );
bool GetItemPosition(long item, wxPoint& pos); bool GetItemPosition( long item, wxPoint& pos );
int GetSelectedItemCount( void ); int GetSelectedItemCount();
void SetMode( long mode ); void SetMode( long mode );
long GetMode( void ) const; long GetMode() const;
void CalculatePositions( void ); void CalculatePositions();
void RealizeChanges(void); void RealizeChanges();
long GetNextItem( long item, int geometry, int state ); long GetNextItem( long item, int geometry, int state );
void DeleteItem( long index ); void DeleteItem( long index );
void DeleteAllItems( void ); void DeleteAllItems();
void DeleteColumn( int col ); void DeleteColumn( int col );
void DeleteEverything( void ); void DeleteEverything();
void EnsureVisible( long index ); void EnsureVisible( long index );
long FindItem(long start, const wxString& str, bool partial = FALSE ); long FindItem( long start, const wxString& str, bool partial = FALSE );
long FindItem(long start, long data); long FindItem( long start, long data);
long HitTest( int x, int y, int &flags ); long HitTest( int x, int y, int &flags );
void InsertItem( wxListItem &item ); void InsertItem( wxListItem &item );
// void AddItem( wxListItem &item ); // void AddItem( wxListItem &item );
@ -538,8 +540,7 @@ class WXDLLEXPORT wxListCtrl: public wxControl
DECLARE_DYNAMIC_CLASS(wxListCtrl); DECLARE_DYNAMIC_CLASS(wxListCtrl);
public: public:
wxListCtrl();
wxListCtrl(void);
wxListCtrl( wxWindow *parent, wxWindowID id = -1, wxListCtrl( wxWindow *parent, wxWindowID id = -1,
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
long style = wxLC_ICON, const wxValidator& validator = wxDefaultValidator, long style = wxLC_ICON, const wxValidator& validator = wxDefaultValidator,
@ -547,7 +548,7 @@ class WXDLLEXPORT wxListCtrl: public wxControl
{ {
Create(parent, id, pos, size, style, validator, name); Create(parent, id, pos, size, style, validator, name);
} }
~wxListCtrl(void); ~wxListCtrl();
bool Create( wxWindow *parent, wxWindowID id = -1, bool Create( wxWindow *parent, wxWindowID id = -1,
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
long style = wxLC_ICON, const wxValidator& validator = wxDefaultValidator, long style = wxLC_ICON, const wxValidator& validator = wxDefaultValidator,
@ -557,8 +558,7 @@ class WXDLLEXPORT wxListCtrl: public wxControl
bool SetColumn( int col, wxListItem& item ); bool SetColumn( int col, wxListItem& item );
int GetColumnWidth( int col ) const; int GetColumnWidth( int col ) const;
bool SetColumnWidth( int col, int width); bool SetColumnWidth( int col, int width);
int GetCountPerPage(void) const; // not the same in wxGLC as in Windows, I think int GetCountPerPage() const; // not the same in wxGLC as in Windows, I think
// wxText& GetEditControl(void) const; // not supported in wxGLC
bool GetItem( wxListItem& info ) const; bool GetItem( wxListItem& info ) const;
bool SetItem( wxListItem& info ) ; bool SetItem( wxListItem& info ) ;
long SetItem( long index, int col, const wxString& label, int imageId = -1 ); long SetItem( long index, int col, const wxString& label, int imageId = -1 );
@ -572,42 +572,46 @@ class WXDLLEXPORT wxListCtrl: public wxControl
bool GetItemRect( long item, wxRect& rect, int code = wxLIST_RECT_BOUNDS ) const; bool GetItemRect( long item, wxRect& rect, int code = wxLIST_RECT_BOUNDS ) const;
bool GetItemPosition( long item, wxPoint& pos ) const; bool GetItemPosition( long item, wxPoint& pos ) const;
bool SetItemPosition( long item, const wxPoint& pos ); // not supported in wxGLC bool SetItemPosition( long item, const wxPoint& pos ); // not supported in wxGLC
int GetItemCount(void) const; int GetItemCount() const;
int GetColumnCount(void) const; int GetColumnCount() const;
void SetItemSpacing( int spacing, bool isSmall = FALSE ); void SetItemSpacing( int spacing, bool isSmall = FALSE );
int GetItemSpacing( bool isSmall ) const; int GetItemSpacing( bool isSmall ) const;
int GetSelectedItemCount(void) const; int GetSelectedItemCount() const;
// wxColour GetTextColour(void) const; // wxGLC has colours for every Item (see wxListItem) // wxColour GetTextColour() const; // wxGLC has colours for every Item (see wxListItem)
// void SetTextColour(const wxColour& col); // void SetTextColour(const wxColour& col);
long GetTopItem(void) const; long GetTopItem() const;
void SetSingleStyle( long style, bool add = TRUE ) ; void SetSingleStyle( long style, bool add = TRUE ) ;
void SetWindowStyleFlag(long style); void SetWindowStyleFlag( long style );
void RecreateWindow(void) {}; void RecreateWindow() {}
long GetNextItem(long item, int geometry = wxLIST_NEXT_ALL, int state = wxLIST_STATE_DONTCARE) const; long GetNextItem( long item, int geometry = wxLIST_NEXT_ALL, int state = wxLIST_STATE_DONTCARE ) const;
wxImageList *GetImageList(int which) const; wxImageList *GetImageList( int which ) const;
void SetImageList(wxImageList *imageList, int which) ; void SetImageList( wxImageList *imageList, int which );
bool Arrange( int flag = wxLIST_ALIGN_DEFAULT ); // always wxLIST_ALIGN_LEFT in wxGLC bool Arrange( int flag = wxLIST_ALIGN_DEFAULT ); // always wxLIST_ALIGN_LEFT in wxGLC
void ClearAll(); void ClearAll();
bool DeleteItem( long item ); bool DeleteItem( long item );
bool DeleteAllItems(void); bool DeleteAllItems();
bool DeleteAllColumns(void); bool DeleteAllColumns();
bool DeleteColumn( int col ); bool DeleteColumn( int col );
// wxText& Edit(long item) ; // not supported in wxGLC
void EditLabel( long item ) { Edit(item); }
void Edit( long item );
bool EnsureVisible( long item ); bool EnsureVisible( long item );
long FindItem(long start, const wxString& str, bool partial = FALSE ); long FindItem( long start, const wxString& str, bool partial = FALSE );
long FindItem(long start, long data); long FindItem( long start, long data );
long FindItem(long start, const wxPoint& pt, int direction); // not supported in wxGLC long FindItem( long start, const wxPoint& pt, int direction ); // not supported in wxGLC
long HitTest(const wxPoint& point, int& flags); long HitTest( const wxPoint& point, int& flags);
long InsertItem(wxListItem& info); long InsertItem(wxListItem& info);
long InsertItem(long index, const wxString& label); long InsertItem( long index, const wxString& label );
long InsertItem(long index, int imageIndex); long InsertItem( long index, int imageIndex );
long InsertItem(long index, const wxString& label, int imageIndex); long InsertItem( long index, const wxString& label, int imageIndex );
long InsertColumn(long col, wxListItem& info); long InsertColumn( long col, wxListItem& info );
long InsertColumn(long col, const wxString& heading, int format = wxLIST_FORMAT_LEFT, long InsertColumn( long col, const wxString& heading, int format = wxLIST_FORMAT_LEFT,
int width = -1); int width = -1 );
bool ScrollList(int dx, int dy); bool ScrollList( int dx, int dy );
bool SortItems(wxListCtrlCompare fn, long data); bool SortItems( wxListCtrlCompare fn, long data );
bool Update(long item); bool Update( long item );
void OnIdle( wxIdleEvent &event ); void OnIdle( wxIdleEvent &event );
// We have to hand down a few functions // We have to hand down a few functions
@ -635,8 +639,7 @@ class WXDLLEXPORT wxListCtrl: public wxControl
{ m_mainWin->SetFocus(); } { m_mainWin->SetFocus(); }
// implementation // implementation
// wxListTextCtrl m_textCtrl;
wxImageList *m_imageListNormal; wxImageList *m_imageListNormal;
wxImageList *m_imageListSmall; wxImageList *m_imageListSmall;
wxImageList *m_imageListState; // what's that ? wxImageList *m_imageListState; // what's that ?

View File

@ -30,6 +30,7 @@ WXDLLEXPORT_DATA(extern const char*) wxTreeCtrlNameStr;
#include "wx/textctrl.h" #include "wx/textctrl.h"
#include "wx/pen.h" #include "wx/pen.h"
#include "wx/dynarray.h" #include "wx/dynarray.h"
#include "wx/timer.h"
//those defines should only be done in generic/treectrl.h, //those defines should only be done in generic/treectrl.h,
//because wxMSW doesn't allow mutiple selection //because wxMSW doesn't allow mutiple selection
@ -80,10 +81,13 @@ static const int wxTREE_HITTEST_ONITEM = wxTREE_HITTEST_ONITEMICON |
// forward declaration // forward declaration
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
class wxImageList; class WXDLLEXPORT wxImageList;
class wxGenericTreeItem; class WXDLLEXPORT wxGenericTreeItem;
class wxTreeItemData; class WXDLLEXPORT wxTreeItemData;
class WXDLLEXPORT wxTreeRenameTimer;
class WXDLLEXPORT wxTreeTextCtrl;
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
// wxTreeItemId - unique identifier of a tree element // wxTreeItemId - unique identifier of a tree element
@ -123,6 +127,7 @@ WX_DECLARE_OBJARRAY(wxTreeItemId, wxArrayTreeItemIds);
// Because the objects of this class are deleted by the tree, they should // Because the objects of this class are deleted by the tree, they should
// always be allocated on the heap! // always be allocated on the heap!
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
class WXDLLEXPORT wxTreeItemData: public wxClientData class WXDLLEXPORT wxTreeItemData: public wxClientData
{ {
friend class wxTreeCtrl; friend class wxTreeCtrl;
@ -142,6 +147,47 @@ protected:
wxTreeItemId m_pItem; wxTreeItemId m_pItem;
}; };
//-----------------------------------------------------------------------------
// wxTreeRenameTimer (internal)
//-----------------------------------------------------------------------------
class WXDLLEXPORT wxTreeRenameTimer: public wxTimer
{
private:
wxTreeCtrl *m_owner;
public:
wxTreeRenameTimer( wxTreeCtrl *owner );
void Notify();
};
//-----------------------------------------------------------------------------
// wxTreeTextCtrl (internal)
//-----------------------------------------------------------------------------
class WXDLLEXPORT wxTreeTextCtrl: public wxTextCtrl
{
DECLARE_DYNAMIC_CLASS(wxTreeTextCtrl);
private:
bool *m_accept;
wxString *m_res;
wxTreeCtrl *m_owner;
public:
wxTreeTextCtrl(void) {};
wxTreeTextCtrl( wxWindow *parent, const wxWindowID id,
bool *accept, wxString *res, wxTreeCtrl *owner,
const wxString &value = "",
const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
int style = 0, const wxValidator& validator = wxDefaultValidator,
const wxString &name = "wxTreeTextCtrlText" );
void OnChar( wxKeyEvent &event );
void OnKillFocus( wxFocusEvent &event );
DECLARE_EVENT_TABLE()
};
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
// wxTreeCtrl - the tree control // wxTreeCtrl - the tree control
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
@ -368,19 +414,12 @@ public:
{ int dummy; return HitTest(point, dummy); } { int dummy; return HitTest(point, dummy); }
wxTreeItemId HitTest(const wxPoint& point, int& flags); wxTreeItemId HitTest(const wxPoint& point, int& flags);
// start editing the item label: this (temporarily) replaces the item // Start editing the item label: this (temporarily) replaces the item
// with a one line edit control. The item will be selected if it hadn't // with a one line edit control. The item will be selected if it hadn't
// been before. textCtrlClass parameter allows you to create an edit // been before.
// control of arbitrary user-defined class deriving from wxTextCtrl. void EditLabel( const wxTreeItemId& item ) { Edit( item ); }
wxTextCtrl* EditLabel(const wxTreeItemId& item, void Edit( const wxTreeItemId& item );
wxClassInfo* textCtrlClass = CLASSINFO(wxTextCtrl));
// returns the same pointer as StartEdit() if the item is being edited,
// NULL otherwise (it's assumed that no more than one item may be
// edited simultaneously)
wxTextCtrl* GetEditControl() const;
// end editing and accept or discard the changes to item label
void EndEditLabel(const wxTreeItemId& item, bool discardChanges = FALSE);
// sorting // sorting
// this function is called to compare 2 items and should return -1, 0 // this function is called to compare 2 items and should return -1, 0
// or +1 if the first item is less than, equal to or greater than the // or +1 if the first item is less than, equal to or greater than the
@ -410,9 +449,11 @@ public:
protected: protected:
friend class wxGenericTreeItem; friend class wxGenericTreeItem;
friend class wxTreeRenameTimer;
friend class wxTreeTextCtrl;
wxGenericTreeItem *m_anchor; wxGenericTreeItem *m_anchor;
wxGenericTreeItem *m_current, *m_key_current; wxGenericTreeItem *m_current, *m_key_current, *m_currentEdit;
bool m_hasFocus; bool m_hasFocus;
bool m_dirty; bool m_dirty;
int m_xScroll,m_yScroll; int m_xScroll,m_yScroll;
@ -424,6 +465,9 @@ protected:
wxImageList *m_imageListNormal, wxImageList *m_imageListNormal,
*m_imageListState; *m_imageListState;
int m_dragCount; int m_dragCount;
wxTimer *m_renameTimer;
bool m_renameAccept;
wxString m_renameRes;
// the common part of all ctors // the common part of all ctors
void Init(); void Init();
@ -446,6 +490,9 @@ protected:
void RefreshSubtree( wxGenericTreeItem *item ); void RefreshSubtree( wxGenericTreeItem *item );
void RefreshLine( wxGenericTreeItem *item ); void RefreshLine( wxGenericTreeItem *item );
void OnRenameTimer();
void OnRenameAccept();
void FillArray(wxGenericTreeItem*, wxArrayTreeItemIds&) const; void FillArray(wxGenericTreeItem*, wxArrayTreeItemIds&) const;
void SelectItemRange( wxGenericTreeItem *item1, wxGenericTreeItem *item2 ); void SelectItemRange( wxGenericTreeItem *item1, wxGenericTreeItem *item2 );

View File

@ -16,7 +16,10 @@
#pragma interface "helpbase.h" #pragma interface "helpbase.h"
#endif #endif
#include "wx/wx.h" #include "wx/defs.h"
#include "wx/object.h"
#include "wx/string.h"
#include "wx/gdicmn.h"
#if wxUSE_HELP #if wxUSE_HELP
@ -29,8 +32,8 @@ class WXDLLEXPORT wxHelpControllerBase: public wxObject
DECLARE_CLASS(wxHelpControllerBase) DECLARE_CLASS(wxHelpControllerBase)
public: public:
inline wxHelpControllerBase(void) {} inline wxHelpControllerBase() {}
inline ~wxHelpControllerBase(void) {}; inline ~wxHelpControllerBase() {};
// Must call this to set the filename and server name. // Must call this to set the filename and server name.
// server is only required when implementing TCP/IP-based // server is only required when implementing TCP/IP-based

View File

@ -58,6 +58,7 @@ class WXDLLEXPORT wxStreamBase {
bool operator!() const { return (LastError() != wxSTR_NOERROR); } bool operator!() const { return (LastError() != wxSTR_NOERROR); }
wxStreamError LastError() const { return m_lasterror; } wxStreamError LastError() const { return m_lasterror; }
virtual size_t GetSize() const { return ~((size_t)0); } virtual size_t GetSize() const { return ~((size_t)0); }
size_t StreamSize() const { return GetSize(); }
protected: protected:

View File

@ -146,7 +146,7 @@ bool MyApp::OnInit(void)
// Make a panel with a message // Make a panel with a message
frame->m_listCtrl = new MyListCtrl(frame, LIST_CTRL, wxPoint(0, 0), wxSize(400, 200), frame->m_listCtrl = new MyListCtrl(frame, LIST_CTRL, wxPoint(0, 0), wxSize(400, 200),
wxLC_LIST|wxSUNKEN_BORDER); wxLC_LIST|wxSUNKEN_BORDER|wxLC_EDIT_LABELS);
// wxLC_LIST|wxLC_USER_TEXT|wxSUNKEN_BORDER); // wxLC_USER_TEXT requires app to supply all text on demand // wxLC_LIST|wxLC_USER_TEXT|wxSUNKEN_BORDER); // wxLC_USER_TEXT requires app to supply all text on demand
frame->m_logWindow = new wxTextCtrl(frame, -1, "", wxPoint(0, 0), wxSize(400, 200), wxTE_MULTILINE|wxSUNKEN_BORDER); frame->m_logWindow = new wxTextCtrl(frame, -1, "", wxPoint(0, 0), wxSize(400, 200), wxTE_MULTILINE|wxSUNKEN_BORDER);

View File

@ -129,9 +129,9 @@ bool MyApp::InitToolbar(wxToolBar* toolBar)
toolBar->AddTool(wxID_SAVE, *(toolBarBitmaps[2]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Save file"); toolBar->AddTool(wxID_SAVE, *(toolBarBitmaps[2]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Save file");
currentX += width + 5; currentX += width + 5;
toolBar->AddSeparator(); toolBar->AddSeparator();
toolBar->AddTool(wxID_COPY, *(toolBarBitmaps[3]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Copy"); toolBar->AddTool(wxID_COPY, *(toolBarBitmaps[3]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Disable/Enable print button");
currentX += width + 5; currentX += width + 5;
toolBar->AddTool(wxID_CUT, *(toolBarBitmaps[4]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Cut"); toolBar->AddTool(wxID_CUT, *(toolBarBitmaps[4]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Toggle/Untoggle help button");
currentX += width + 5; currentX += width + 5;
toolBar->AddTool(wxID_PASTE, *(toolBarBitmaps[5]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Paste"); toolBar->AddTool(wxID_PASTE, *(toolBarBitmaps[5]), wxNullBitmap, FALSE, currentX, -1, (wxObject *) NULL, "Paste");
currentX += width + 5; currentX += width + 5;
@ -157,9 +157,8 @@ bool MyApp::InitToolbar(wxToolBar* toolBar)
BEGIN_EVENT_TABLE(MyFrame, wxFrame) BEGIN_EVENT_TABLE(MyFrame, wxFrame)
EVT_MENU(wxID_EXIT, MyFrame::OnQuit) EVT_MENU(wxID_EXIT, MyFrame::OnQuit)
EVT_MENU(wxID_HELP, MyFrame::OnAbout)
EVT_CLOSE(MyFrame::OnCloseWindow) EVT_CLOSE(MyFrame::OnCloseWindow)
EVT_TOOL_RANGE(wxID_OPEN, wxID_PASTE, MyFrame::OnToolLeftClick) EVT_MENU(-1, MyFrame::OnToolLeftClick)
EVT_TOOL_ENTER(ID_TOOLBAR, MyFrame::OnToolEnter) EVT_TOOL_ENTER(ID_TOOLBAR, MyFrame::OnToolEnter)
END_EVENT_TABLE() END_EVENT_TABLE()
@ -168,7 +167,7 @@ MyFrame::MyFrame(wxFrame* parent, wxWindowID id, const wxString& title, const wx
const wxSize& size, long style): const wxSize& size, long style):
wxFrame(parent, id, title, pos, size, style) wxFrame(parent, id, title, pos, size, style)
{ {
m_textWindow = new wxTextCtrl(this, -1, "", wxPoint(0, 0), wxSize(-1, -1), wxTE_MULTILINE); m_textWindow = new wxTextCtrl(this, -1, "", wxPoint(0, 0), wxSize(-1, -1), wxTE_MULTILINE);
} }
void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event)) void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
@ -185,14 +184,37 @@ void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
// - must delete all frames except for the main one. // - must delete all frames except for the main one.
void MyFrame::OnCloseWindow(wxCloseEvent& WXUNUSED(event)) void MyFrame::OnCloseWindow(wxCloseEvent& WXUNUSED(event))
{ {
Destroy(); Destroy();
} }
void MyFrame::OnToolLeftClick(wxCommandEvent& event) void MyFrame::OnToolLeftClick(wxCommandEvent& event)
{ {
wxString str; wxString str;
str.Printf( _T("Clicked on tool %d"), event.GetId()); str.Printf( _T("Clicked on tool %d\n"), event.GetId());
SetStatusText(str); m_textWindow->WriteText( str );
if (event.GetId() == wxID_HELP)
{
if ((bool)event.GetExtraLong())
m_textWindow->WriteText( _T("Help button down now.\n") );
else
m_textWindow->WriteText( _T("Help button up now.\n") );
}
if (event.GetId() == wxID_COPY)
{
wxToolBar *tb = GetToolBar();
if (tb->GetToolEnabled(wxID_PRINT))
tb->EnableTool( wxID_PRINT, FALSE );
else
tb->EnableTool( wxID_PRINT, TRUE );
}
if (event.GetId() == wxID_CUT)
{
wxToolBar *tb = GetToolBar();
tb->ToggleTool( wxID_HELP, !tb->GetToolState( wxID_HELP ) );
}
} }
void MyFrame::OnToolEnter(wxCommandEvent& event) void MyFrame::OnToolEnter(wxCommandEvent& event)

View File

@ -44,7 +44,7 @@
#endif //__BORLANDC__ #endif //__BORLANDC__
#ifndef WX_PRECOMP #ifndef WX_PRECOMP
#include <wx/wx.h> #include "wx/string.h"
#endif //WX_PRECOMP #endif //WX_PRECOMP
#if wxUSE_ODBC #if wxUSE_ODBC

View File

@ -21,7 +21,10 @@
#endif #endif
#ifndef WX_PRECOMP #ifndef WX_PRECOMP
#include "wx/wx.h" #include "wx/settings.h"
#include "wx/window.h"
#include "wx/dcclient.h"
#include "wx/dcmemory.h"
#endif #endif
#if wxUSE_TOOLBAR #if wxUSE_TOOLBAR

View File

@ -29,7 +29,8 @@
#endif #endif
#ifndef WX_PRECOMP #ifndef WX_PRECOMP
#include "wx/wx.h" #include "wx/window.h"
#include "wx/dcclient.h"
#endif //WX_PRECOMP #endif //WX_PRECOMP
#include "wx/caret.h" #include "wx/caret.h"

View File

@ -27,6 +27,8 @@
#include "wx/utils.h" #include "wx/utils.h"
#include "wx/list.h" #include "wx/list.h"
#include "wx/intl.h" #include "wx/intl.h"
#include "wx/msgdlg.h"
#include "wx/choicdlg.h"
#endif #endif
#include "wx/helpbase.h" #include "wx/helpbase.h"

View File

@ -908,16 +908,14 @@ void wxListTextCtrl::OnChar( wxKeyEvent &event )
(*m_accept) = TRUE; (*m_accept) = TRUE;
(*m_res) = GetValue(); (*m_res) = GetValue();
m_owner->OnRenameAccept(); m_owner->OnRenameAccept();
// Show( FALSE ); if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
Destroy();
return; return;
} }
if (event.m_keyCode == WXK_ESCAPE) if (event.m_keyCode == WXK_ESCAPE)
{ {
(*m_accept) = FALSE; (*m_accept) = FALSE;
(*m_res) = ""; (*m_res) = "";
// Show( FALSE ); if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
Destroy();
return; return;
} }
event.Skip(); event.Skip();
@ -927,8 +925,7 @@ void wxListTextCtrl::OnKillFocus( wxFocusEvent &WXUNUSED(event) )
{ {
(*m_accept) = FALSE; (*m_accept) = FALSE;
(*m_res) = ""; (*m_res) = "";
// Show( FALSE ); if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
Destroy();
return; return;
} }
@ -1140,31 +1137,30 @@ void wxListMainWindow::DeleteLine( wxListLineData *line )
SendNotify( line, wxEVT_COMMAND_LIST_DELETE_ITEM ); SendNotify( line, wxEVT_COMMAND_LIST_DELETE_ITEM );
} }
void wxListMainWindow::StartLabelEdit( wxListLineData *line ) /* *** */
{
SendNotify( line, wxEVT_COMMAND_LIST_BEGIN_LABEL_EDIT );
}
void wxListMainWindow::RenameLine( wxListLineData *line, const wxString &newName ) void wxListMainWindow::Edit( long item )
{ {
wxNode *node = m_lines.Nth( item );
wxCHECK_RET( node, "wrong index in wxListCtrl::Edit() ");
m_currentEdit = (wxListLineData*) node->Data();
wxListEvent le( wxEVT_COMMAND_LIST_END_LABEL_EDIT, GetParent()->GetId() ); wxListEvent le( wxEVT_COMMAND_LIST_END_LABEL_EDIT, GetParent()->GetId() );
le.SetEventObject( GetParent() ); le.SetEventObject( GetParent() );
le.m_itemIndex = GetIndexOfLine( line ); le.m_itemIndex = GetIndexOfLine( m_currentEdit );
line->GetItem( 0, le.m_item ); m_currentEdit->GetItem( 0, le.m_item );
le.m_item.m_text = newName;
GetParent()->GetEventHandler()->ProcessEvent( le ); GetParent()->GetEventHandler()->ProcessEvent( le );
}
if (!le.IsAllowed()) return;
void wxListMainWindow::OnRenameTimer()
{
StartLabelEdit( m_current );
wxString s; wxString s;
m_current->GetText( 0, s ); m_currentEdit->GetText( 0, s );
int x = 0; int x = 0;
int y = 0; int y = 0;
int w = 0; int w = 0;
int h = 0; int h = 0;
m_current->GetLabelExtent( x, y, w, h ); m_currentEdit->GetLabelExtent( x, y, w, h );
wxClientDC dc(this); wxClientDC dc(this);
PrepareDC( dc ); PrepareDC( dc );
@ -1176,9 +1172,25 @@ void wxListMainWindow::OnRenameTimer()
text->SetFocus(); text->SetFocus();
} }
void wxListMainWindow::OnRenameTimer()
{
wxCHECK_RET( m_current, "invalid m_current" );
Edit( m_lines.IndexOf( m_current ) );
}
void wxListMainWindow::OnRenameAccept() void wxListMainWindow::OnRenameAccept()
{ {
RenameLine( m_current, m_renameRes ); wxListEvent le( wxEVT_COMMAND_LIST_END_LABEL_EDIT, GetParent()->GetId() );
le.SetEventObject( GetParent() );
le.m_itemIndex = GetIndexOfLine( m_currentEdit );
m_currentEdit->GetItem( 0, le.m_item );
le.m_item.m_text = m_renameRes;
GetParent()->GetEventHandler()->ProcessEvent( le );
if (!le.IsAllowed()) return;
/* DO CHANGE LABEL */
} }
void wxListMainWindow::OnMouse( wxMouseEvent &event ) void wxListMainWindow::OnMouse( wxMouseEvent &event )
@ -1340,7 +1352,7 @@ void wxListMainWindow::OnMouse( wxMouseEvent &event )
} }
} }
void wxListMainWindow::MoveToFocus( void ) void wxListMainWindow::MoveToFocus()
{ {
if (!m_current) return; if (!m_current) return;
@ -1788,12 +1800,12 @@ int wxListMainWindow::GetColumnWidth( int col )
} }
} }
int wxListMainWindow::GetColumnCount( void ) int wxListMainWindow::GetColumnCount()
{ {
return m_columns.Number(); return m_columns.Number();
} }
int wxListMainWindow::GetCountPerPage( void ) int wxListMainWindow::GetCountPerPage()
{ {
return m_visibleLines; return m_visibleLines;
} }
@ -1899,7 +1911,7 @@ void wxListMainWindow::GetItem( wxListItem &item )
} }
} }
int wxListMainWindow::GetItemCount( void ) int wxListMainWindow::GetItemCount()
{ {
return m_lines.Number(); return m_lines.Number();
} }
@ -1940,7 +1952,7 @@ bool wxListMainWindow::GetItemPosition(long item, wxPoint& pos)
return TRUE; return TRUE;
} }
int wxListMainWindow::GetSelectedItemCount( void ) int wxListMainWindow::GetSelectedItemCount()
{ {
int ret = 0; int ret = 0;
wxNode *node = m_lines.First(); wxNode *node = m_lines.First();
@ -1972,12 +1984,12 @@ void wxListMainWindow::SetMode( long mode )
} }
} }
long wxListMainWindow::GetMode( void ) const long wxListMainWindow::GetMode() const
{ {
return m_mode; return m_mode;
} }
void wxListMainWindow::CalculatePositions( void ) void wxListMainWindow::CalculatePositions()
{ {
if (!m_lines.First()) return; if (!m_lines.First()) return;
@ -2505,12 +2517,6 @@ int wxListCtrl::GetCountPerPage(void) const
return m_mainWin->GetCountPerPage(); // different from Windows ? return m_mainWin->GetCountPerPage(); // different from Windows ?
} }
/*
wxText& wxListCtrl::GetEditControl(void) const
{
}
*/
bool wxListCtrl::GetItem( wxListItem &info ) const bool wxListCtrl::GetItem( wxListItem &info ) const
{ {
m_mainWin->GetItem( info ); m_mainWin->GetItem( info );
@ -2715,11 +2721,10 @@ bool wxListCtrl::DeleteColumn( int col )
return TRUE; return TRUE;
} }
/* void wxListCtrl::Edit( long item )
wxText& wxListCtrl::Edit( long WXUNUSED(item ) )
{ {
m_mainWin->Edit( item );
} }
*/
bool wxListCtrl::EnsureVisible( long item ) bool wxListCtrl::EnsureVisible( long item )
{ {

View File

@ -157,12 +157,77 @@ private:
// implementation // implementation
// ============================================================================= // =============================================================================
// -----------------------------------------------------------------------------
// wxTreeRenameTimer (internal)
// -----------------------------------------------------------------------------
wxTreeRenameTimer::wxTreeRenameTimer( wxTreeCtrl *owner )
{
m_owner = owner;
}
void wxTreeRenameTimer::Notify()
{
m_owner->OnRenameTimer();
}
//-----------------------------------------------------------------------------
// wxTreeTextCtrl (internal)
//-----------------------------------------------------------------------------
IMPLEMENT_DYNAMIC_CLASS(wxTreeTextCtrl,wxTextCtrl);
BEGIN_EVENT_TABLE(wxTreeTextCtrl,wxTextCtrl)
EVT_CHAR (wxTreeTextCtrl::OnChar)
EVT_KILL_FOCUS (wxTreeTextCtrl::OnKillFocus)
END_EVENT_TABLE()
wxTreeTextCtrl::wxTreeTextCtrl( wxWindow *parent, const wxWindowID id,
bool *accept, wxString *res, wxTreeCtrl *owner,
const wxString &value, const wxPoint &pos, const wxSize &size,
int style, const wxValidator& validator, const wxString &name ) :
wxTextCtrl( parent, id, value, pos, size, style, validator, name )
{
m_res = res;
m_accept = accept;
m_owner = owner;
}
void wxTreeTextCtrl::OnChar( wxKeyEvent &event )
{
if (event.m_keyCode == WXK_RETURN)
{
(*m_accept) = TRUE;
(*m_res) = GetValue();
m_owner->OnRenameAccept();
if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
return;
}
if (event.m_keyCode == WXK_ESCAPE)
{
(*m_accept) = FALSE;
(*m_res) = "";
if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
return;
}
event.Skip();
}
void wxTreeTextCtrl::OnKillFocus( wxFocusEvent &WXUNUSED(event) )
{
(*m_accept) = FALSE;
(*m_res) = "";
if (!wxPendingDelete.Member(this)) wxPendingDelete.Append(this);
}
#define PIXELS_PER_UNIT 10 #define PIXELS_PER_UNIT 10
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
// wxTreeEvent // wxTreeEvent
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
IMPLEMENT_DYNAMIC_CLASS(wxTreeEvent, wxNotifyEvent)
IMPLEMENT_DYNAMIC_CLASS(wxTreeEvent, wxNotifyEvent)
wxTreeEvent::wxTreeEvent( wxEventType commandType, int id ) wxTreeEvent::wxTreeEvent( wxEventType commandType, int id )
: wxNotifyEvent( commandType, id ) : wxNotifyEvent( commandType, id )
{ {
@ -393,6 +458,8 @@ void wxTreeCtrl::Init()
m_imageListState = (wxImageList *) NULL; m_imageListState = (wxImageList *) NULL;
m_dragCount = 0; m_dragCount = 0;
m_renameTimer = new wxTreeRenameTimer( this );
} }
bool wxTreeCtrl::Create(wxWindow *parent, wxWindowID id, bool wxTreeCtrl::Create(wxWindow *parent, wxWindowID id,
@ -421,6 +488,8 @@ wxTreeCtrl::~wxTreeCtrl()
wxDELETE( m_hilightBrush ); wxDELETE( m_hilightBrush );
DeleteAllItems(); DeleteAllItems();
delete m_renameTimer;
} }
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
@ -1153,26 +1222,6 @@ void wxTreeCtrl::ScrollTo(const wxTreeItemId &item)
} }
} }
wxTextCtrl *wxTreeCtrl::EditLabel( const wxTreeItemId& WXUNUSED(item),
wxClassInfo* WXUNUSED(textCtrlClass) )
{
wxFAIL_MSG(_T("not implemented"));
return (wxTextCtrl*)NULL;
}
wxTextCtrl *wxTreeCtrl::GetEditControl() const
{
wxFAIL_MSG(_T("not implemented"));
return (wxTextCtrl*)NULL;
}
void wxTreeCtrl::EndEditLabel(const wxTreeItemId& WXUNUSED(item), bool WXUNUSED(discardChanges))
{
wxFAIL_MSG(_T("not implemented"));
}
// FIXME: tree sorting functions are not reentrant and not MT-safe! // FIXME: tree sorting functions are not reentrant and not MT-safe!
static wxTreeCtrl *s_treeBeingSorted = NULL; static wxTreeCtrl *s_treeBeingSorted = NULL;
@ -1732,6 +1781,55 @@ wxTreeItemId wxTreeCtrl::HitTest(const wxPoint& point, int& flags)
return m_anchor->HitTest( wxPoint(x, y), this, flags); return m_anchor->HitTest( wxPoint(x, y), this, flags);
} }
/* **** */
void wxTreeCtrl::Edit( const wxTreeItemId& item )
{
if (!item.IsOk()) return;
m_currentEdit = item.m_pItem;
wxTreeEvent te( wxEVT_COMMAND_TREE_BEGIN_LABEL_EDIT, GetId() );
te.m_item = m_currentEdit;
te.SetEventObject( this );
GetEventHandler()->ProcessEvent( te );
if (!te.IsAllowed()) return;
wxString s = m_currentEdit->GetText();
int x = m_currentEdit->GetX();
int y = m_currentEdit->GetY();
int w = m_currentEdit->GetWidth();
int h = m_currentEdit->GetHeight();
wxClientDC dc(this);
PrepareDC( dc );
x = dc.LogicalToDeviceX( x );
y = dc.LogicalToDeviceY( y );
wxTreeTextCtrl *text = new wxTreeTextCtrl(
this, -1, &m_renameAccept, &m_renameRes, this, s, wxPoint(x-4,y-4), wxSize(w+11,h+8) );
text->SetFocus();
}
void wxTreeCtrl::OnRenameTimer()
{
Edit( m_current );
}
void wxTreeCtrl::OnRenameAccept()
{
wxTreeEvent le( wxEVT_COMMAND_TREE_END_LABEL_EDIT, GetId() );
le.m_item = m_currentEdit;
le.SetEventObject( this );
le.m_label = m_renameRes;
GetEventHandler()->ProcessEvent( le );
if (!le.IsAllowed()) return;
/* DO CHANGE LABEL */
}
void wxTreeCtrl::OnMouse( wxMouseEvent &event ) void wxTreeCtrl::OnMouse( wxMouseEvent &event )
{ {
if (!event.LeftIsDown()) m_dragCount = 0; if (!event.LeftIsDown()) m_dragCount = 0;
@ -1769,6 +1867,14 @@ void wxTreeCtrl::OnMouse( wxMouseEvent &event )
return; return;
} }
if (event.LeftUp() && (item == m_current) &&
(flags & wxTREE_HITTEST_ONITEMLABEL) &&
HasFlag(wxTR_EDIT_LABELS) )
{
m_renameTimer->Start( 100, TRUE );
return;
}
bool is_multiple=(GetWindowStyleFlag() & wxTR_MULTIPLE); bool is_multiple=(GetWindowStyleFlag() & wxTR_MULTIPLE);
bool extended_select=(event.ShiftDown() && is_multiple); bool extended_select=(event.ShiftDown() && is_multiple);
bool unselect_others=!(extended_select || (event.ControlDown() && is_multiple)); bool unselect_others=!(extended_select || (event.ControlDown() && is_multiple));

View File

@ -381,9 +381,32 @@ void wxToolBar::ToggleTool( int toolIndex, bool toggle )
wxToolBarTool *tool = (wxToolBarTool*)node->Data(); wxToolBarTool *tool = (wxToolBarTool*)node->Data();
if (tool->m_index == toolIndex) if (tool->m_index == toolIndex)
{ {
tool->m_toggleState = toggle;
if ((tool->m_item) && (GTK_IS_TOGGLE_BUTTON(tool->m_item))) if ((tool->m_item) && (GTK_IS_TOGGLE_BUTTON(tool->m_item)))
{
tool->m_toggleState = toggle;
if (tool->m_bitmap2.Ok())
{
wxBitmap bitmap = tool->m_bitmap1;
if (tool->m_toggleState) bitmap = tool->m_bitmap2;
GtkPixmap *pixmap = GTK_PIXMAP( tool->m_pixmap );
GdkBitmap *mask = (GdkBitmap *) NULL;
if (bitmap.GetMask()) mask = bitmap.GetMask()->GetBitmap();
gtk_pixmap_set( pixmap, bitmap.GetPixmap(), mask );
}
gtk_signal_disconnect_by_func( GTK_OBJECT(tool->m_item),
GTK_SIGNAL_FUNC(gtk_toolbar_callback), (gpointer*)tool );
gtk_toggle_button_set_state( GTK_TOGGLE_BUTTON(tool->m_item), toggle ); gtk_toggle_button_set_state( GTK_TOGGLE_BUTTON(tool->m_item), toggle );
gtk_signal_connect( GTK_OBJECT(tool->m_item), "clicked",
GTK_SIGNAL_FUNC(gtk_toolbar_callback), (gpointer*)tool );
}
return; return;
} }
node = node->Next(); node = node->Next();

View File

@ -381,9 +381,32 @@ void wxToolBar::ToggleTool( int toolIndex, bool toggle )
wxToolBarTool *tool = (wxToolBarTool*)node->Data(); wxToolBarTool *tool = (wxToolBarTool*)node->Data();
if (tool->m_index == toolIndex) if (tool->m_index == toolIndex)
{ {
tool->m_toggleState = toggle;
if ((tool->m_item) && (GTK_IS_TOGGLE_BUTTON(tool->m_item))) if ((tool->m_item) && (GTK_IS_TOGGLE_BUTTON(tool->m_item)))
{
tool->m_toggleState = toggle;
if (tool->m_bitmap2.Ok())
{
wxBitmap bitmap = tool->m_bitmap1;
if (tool->m_toggleState) bitmap = tool->m_bitmap2;
GtkPixmap *pixmap = GTK_PIXMAP( tool->m_pixmap );
GdkBitmap *mask = (GdkBitmap *) NULL;
if (bitmap.GetMask()) mask = bitmap.GetMask()->GetBitmap();
gtk_pixmap_set( pixmap, bitmap.GetPixmap(), mask );
}
gtk_signal_disconnect_by_func( GTK_OBJECT(tool->m_item),
GTK_SIGNAL_FUNC(gtk_toolbar_callback), (gpointer*)tool );
gtk_toggle_button_set_state( GTK_TOGGLE_BUTTON(tool->m_item), toggle ); gtk_toggle_button_set_state( GTK_TOGGLE_BUTTON(tool->m_item), toggle );
gtk_signal_connect( GTK_OBJECT(tool->m_item), "clicked",
GTK_SIGNAL_FUNC(gtk_toolbar_callback), (gpointer*)tool );
}
return; return;
} }
node = node->Next(); node = node->Next();