Menu/toolbar event handling now tries the window with the focus first.
wxTextCtrl processes cut, copy, paste, undo, redo commands and UI updates automatically. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@2069 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -383,7 +383,15 @@ A menu bar is a series of menus accessible from the top of a frame.
|
|||||||
\wxheading{Event handling}
|
\wxheading{Event handling}
|
||||||
|
|
||||||
To respond to a menu selection, provide a handler for EVT\_MENU, in the frame
|
To respond to a menu selection, provide a handler for EVT\_MENU, in the frame
|
||||||
that contains the menu bar.
|
that contains the menu bar. If you have a toolbar which uses the same identifiers
|
||||||
|
as your EVT\_MENU entries, events from the toolbar will also be processed by your
|
||||||
|
EVT\_MENU event handlers.
|
||||||
|
|
||||||
|
Note that menu commands (and UI update events for menus) are first sent to
|
||||||
|
the focus window within the frame. If no window within the frame has the focus,
|
||||||
|
then the events are sent directly to the frame. This allows command and UI update
|
||||||
|
handling to be processed by specific windows and controls, and not necessarily
|
||||||
|
by the application frame.
|
||||||
|
|
||||||
\wxheading{See also}
|
\wxheading{See also}
|
||||||
|
|
||||||
|
@@ -134,7 +134,9 @@ recursively applied to the parent window's event handler. If this returns TRUE,
|
|||||||
|
|
||||||
Note that your application may wish to override ProcessEvent to redirect processing of
|
Note that your application may wish to override ProcessEvent to redirect processing of
|
||||||
events. This is done in the document/view framework, for example, to allow event handlers
|
events. This is done in the document/view framework, for example, to allow event handlers
|
||||||
to be defined in the document or view.
|
to be defined in the document or view. To test for command events (which will probably
|
||||||
|
be the only events you wish to redirect), you may use wxEvent::IsCommandEvent for
|
||||||
|
efficiency, instead of using the slower run-time type system.
|
||||||
|
|
||||||
As mentioned above, only command events are recursively applied to the parents event
|
As mentioned above, only command events are recursively applied to the parents event
|
||||||
handler. As this quite often causes confusion for users, here is a list of system
|
handler. As this quite often causes confusion for users, here is a list of system
|
||||||
@@ -164,7 +166,21 @@ In some cases, it might be desired by the programmer to get a certain number
|
|||||||
of system events in a parent window, for example all key events sent to, but not
|
of system events in a parent window, for example all key events sent to, but not
|
||||||
used by, the native controls in a dialog. In this case, a special event handler
|
used by, the native controls in a dialog. In this case, a special event handler
|
||||||
will have to be written that will override ProcessEvent() in order to pass
|
will have to be written that will override ProcessEvent() in order to pass
|
||||||
all events (or any selection of them) to the parent window. See next section.
|
all events (or any selection of them) to the parent window.
|
||||||
|
|
||||||
|
\subsection{Redirection of command events to the window with the focus}
|
||||||
|
|
||||||
|
The usual upward search through the window hierarchy for command event
|
||||||
|
handlers does not always meet an application's requirements. Say you have two
|
||||||
|
wxTextCtrl windows in a frame, plus a toolbar with Cut, Copy and Paste
|
||||||
|
buttons. To avoid the need to define event handlers in the frame
|
||||||
|
and redirect them explicitly to the window with the focus, command events
|
||||||
|
are sent to the window with the focus first, for
|
||||||
|
menu and toolbar command and UI update events only. This means that
|
||||||
|
each window can handle its own commands and UI updates independently. In
|
||||||
|
fact wxTextCtrl can handle Cut, Copy, Paste, Undo and Redo commands and UI update
|
||||||
|
requests, so no extra coding is required to support them in your menus and
|
||||||
|
toolbars.
|
||||||
|
|
||||||
\subsection{Pluggable event handlers}
|
\subsection{Pluggable event handlers}
|
||||||
|
|
||||||
|
@@ -52,6 +52,10 @@ wxTextCtrl header file.
|
|||||||
|
|
||||||
\wxheading{Event handling}
|
\wxheading{Event handling}
|
||||||
|
|
||||||
|
The following commands are processed by default event handlers in wxTextCtrl: wxID\_CUT, wxID\_COPY,
|
||||||
|
wxID\_PASTE, wxID\_UNDO, wxID\_REDO. The associated UI update events are also processed
|
||||||
|
automatically, when the control has the focus.
|
||||||
|
|
||||||
To process input from a text control, use these event handler macros to direct input to member
|
To process input from a text control, use these event handler macros to direct input to member
|
||||||
functions that take a \helpref{wxCommandEvent}{wxcommandevent} argument.
|
functions that take a \helpref{wxCommandEvent}{wxcommandevent} argument.
|
||||||
|
|
||||||
|
@@ -62,6 +62,13 @@ window is passed and the tool id is retrieved from the wxCommandEvent.
|
|||||||
This is because the id may be -1 when the mouse moves off a tool, and -1 is not
|
This is because the id may be -1 when the mouse moves off a tool, and -1 is not
|
||||||
allowed as an identifier in the event system.
|
allowed as an identifier in the event system.
|
||||||
|
|
||||||
|
Note that tool commands (and UI update events for tools) are first sent to
|
||||||
|
the focus window within the frame that contains the toolbar. If no window within the frame has the focus,
|
||||||
|
then the events are sent directly to the toolbar (and up the hierarchy to the
|
||||||
|
frame, depending on where the application has put its event handlers). This allows command and UI update
|
||||||
|
handling to be processed by specific windows and controls, and not necessarily
|
||||||
|
by the application frame.
|
||||||
|
|
||||||
\twocolwidtha{7cm}
|
\twocolwidtha{7cm}
|
||||||
\begin{twocollist}\itemsep=0pt
|
\begin{twocollist}\itemsep=0pt
|
||||||
\twocolitem{{\bf EVT\_TOOL(id, func)}}{Process a wxEVT\_COMMAND\_TOOL\_CLICKED event
|
\twocolitem{{\bf EVT\_TOOL(id, func)}}{Process a wxEVT\_COMMAND\_TOOL\_CLICKED event
|
||||||
|
@@ -13,8 +13,7 @@ Instead of supplying one toolbar class with a number
|
|||||||
of different implementations depending on platform, wxWindows separates
|
of different implementations depending on platform, wxWindows separates
|
||||||
out the classes. This is because there are a number of different toolbar
|
out the classes. This is because there are a number of different toolbar
|
||||||
styles that you may wish to use simultaneously, and also, future
|
styles that you may wish to use simultaneously, and also, future
|
||||||
toolbar implementations will emerge (for example, using the
|
toolbar implementations will emerge which
|
||||||
new-style Windows `coolbar' as seen in Microsoft applications) which
|
|
||||||
cannot all be shoe-horned into the one class.
|
cannot all be shoe-horned into the one class.
|
||||||
|
|
||||||
For each platform, the symbol {\bf wxToolBar} is defined to be one of the
|
For each platform, the symbol {\bf wxToolBar} is defined to be one of the
|
||||||
@@ -26,7 +25,7 @@ The following is a summary of the toolbar classes and their differences.
|
|||||||
\item {\bf wxToolBarBase.} This is a base class with pure virtual functions,
|
\item {\bf wxToolBarBase.} This is a base class with pure virtual functions,
|
||||||
and should not be used directly.
|
and should not be used directly.
|
||||||
\item {\bf wxToolBarSimple.} A simple toolbar class written entirely with generic wxWindows
|
\item {\bf wxToolBarSimple.} A simple toolbar class written entirely with generic wxWindows
|
||||||
functionality. A simply 3D effect for buttons is possible, but it is not consistent
|
functionality. A simple 3D effect for buttons is possible, but it is not consistent
|
||||||
with the Windows look and feel. This toolbar can scroll, and you can have arbitrary
|
with the Windows look and feel. This toolbar can scroll, and you can have arbitrary
|
||||||
numbers of rows and columns.
|
numbers of rows and columns.
|
||||||
\item {\bf wxToolBarMSW.} This class implements an old-style Windows toolbar, only on
|
\item {\bf wxToolBarMSW.} This class implements an old-style Windows toolbar, only on
|
||||||
@@ -39,7 +38,8 @@ CreateTools must be called after the tools have been added.
|
|||||||
No absolute positioning is supported but you can specify the number
|
No absolute positioning is supported but you can specify the number
|
||||||
of rows, and add tool separators with {\bf AddSeparator}.
|
of rows, and add tool separators with {\bf AddSeparator}.
|
||||||
Tooltips are supported. {\bf OnRightClick} is not supported. This is the default wxToolBar
|
Tooltips are supported. {\bf OnRightClick} is not supported. This is the default wxToolBar
|
||||||
on Windows 95, Windows NT 4 and above.
|
on Windows 95, Windows NT 4 and above. With the style wxTB\_FLAT, the flat toolbar
|
||||||
|
look is used, with a border that is highlit when the cursor moves over the buttons.
|
||||||
\end{itemize}
|
\end{itemize}
|
||||||
|
|
||||||
A toolbar might appear as a single row of images under
|
A toolbar might appear as a single row of images under
|
||||||
@@ -61,8 +61,6 @@ as the demo shows, before adding tools to the button bar. Don't supply more than
|
|||||||
one bitmap for each tool, because the toolbar generates all three images (normal,
|
one bitmap for each tool, because the toolbar generates all three images (normal,
|
||||||
depressed and checked) from the single bitmap you give it.
|
depressed and checked) from the single bitmap you give it.
|
||||||
|
|
||||||
To intercept
|
|
||||||
|
|
||||||
\subsection{Using the toolbar library}
|
\subsection{Using the toolbar library}
|
||||||
|
|
||||||
Include {\tt "wx/toolbar.h"}, or if using a class directly, one of:
|
Include {\tt "wx/toolbar.h"}, or if using a class directly, one of:
|
||||||
@@ -74,7 +72,9 @@ Include {\tt "wx/toolbar.h"}, or if using a class directly, one of:
|
|||||||
\end{itemize}
|
\end{itemize}
|
||||||
|
|
||||||
Example of toolbar use are given in the sample program ``toolbar''. The
|
Example of toolbar use are given in the sample program ``toolbar''. The
|
||||||
source is given below.
|
source is given below. In fact it's out of date because recommended
|
||||||
|
practise is to use event handlers (using EVT\_MENU or EVT\_TOOL) instead of
|
||||||
|
overriding OnLeftClick.
|
||||||
|
|
||||||
{\small
|
{\small
|
||||||
\begin{verbatim}
|
\begin{verbatim}
|
||||||
|
@@ -1427,5 +1427,13 @@ const wxEventTableEntry theClass::sm_eventTableEntries[] = { \
|
|||||||
#define EVT_UPDATE_UI(id, func) \
|
#define EVT_UPDATE_UI(id, func) \
|
||||||
{ wxEVT_UPDATE_UI, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxUpdateUIEventFunction) & func, (wxObject *) NULL },\
|
{ wxEVT_UPDATE_UI, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxUpdateUIEventFunction) & func, (wxObject *) NULL },\
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Helper functions
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Find a window with the focus, that is also a descendant of the given window.
|
||||||
|
// This is used to determine the window to initially send commands to.
|
||||||
|
wxWindow* wxFindFocusDescendant(wxWindow* ancestor);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// _WX_EVENTH__
|
// _WX_EVENTH__
|
||||||
|
@@ -105,7 +105,7 @@ public:
|
|||||||
virtual void GtkOnSize( int x, int y, int width, int height );
|
virtual void GtkOnSize( int x, int y, int width, int height );
|
||||||
virtual wxPoint GetClientAreaOrigin() const;
|
virtual wxPoint GetClientAreaOrigin() const;
|
||||||
void DoMenuUpdates();
|
void DoMenuUpdates();
|
||||||
void DoMenuUpdates(wxMenu* menu);
|
void DoMenuUpdates(wxMenu* menu, wxWindow* focusWin);
|
||||||
virtual void OnInternalIdle();
|
virtual void OnInternalIdle();
|
||||||
|
|
||||||
wxMenuBar *m_frameMenuBar;
|
wxMenuBar *m_frameMenuBar;
|
||||||
|
@@ -118,6 +118,18 @@ class wxTextCtrl: public wxControl
|
|||||||
|
|
||||||
void OnChar( wxKeyEvent &event );
|
void OnChar( wxKeyEvent &event );
|
||||||
|
|
||||||
|
void OnCut(wxCommandEvent& event);
|
||||||
|
void OnCopy(wxCommandEvent& event);
|
||||||
|
void OnPaste(wxCommandEvent& event);
|
||||||
|
void OnUndo(wxCommandEvent& event);
|
||||||
|
void OnRedo(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnUpdateCut(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateCopy(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdatePaste(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateUndo(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateRedo(wxUpdateUIEvent& event);
|
||||||
|
|
||||||
#ifndef NO_TEXT_WINDOW_STREAM
|
#ifndef NO_TEXT_WINDOW_STREAM
|
||||||
int overflow(int i);
|
int overflow(int i);
|
||||||
int sync();
|
int sync();
|
||||||
|
@@ -105,7 +105,7 @@ public:
|
|||||||
virtual void GtkOnSize( int x, int y, int width, int height );
|
virtual void GtkOnSize( int x, int y, int width, int height );
|
||||||
virtual wxPoint GetClientAreaOrigin() const;
|
virtual wxPoint GetClientAreaOrigin() const;
|
||||||
void DoMenuUpdates();
|
void DoMenuUpdates();
|
||||||
void DoMenuUpdates(wxMenu* menu);
|
void DoMenuUpdates(wxMenu* menu, wxWindow* focusWin);
|
||||||
virtual void OnInternalIdle();
|
virtual void OnInternalIdle();
|
||||||
|
|
||||||
wxMenuBar *m_frameMenuBar;
|
wxMenuBar *m_frameMenuBar;
|
||||||
|
@@ -118,6 +118,18 @@ class wxTextCtrl: public wxControl
|
|||||||
|
|
||||||
void OnChar( wxKeyEvent &event );
|
void OnChar( wxKeyEvent &event );
|
||||||
|
|
||||||
|
void OnCut(wxCommandEvent& event);
|
||||||
|
void OnCopy(wxCommandEvent& event);
|
||||||
|
void OnPaste(wxCommandEvent& event);
|
||||||
|
void OnUndo(wxCommandEvent& event);
|
||||||
|
void OnRedo(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnUpdateCut(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateCopy(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdatePaste(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateUndo(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateRedo(wxUpdateUIEvent& event);
|
||||||
|
|
||||||
#ifndef NO_TEXT_WINDOW_STREAM
|
#ifndef NO_TEXT_WINDOW_STREAM
|
||||||
int overflow(int i);
|
int overflow(int i);
|
||||||
int sync();
|
int sync();
|
||||||
|
@@ -136,7 +136,7 @@ public:
|
|||||||
|
|
||||||
// Query app for menu item updates (called from OnIdle)
|
// Query app for menu item updates (called from OnIdle)
|
||||||
void DoMenuUpdates();
|
void DoMenuUpdates();
|
||||||
void DoMenuUpdates(wxMenu* menu);
|
void DoMenuUpdates(wxMenu* menu, wxWindow* focusWin);
|
||||||
|
|
||||||
// Checks if there is a toolbar, and returns the first free client position
|
// Checks if there is a toolbar, and returns the first free client position
|
||||||
virtual wxPoint GetClientAreaOrigin() const;
|
virtual wxPoint GetClientAreaOrigin() const;
|
||||||
|
@@ -145,7 +145,7 @@ public:
|
|||||||
|
|
||||||
// Query app for menu item updates (called from OnIdle)
|
// Query app for menu item updates (called from OnIdle)
|
||||||
void DoMenuUpdates();
|
void DoMenuUpdates();
|
||||||
void DoMenuUpdates(wxMenu* menu);
|
void DoMenuUpdates(wxMenu* menu, wxWindow* focusWin);
|
||||||
|
|
||||||
// Checks if there is a toolbar, and returns the first free client position
|
// Checks if there is a toolbar, and returns the first free client position
|
||||||
virtual wxPoint GetClientAreaOrigin() const;
|
virtual wxPoint GetClientAreaOrigin() const;
|
||||||
|
@@ -16,8 +16,8 @@
|
|||||||
#pragma interface "textctrl.h"
|
#pragma interface "textctrl.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/ioswrap.h"
|
|
||||||
#include "wx/control.h"
|
#include "wx/control.h"
|
||||||
|
#include "wx/ioswrap.h"
|
||||||
|
|
||||||
// TODO Some platforms/compilers don't like inheritance from streambuf.
|
// TODO Some platforms/compilers don't like inheritance from streambuf.
|
||||||
#if (defined(__BORLANDC__) && !defined(__WIN32__)) || defined(__MWERKS__)
|
#if (defined(__BORLANDC__) && !defined(__WIN32__)) || defined(__MWERKS__)
|
||||||
@@ -133,6 +133,18 @@ public:
|
|||||||
void OnChar(wxKeyEvent& event);
|
void OnChar(wxKeyEvent& event);
|
||||||
// void OnEraseBackground(wxEraseEvent& event);
|
// void OnEraseBackground(wxEraseEvent& event);
|
||||||
|
|
||||||
|
void OnCut(wxCommandEvent& event);
|
||||||
|
void OnCopy(wxCommandEvent& event);
|
||||||
|
void OnPaste(wxCommandEvent& event);
|
||||||
|
void OnUndo(wxCommandEvent& event);
|
||||||
|
void OnRedo(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnUpdateCut(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateCopy(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdatePaste(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateUndo(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateRedo(wxUpdateUIEvent& event);
|
||||||
|
|
||||||
virtual void Command(wxCommandEvent& event);
|
virtual void Command(wxCommandEvent& event);
|
||||||
|
|
||||||
// implementation from here to the end
|
// implementation from here to the end
|
||||||
|
@@ -153,7 +153,7 @@ public:
|
|||||||
|
|
||||||
// Query app for menu item updates (called from OnIdle)
|
// Query app for menu item updates (called from OnIdle)
|
||||||
void DoMenuUpdates();
|
void DoMenuUpdates();
|
||||||
void DoMenuUpdates(wxMenu* menu);
|
void DoMenuUpdates(wxMenu* menu, wxWindow* focusWin);
|
||||||
|
|
||||||
WXHMENU GetWinMenu() const ;
|
WXHMENU GetWinMenu() const ;
|
||||||
|
|
||||||
|
@@ -154,6 +154,18 @@ public:
|
|||||||
void OnChar(wxKeyEvent& event); // Process 'enter' if required
|
void OnChar(wxKeyEvent& event); // Process 'enter' if required
|
||||||
void OnEraseBackground(wxEraseEvent& event);
|
void OnEraseBackground(wxEraseEvent& event);
|
||||||
|
|
||||||
|
void OnCut(wxCommandEvent& event);
|
||||||
|
void OnCopy(wxCommandEvent& event);
|
||||||
|
void OnPaste(wxCommandEvent& event);
|
||||||
|
void OnUndo(wxCommandEvent& event);
|
||||||
|
void OnRedo(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnUpdateCut(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateCopy(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdatePaste(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateUndo(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateRedo(wxUpdateUIEvent& event);
|
||||||
|
|
||||||
// Implementation
|
// Implementation
|
||||||
// --------------
|
// --------------
|
||||||
virtual void Command(wxCommandEvent& event);
|
virtual void Command(wxCommandEvent& event);
|
||||||
|
@@ -136,7 +136,7 @@ public:
|
|||||||
|
|
||||||
// Query app for menu item updates (called from OnIdle)
|
// Query app for menu item updates (called from OnIdle)
|
||||||
void DoMenuUpdates();
|
void DoMenuUpdates();
|
||||||
void DoMenuUpdates(wxMenu* menu);
|
void DoMenuUpdates(wxMenu* menu, wxWindow* focusWin);
|
||||||
|
|
||||||
// Checks if there is a toolbar, and returns the first free client position
|
// Checks if there is a toolbar, and returns the first free client position
|
||||||
virtual wxPoint GetClientAreaOrigin() const;
|
virtual wxPoint GetClientAreaOrigin() const;
|
||||||
|
@@ -141,7 +141,18 @@ public:
|
|||||||
void OnDropFiles(wxDropFilesEvent& event);
|
void OnDropFiles(wxDropFilesEvent& event);
|
||||||
// void OnChar(wxKeyEvent& event); // Process 'enter' if required
|
// void OnChar(wxKeyEvent& event); // Process 'enter' if required
|
||||||
// void OnEraseBackground(wxEraseEvent& event);
|
// void OnEraseBackground(wxEraseEvent& event);
|
||||||
|
void OnCut(wxCommandEvent& event);
|
||||||
|
void OnCopy(wxCommandEvent& event);
|
||||||
|
void OnPaste(wxCommandEvent& event);
|
||||||
|
void OnUndo(wxCommandEvent& event);
|
||||||
|
void OnRedo(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnUpdateCut(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateCopy(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdatePaste(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateUndo(wxUpdateUIEvent& event);
|
||||||
|
void OnUpdateRedo(wxUpdateUIEvent& event);
|
||||||
|
|
||||||
// Implementation
|
// Implementation
|
||||||
// --------------
|
// --------------
|
||||||
virtual void Command(wxCommandEvent& event);
|
virtual void Command(wxCommandEvent& event);
|
||||||
|
@@ -555,3 +555,26 @@ bool wxEvtHandler::OnClose()
|
|||||||
}
|
}
|
||||||
#endif // WXWIN_COMPATIBILITY
|
#endif // WXWIN_COMPATIBILITY
|
||||||
|
|
||||||
|
// Find a window with the focus, that is also a descendant of the given window.
|
||||||
|
// This is used to determine the window to initially send commands to.
|
||||||
|
wxWindow* wxFindFocusDescendant(wxWindow* ancestor)
|
||||||
|
{
|
||||||
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxWindow::FindFocus();
|
||||||
|
wxWindow* win = focusWin;
|
||||||
|
|
||||||
|
// Check if this is a descendant of this frame.
|
||||||
|
// If not, win will be set to NULL.
|
||||||
|
while (win)
|
||||||
|
{
|
||||||
|
if (win == ancestor)
|
||||||
|
break;
|
||||||
|
else
|
||||||
|
win = win->GetParent();
|
||||||
|
}
|
||||||
|
if (win == (wxWindow*) NULL)
|
||||||
|
focusWin = (wxWindow*) NULL;
|
||||||
|
|
||||||
|
return focusWin;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -30,16 +30,21 @@ void wxFrame::OnIdle(wxIdleEvent& WXUNUSED(event) )
|
|||||||
void wxFrame::DoMenuUpdates()
|
void wxFrame::DoMenuUpdates()
|
||||||
{
|
{
|
||||||
wxMenuBar* bar = GetMenuBar();
|
wxMenuBar* bar = GetMenuBar();
|
||||||
|
|
||||||
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxFindFocusDescendant(this);
|
||||||
|
|
||||||
if ( bar != NULL ) {
|
if ( bar != NULL ) {
|
||||||
int nCount = bar->GetMenuCount();
|
int nCount = bar->GetMenuCount();
|
||||||
for (int n = 0; n < nCount; n++)
|
for (int n = 0; n < nCount; n++)
|
||||||
DoMenuUpdates(bar->GetMenu(n));
|
DoMenuUpdates(bar->GetMenu(n), focusWin);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// update a menu and all submenus recursively
|
// update a menu and all submenus recursively
|
||||||
void wxFrame::DoMenuUpdates(wxMenu* menu)
|
void wxFrame::DoMenuUpdates(wxMenu* menu, wxWindow* focusWin)
|
||||||
{
|
{
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler();
|
||||||
wxNode* node = menu->GetItems().First();
|
wxNode* node = menu->GetItems().First();
|
||||||
while (node)
|
while (node)
|
||||||
{
|
{
|
||||||
@@ -50,7 +55,7 @@ void wxFrame::DoMenuUpdates(wxMenu* menu)
|
|||||||
wxUpdateUIEvent event(id);
|
wxUpdateUIEvent event(id);
|
||||||
event.SetEventObject( this );
|
event.SetEventObject( this );
|
||||||
|
|
||||||
if (GetEventHandler()->ProcessEvent(event))
|
if (evtHandler->ProcessEvent(event))
|
||||||
{
|
{
|
||||||
if (event.GetSetText())
|
if (event.GetSetText())
|
||||||
menu->SetLabel(id, event.GetText());
|
menu->SetLabel(id, event.GetText());
|
||||||
@@ -61,7 +66,7 @@ void wxFrame::DoMenuUpdates(wxMenu* menu)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (item->GetSubMenu())
|
if (item->GetSubMenu())
|
||||||
DoMenuUpdates(item->GetSubMenu());
|
DoMenuUpdates(item->GetSubMenu(), focusWin);
|
||||||
}
|
}
|
||||||
node = node->Next();
|
node = node->Next();
|
||||||
}
|
}
|
||||||
|
@@ -24,6 +24,8 @@
|
|||||||
#include "wx/wx.h"
|
#include "wx/wx.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "wx/frame.h"
|
||||||
|
|
||||||
// For ::UpdateWindow
|
// For ::UpdateWindow
|
||||||
#ifdef __WXMSW__
|
#ifdef __WXMSW__
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
@@ -147,6 +149,29 @@ bool wxToolBarBase::OnLeftClick(int toolIndex, bool toggleDown)
|
|||||||
event.SetEventObject(this);
|
event.SetEventObject(this);
|
||||||
event.SetExtraLong((long) toggleDown);
|
event.SetExtraLong((long) toggleDown);
|
||||||
|
|
||||||
|
// First try sending the command to a window that has the focus, within a frame that
|
||||||
|
// also contains this toolbar.
|
||||||
|
wxFrame* frame = (wxFrame*) NULL;
|
||||||
|
wxWindow* win = this;
|
||||||
|
wxWindow* focusWin = (wxWindow*) NULL;
|
||||||
|
|
||||||
|
while (win)
|
||||||
|
{
|
||||||
|
if (win->IsKindOf(CLASSINFO(wxFrame)))
|
||||||
|
{
|
||||||
|
frame = (wxFrame*) win;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
win = win->GetParent();
|
||||||
|
}
|
||||||
|
if (frame)
|
||||||
|
focusWin = wxFindFocusDescendant(frame);
|
||||||
|
|
||||||
|
if (focusWin && focusWin->GetEventHandler()->ProcessEvent(event))
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
// Send events to this toolbar instead (and thence up the window hierarchy)
|
||||||
GetEventHandler()->ProcessEvent(event);
|
GetEventHandler()->ProcessEvent(event);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@@ -732,6 +757,28 @@ void wxToolBarBase::OnIdle(wxIdleEvent& event)
|
|||||||
// Do the toolbar button updates (check for EVT_UPDATE_UI handlers)
|
// Do the toolbar button updates (check for EVT_UPDATE_UI handlers)
|
||||||
void wxToolBarBase::DoToolbarUpdates()
|
void wxToolBarBase::DoToolbarUpdates()
|
||||||
{
|
{
|
||||||
|
// First try sending the command to a window that has the focus, within a frame that
|
||||||
|
// also contains this toolbar.
|
||||||
|
wxFrame* frame = (wxFrame*) NULL;
|
||||||
|
wxWindow* win = this;
|
||||||
|
wxWindow* focusWin = (wxWindow*) NULL;
|
||||||
|
|
||||||
|
while (win)
|
||||||
|
{
|
||||||
|
if (win->IsKindOf(CLASSINFO(wxFrame)))
|
||||||
|
{
|
||||||
|
frame = (wxFrame*) win;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
win = win->GetParent();
|
||||||
|
}
|
||||||
|
if (frame)
|
||||||
|
focusWin = wxFindFocusDescendant(frame);
|
||||||
|
|
||||||
|
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler() ;
|
||||||
|
|
||||||
wxNode* node = GetTools().First();
|
wxNode* node = GetTools().First();
|
||||||
while (node)
|
while (node)
|
||||||
{
|
{
|
||||||
@@ -740,7 +787,7 @@ void wxToolBarBase::DoToolbarUpdates()
|
|||||||
wxUpdateUIEvent event(tool->m_index);
|
wxUpdateUIEvent event(tool->m_index);
|
||||||
event.SetEventObject(this);
|
event.SetEventObject(this);
|
||||||
|
|
||||||
if (GetEventHandler()->ProcessEvent(event))
|
if (evtHandler->ProcessEvent(event))
|
||||||
{
|
{
|
||||||
if (event.GetSetEnabled())
|
if (event.GetSetEnabled())
|
||||||
EnableTool(tool->m_index, event.GetEnabled());
|
EnableTool(tool->m_index, event.GetEnabled());
|
||||||
|
@@ -28,6 +28,7 @@ LIB_CPP_SRC=\
|
|||||||
common/image.cpp \
|
common/image.cpp \
|
||||||
common/imagjpeg.cpp \
|
common/imagjpeg.cpp \
|
||||||
common/imagpng.cpp \
|
common/imagpng.cpp \
|
||||||
|
common/imaggif.cpp \
|
||||||
common/ipcbase.cpp \
|
common/ipcbase.cpp \
|
||||||
common/layout.cpp \
|
common/layout.cpp \
|
||||||
common/list.cpp \
|
common/list.cpp \
|
||||||
|
@@ -654,7 +654,13 @@ void wxFrame::Command( int id )
|
|||||||
{
|
{
|
||||||
bar->Check(id,!bar->Checked(id)) ;
|
bar->Check(id,!bar->Checked(id)) ;
|
||||||
}
|
}
|
||||||
GetEventHandler()->ProcessEvent(commandEvent);
|
|
||||||
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxFindFocusDescendant(this);
|
||||||
|
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler();
|
||||||
|
|
||||||
|
evtHandler->ProcessEvent(commandEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxFrame::SetStatusText(const wxString& text, int number)
|
void wxFrame::SetStatusText(const wxString& text, int number)
|
||||||
|
@@ -12,6 +12,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/toolbar.h"
|
#include "wx/toolbar.h"
|
||||||
|
#include "wx/frame.h"
|
||||||
|
|
||||||
#include "glib.h"
|
#include "glib.h"
|
||||||
#include "gdk/gdk.h"
|
#include "gdk/gdk.h"
|
||||||
@@ -168,6 +169,28 @@ bool wxToolBar::OnLeftClick( int toolIndex, bool toggleDown )
|
|||||||
event.SetInt( toolIndex );
|
event.SetInt( toolIndex );
|
||||||
event.SetExtraLong((long) toggleDown);
|
event.SetExtraLong((long) toggleDown);
|
||||||
|
|
||||||
|
// First try sending the command to a window that has the focus, within a frame that
|
||||||
|
// also contains this toolbar.
|
||||||
|
wxFrame* frame = (wxFrame*) NULL;
|
||||||
|
wxWindow* win = this;
|
||||||
|
wxWindow* focusWin = (wxWindow*) NULL;
|
||||||
|
|
||||||
|
while (win)
|
||||||
|
{
|
||||||
|
if (win->IsKindOf(CLASSINFO(wxFrame)))
|
||||||
|
{
|
||||||
|
frame = (wxFrame*) win;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
win = win->GetParent();
|
||||||
|
}
|
||||||
|
if (frame)
|
||||||
|
focusWin = wxFindFocusDescendant(frame);
|
||||||
|
|
||||||
|
if (focusWin && focusWin->GetEventHandler()->ProcessEvent(event))
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
GetEventHandler()->ProcessEvent(event);
|
GetEventHandler()->ProcessEvent(event);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@@ -65,6 +65,18 @@ IMPLEMENT_DYNAMIC_CLASS(wxTextCtrl,wxControl)
|
|||||||
|
|
||||||
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
||||||
EVT_CHAR(wxTextCtrl::OnChar)
|
EVT_CHAR(wxTextCtrl::OnChar)
|
||||||
|
|
||||||
|
EVT_MENU(wxID_CUT, wxTextCtrl::OnCut)
|
||||||
|
EVT_MENU(wxID_COPY, wxTextCtrl::OnCopy)
|
||||||
|
EVT_MENU(wxID_PASTE, wxTextCtrl::OnPaste)
|
||||||
|
EVT_MENU(wxID_UNDO, wxTextCtrl::OnUndo)
|
||||||
|
EVT_MENU(wxID_REDO, wxTextCtrl::OnRedo)
|
||||||
|
|
||||||
|
EVT_UPDATE_UI(wxID_CUT, wxTextCtrl::OnUpdateCut)
|
||||||
|
EVT_UPDATE_UI(wxID_COPY, wxTextCtrl::OnUpdateCopy)
|
||||||
|
EVT_UPDATE_UI(wxID_PASTE, wxTextCtrl::OnUpdatePaste)
|
||||||
|
EVT_UPDATE_UI(wxID_UNDO, wxTextCtrl::OnUpdateUndo)
|
||||||
|
EVT_UPDATE_UI(wxID_REDO, wxTextCtrl::OnUpdateRedo)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
#ifndef NO_TEXT_WINDOW_STREAM
|
#ifndef NO_TEXT_WINDOW_STREAM
|
||||||
@@ -931,3 +943,52 @@ void wxTextCtrl::ApplyWidgetStyle()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCut(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Cut();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCopy(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Copy();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnPaste(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Paste();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUndo(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Undo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnRedo(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Redo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCut(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCut() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCopy(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCopy() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdatePaste(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanPaste() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateUndo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanUndo() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateRedo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanRedo() );
|
||||||
|
}
|
||||||
|
@@ -654,7 +654,13 @@ void wxFrame::Command( int id )
|
|||||||
{
|
{
|
||||||
bar->Check(id,!bar->Checked(id)) ;
|
bar->Check(id,!bar->Checked(id)) ;
|
||||||
}
|
}
|
||||||
GetEventHandler()->ProcessEvent(commandEvent);
|
|
||||||
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxFindFocusDescendant(this);
|
||||||
|
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler();
|
||||||
|
|
||||||
|
evtHandler->ProcessEvent(commandEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxFrame::SetStatusText(const wxString& text, int number)
|
void wxFrame::SetStatusText(const wxString& text, int number)
|
||||||
|
@@ -12,6 +12,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/toolbar.h"
|
#include "wx/toolbar.h"
|
||||||
|
#include "wx/frame.h"
|
||||||
|
|
||||||
#include "glib.h"
|
#include "glib.h"
|
||||||
#include "gdk/gdk.h"
|
#include "gdk/gdk.h"
|
||||||
@@ -168,6 +169,28 @@ bool wxToolBar::OnLeftClick( int toolIndex, bool toggleDown )
|
|||||||
event.SetInt( toolIndex );
|
event.SetInt( toolIndex );
|
||||||
event.SetExtraLong((long) toggleDown);
|
event.SetExtraLong((long) toggleDown);
|
||||||
|
|
||||||
|
// First try sending the command to a window that has the focus, within a frame that
|
||||||
|
// also contains this toolbar.
|
||||||
|
wxFrame* frame = (wxFrame*) NULL;
|
||||||
|
wxWindow* win = this;
|
||||||
|
wxWindow* focusWin = (wxWindow*) NULL;
|
||||||
|
|
||||||
|
while (win)
|
||||||
|
{
|
||||||
|
if (win->IsKindOf(CLASSINFO(wxFrame)))
|
||||||
|
{
|
||||||
|
frame = (wxFrame*) win;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
win = win->GetParent();
|
||||||
|
}
|
||||||
|
if (frame)
|
||||||
|
focusWin = wxFindFocusDescendant(frame);
|
||||||
|
|
||||||
|
if (focusWin && focusWin->GetEventHandler()->ProcessEvent(event))
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
GetEventHandler()->ProcessEvent(event);
|
GetEventHandler()->ProcessEvent(event);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@@ -65,6 +65,18 @@ IMPLEMENT_DYNAMIC_CLASS(wxTextCtrl,wxControl)
|
|||||||
|
|
||||||
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
||||||
EVT_CHAR(wxTextCtrl::OnChar)
|
EVT_CHAR(wxTextCtrl::OnChar)
|
||||||
|
|
||||||
|
EVT_MENU(wxID_CUT, wxTextCtrl::OnCut)
|
||||||
|
EVT_MENU(wxID_COPY, wxTextCtrl::OnCopy)
|
||||||
|
EVT_MENU(wxID_PASTE, wxTextCtrl::OnPaste)
|
||||||
|
EVT_MENU(wxID_UNDO, wxTextCtrl::OnUndo)
|
||||||
|
EVT_MENU(wxID_REDO, wxTextCtrl::OnRedo)
|
||||||
|
|
||||||
|
EVT_UPDATE_UI(wxID_CUT, wxTextCtrl::OnUpdateCut)
|
||||||
|
EVT_UPDATE_UI(wxID_COPY, wxTextCtrl::OnUpdateCopy)
|
||||||
|
EVT_UPDATE_UI(wxID_PASTE, wxTextCtrl::OnUpdatePaste)
|
||||||
|
EVT_UPDATE_UI(wxID_UNDO, wxTextCtrl::OnUpdateUndo)
|
||||||
|
EVT_UPDATE_UI(wxID_REDO, wxTextCtrl::OnUpdateRedo)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
#ifndef NO_TEXT_WINDOW_STREAM
|
#ifndef NO_TEXT_WINDOW_STREAM
|
||||||
@@ -931,3 +943,52 @@ void wxTextCtrl::ApplyWidgetStyle()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCut(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Cut();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCopy(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Copy();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnPaste(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Paste();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUndo(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Undo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnRedo(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Redo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCut(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCut() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCopy(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCopy() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdatePaste(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanPaste() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateUndo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanUndo() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateRedo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanRedo() );
|
||||||
|
}
|
||||||
|
@@ -450,7 +450,12 @@ void wxFrame::ProcessCommand(int id)
|
|||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
GetEventHandler()->ProcessEvent(commandEvent);
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxFindFocusDescendant(this);
|
||||||
|
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler();
|
||||||
|
|
||||||
|
evtHandler->ProcessEvent(commandEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Checks if there is a toolbar, and returns the first free client position
|
// Checks if there is a toolbar, and returns the first free client position
|
||||||
|
@@ -450,7 +450,12 @@ void wxFrame::ProcessCommand(int id)
|
|||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
GetEventHandler()->ProcessEvent(commandEvent);
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxFindFocusDescendant(this);
|
||||||
|
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler();
|
||||||
|
|
||||||
|
evtHandler->ProcessEvent(commandEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Checks if there is a toolbar, and returns the first free client position
|
// Checks if there is a toolbar, and returns the first free client position
|
||||||
|
@@ -27,6 +27,7 @@ LIB_CPP_SRC=\
|
|||||||
common/image.cpp \
|
common/image.cpp \
|
||||||
common/imagjpeg.cpp \
|
common/imagjpeg.cpp \
|
||||||
common/imagpng.cpp \
|
common/imagpng.cpp \
|
||||||
|
common/imaggif.cpp \
|
||||||
common/intl.cpp \
|
common/intl.cpp \
|
||||||
common/ipcbase.cpp \
|
common/ipcbase.cpp \
|
||||||
common/layout.cpp \
|
common/layout.cpp \
|
||||||
|
@@ -869,7 +869,12 @@ void wxFrame::ProcessCommand(int id)
|
|||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
GetEventHandler()->ProcessEvent(commandEvent);
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxFindFocusDescendant(this);
|
||||||
|
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler();
|
||||||
|
|
||||||
|
evtHandler->ProcessEvent(commandEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Checks if there is a toolbar, and returns the first free client position
|
// Checks if there is a toolbar, and returns the first free client position
|
||||||
|
@@ -33,6 +33,7 @@ LIB_CPP_SRC=\
|
|||||||
../common/image.cpp \
|
../common/image.cpp \
|
||||||
../common/imagjpeg.cpp \
|
../common/imagjpeg.cpp \
|
||||||
../common/imagpng.cpp \
|
../common/imagpng.cpp \
|
||||||
|
../common/imaggif.cpp \
|
||||||
../common/layout.cpp \
|
../common/layout.cpp \
|
||||||
../common/list.cpp \
|
../common/list.cpp \
|
||||||
../common/log.cpp \
|
../common/log.cpp \
|
||||||
|
@@ -57,6 +57,19 @@ static void wxTextWindowActivateProc(Widget w, XtPointer clientData, XmAnyCallba
|
|||||||
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
||||||
EVT_DROP_FILES(wxTextCtrl::OnDropFiles)
|
EVT_DROP_FILES(wxTextCtrl::OnDropFiles)
|
||||||
EVT_CHAR(wxTextCtrl::OnChar)
|
EVT_CHAR(wxTextCtrl::OnChar)
|
||||||
|
|
||||||
|
EVT_MENU(wxID_CUT, wxTextCtrl::OnCut)
|
||||||
|
EVT_MENU(wxID_COPY, wxTextCtrl::OnCopy)
|
||||||
|
EVT_MENU(wxID_PASTE, wxTextCtrl::OnPaste)
|
||||||
|
EVT_MENU(wxID_UNDO, wxTextCtrl::OnUndo)
|
||||||
|
EVT_MENU(wxID_REDO, wxTextCtrl::OnRedo)
|
||||||
|
|
||||||
|
EVT_UPDATE_UI(wxID_CUT, wxTextCtrl::OnUpdateCut)
|
||||||
|
EVT_UPDATE_UI(wxID_COPY, wxTextCtrl::OnUpdateCopy)
|
||||||
|
EVT_UPDATE_UI(wxID_PASTE, wxTextCtrl::OnUpdatePaste)
|
||||||
|
EVT_UPDATE_UI(wxID_UNDO, wxTextCtrl::OnUpdateUndo)
|
||||||
|
EVT_UPDATE_UI(wxID_REDO, wxTextCtrl::OnUpdateRedo)
|
||||||
|
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -995,3 +1008,52 @@ static void wxTextWindowActivateProc(Widget w, XtPointer clientData,
|
|||||||
tw->ProcessCommand(event);
|
tw->ProcessCommand(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCut(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Cut();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCopy(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Copy();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnPaste(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Paste();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUndo(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Undo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnRedo(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Redo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCut(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCut() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCopy(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCopy() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdatePaste(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanPaste() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateUndo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanUndo() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateRedo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanRedo() );
|
||||||
|
}
|
||||||
|
@@ -916,7 +916,12 @@ void wxFrame::ProcessCommand(int id)
|
|||||||
{
|
{
|
||||||
bar->Check(id,!bar->Checked(id)) ;
|
bar->Check(id,!bar->Checked(id)) ;
|
||||||
}
|
}
|
||||||
GetEventHandler()->ProcessEvent(commandEvent);
|
|
||||||
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxFindFocusDescendant(this);
|
||||||
|
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler();
|
||||||
|
evtHandler->ProcessEvent(commandEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Checks if there is a toolbar, and returns the first free client position
|
// Checks if there is a toolbar, and returns the first free client position
|
||||||
|
@@ -114,6 +114,7 @@ COMMONOBJS = \
|
|||||||
..\common\$D\image.obj \
|
..\common\$D\image.obj \
|
||||||
..\common\$D\imagjpeg.obj \
|
..\common\$D\imagjpeg.obj \
|
||||||
..\common\$D\imagpng.obj \
|
..\common\$D\imagpng.obj \
|
||||||
|
..\common\$D\imaggif.obj \
|
||||||
..\common\$D\intl.obj \
|
..\common\$D\intl.obj \
|
||||||
..\common\$D\ipcbase.obj \
|
..\common\$D\ipcbase.obj \
|
||||||
..\common\$D\helpbase.obj \
|
..\common\$D\helpbase.obj \
|
||||||
|
@@ -68,13 +68,27 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !USE_SHARED_LIBRARY
|
#if !USE_SHARED_LIBRARY
|
||||||
|
|
||||||
IMPLEMENT_DYNAMIC_CLASS(wxTextCtrl, wxControl)
|
IMPLEMENT_DYNAMIC_CLASS(wxTextCtrl, wxControl)
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
||||||
EVT_CHAR(wxTextCtrl::OnChar)
|
EVT_CHAR(wxTextCtrl::OnChar)
|
||||||
EVT_DROP_FILES(wxTextCtrl::OnDropFiles)
|
EVT_DROP_FILES(wxTextCtrl::OnDropFiles)
|
||||||
EVT_ERASE_BACKGROUND(wxTextCtrl::OnEraseBackground)
|
EVT_ERASE_BACKGROUND(wxTextCtrl::OnEraseBackground)
|
||||||
|
|
||||||
|
EVT_MENU(wxID_CUT, wxTextCtrl::OnCut)
|
||||||
|
EVT_MENU(wxID_COPY, wxTextCtrl::OnCopy)
|
||||||
|
EVT_MENU(wxID_PASTE, wxTextCtrl::OnPaste)
|
||||||
|
EVT_MENU(wxID_UNDO, wxTextCtrl::OnUndo)
|
||||||
|
EVT_MENU(wxID_REDO, wxTextCtrl::OnRedo)
|
||||||
|
|
||||||
|
EVT_UPDATE_UI(wxID_CUT, wxTextCtrl::OnUpdateCut)
|
||||||
|
EVT_UPDATE_UI(wxID_COPY, wxTextCtrl::OnUpdateCopy)
|
||||||
|
EVT_UPDATE_UI(wxID_PASTE, wxTextCtrl::OnUpdatePaste)
|
||||||
|
EVT_UPDATE_UI(wxID_UNDO, wxTextCtrl::OnUpdateUndo)
|
||||||
|
EVT_UPDATE_UI(wxID_REDO, wxTextCtrl::OnUpdateRedo)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
#endif // USE_SHARED_LIBRARY
|
#endif // USE_SHARED_LIBRARY
|
||||||
|
|
||||||
// Text item
|
// Text item
|
||||||
@@ -363,20 +377,29 @@ void wxTextCtrl::DoSetSize(int x, int y, int width, int height, int sizeFlags)
|
|||||||
// Clipboard operations
|
// Clipboard operations
|
||||||
void wxTextCtrl::Copy()
|
void wxTextCtrl::Copy()
|
||||||
{
|
{
|
||||||
HWND hWnd = (HWND) GetHWND();
|
if (CanCopy())
|
||||||
SendMessage(hWnd, WM_COPY, 0, 0L);
|
{
|
||||||
|
HWND hWnd = (HWND) GetHWND();
|
||||||
|
SendMessage(hWnd, WM_COPY, 0, 0L);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxTextCtrl::Cut()
|
void wxTextCtrl::Cut()
|
||||||
{
|
{
|
||||||
HWND hWnd = (HWND) GetHWND();
|
if (CanCut())
|
||||||
SendMessage(hWnd, WM_CUT, 0, 0L);
|
{
|
||||||
|
HWND hWnd = (HWND) GetHWND();
|
||||||
|
SendMessage(hWnd, WM_CUT, 0, 0L);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxTextCtrl::Paste()
|
void wxTextCtrl::Paste()
|
||||||
{
|
{
|
||||||
HWND hWnd = (HWND) GetHWND();
|
if (CanPaste())
|
||||||
SendMessage(hWnd, WM_PASTE, 0, 0L);
|
{
|
||||||
|
HWND hWnd = (HWND) GetHWND();
|
||||||
|
SendMessage(hWnd, WM_PASTE, 0, 0L);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxTextCtrl::SetEditable(bool editable)
|
void wxTextCtrl::SetEditable(bool editable)
|
||||||
@@ -1235,3 +1258,53 @@ bool wxTextCtrl::MSWNotify(WXWPARAM wParam, WXLPARAM lParam)
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCut(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Cut();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCopy(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Copy();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnPaste(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Paste();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUndo(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Undo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnRedo(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Redo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCut(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCut() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCopy(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCopy() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdatePaste(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanPaste() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateUndo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanUndo() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateRedo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanRedo() );
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -451,7 +451,12 @@ void wxFrame::ProcessCommand(int id)
|
|||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
GetEventHandler()->ProcessEvent(commandEvent);
|
// Process events starting with the window with the focus, if any.
|
||||||
|
wxWindow* focusWin = wxFindFocusDescendant(this);
|
||||||
|
|
||||||
|
wxEvtHandler* evtHandler = focusWin ? focusWin->GetEventHandler() : GetEventHandler();
|
||||||
|
|
||||||
|
evtHandler->ProcessEvent(commandEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Checks if there is a toolbar, and returns the first free client position
|
// Checks if there is a toolbar, and returns the first free client position
|
||||||
|
@@ -35,6 +35,17 @@ IMPLEMENT_DYNAMIC_CLASS(wxTextCtrl, wxControl)
|
|||||||
|
|
||||||
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
BEGIN_EVENT_TABLE(wxTextCtrl, wxControl)
|
||||||
EVT_DROP_FILES(wxTextCtrl::OnDropFiles)
|
EVT_DROP_FILES(wxTextCtrl::OnDropFiles)
|
||||||
|
EVT_MENU(wxID_CUT, wxTextCtrl::OnCut)
|
||||||
|
EVT_MENU(wxID_COPY, wxTextCtrl::OnCopy)
|
||||||
|
EVT_MENU(wxID_PASTE, wxTextCtrl::OnPaste)
|
||||||
|
EVT_MENU(wxID_UNDO, wxTextCtrl::OnUndo)
|
||||||
|
EVT_MENU(wxID_REDO, wxTextCtrl::OnRedo)
|
||||||
|
|
||||||
|
EVT_UPDATE_UI(wxID_CUT, wxTextCtrl::OnUpdateCut)
|
||||||
|
EVT_UPDATE_UI(wxID_COPY, wxTextCtrl::OnUpdateCopy)
|
||||||
|
EVT_UPDATE_UI(wxID_PASTE, wxTextCtrl::OnUpdatePaste)
|
||||||
|
EVT_UPDATE_UI(wxID_UNDO, wxTextCtrl::OnUpdateUndo)
|
||||||
|
EVT_UPDATE_UI(wxID_REDO, wxTextCtrl::OnUpdateRedo)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -496,3 +507,52 @@ wxTextCtrl& wxTextCtrl::operator<<(const char c)
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCut(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Cut();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnCopy(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Copy();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnPaste(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Paste();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUndo(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Undo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnRedo(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
Redo();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCut(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCut() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateCopy(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanCopy() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdatePaste(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanPaste() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateUndo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanUndo() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTextCtrl::OnUpdateRedo(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
event.Enable( CanRedo() );
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user