wxTextCtrl works as itshould in disabled and/or not editable states
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/wxUNIVERSAL@8579 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
6
TODO
6
TODO
@@ -19,9 +19,9 @@ All
|
|||||||
* text ctrl wxTE_XXX styles support
|
* text ctrl wxTE_XXX styles support
|
||||||
* listbox inc kbd search
|
* listbox inc kbd search
|
||||||
|
|
||||||
MSW
|
* popup menu for text ctrls
|
||||||
|
|
||||||
wxTextCtrl caret is not shown until *next* refresh
|
MSW
|
||||||
|
|
||||||
GTK
|
GTK
|
||||||
|
|
||||||
@@ -41,6 +41,8 @@ All
|
|||||||
|
|
||||||
MSW
|
MSW
|
||||||
|
|
||||||
|
+ wxTextCtrl caret is not shown until *next* refresh
|
||||||
|
|
||||||
GTK
|
GTK
|
||||||
|
|
||||||
+ check/radio box remains pressed in win32 mode
|
+ check/radio box remains pressed in win32 mode
|
||||||
|
@@ -10,9 +10,10 @@
|
|||||||
/*
|
/*
|
||||||
Current bugs:
|
Current bugs:
|
||||||
|
|
||||||
1. horz scrollbar doesn't appear in listbox
|
+1. horz scrollbar doesn't appear in listbox
|
||||||
+2. truncating text ctrl doesn't update display
|
+2. truncating text ctrl doesn't update display
|
||||||
+3. deleting last listbox item doesn't update display
|
+3. deleting last listbox item doesn't update display
|
||||||
|
4. text ctrl background corrupted after resize
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
@@ -28,15 +29,14 @@
|
|||||||
// headers
|
// headers
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
// For compilers that support precompilation, includes "wx/wx.h".
|
// for compilers that support precompilation, includes "wx/wx.h".
|
||||||
#include "wx/wxprec.h"
|
#include "wx/wxprec.h"
|
||||||
|
|
||||||
#ifdef __BORLANDC__
|
#ifdef __BORLANDC__
|
||||||
#pragma hdrstop
|
#pragma hdrstop
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// for all others, include the necessary headers (this file is usually all you
|
// for all others, include the necessary headers
|
||||||
// need because it includes almost all "standard" wxWindows headers)
|
|
||||||
#ifndef WX_PRECOMP
|
#ifndef WX_PRECOMP
|
||||||
#include "wx/app.h"
|
#include "wx/app.h"
|
||||||
#include "wx/frame.h"
|
#include "wx/frame.h"
|
||||||
@@ -72,9 +72,12 @@ enum
|
|||||||
LboxTest_AddText,
|
LboxTest_AddText,
|
||||||
LboxTest_AddSeveral,
|
LboxTest_AddSeveral,
|
||||||
LboxTest_Clear,
|
LboxTest_Clear,
|
||||||
|
LboxTest_ClearLog,
|
||||||
LboxTest_Delete,
|
LboxTest_Delete,
|
||||||
LboxTest_DeleteText,
|
LboxTest_DeleteText,
|
||||||
LboxTest_DeleteSel
|
LboxTest_DeleteSel,
|
||||||
|
LboxTest_Listbox,
|
||||||
|
LboxTest_Quit
|
||||||
};
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -98,8 +101,9 @@ public:
|
|||||||
class LboxTestFrame : public wxFrame
|
class LboxTestFrame : public wxFrame
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
// ctor(s)
|
// ctor(s) and dtor
|
||||||
LboxTestFrame(const wxString& title);
|
LboxTestFrame(const wxString& title);
|
||||||
|
virtual ~LboxTestFrame();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// event handlers
|
// event handlers
|
||||||
@@ -108,10 +112,13 @@ protected:
|
|||||||
void OnButtonDelete(wxCommandEvent& event);
|
void OnButtonDelete(wxCommandEvent& event);
|
||||||
void OnButtonDeleteSel(wxCommandEvent& event);
|
void OnButtonDeleteSel(wxCommandEvent& event);
|
||||||
void OnButtonClear(wxCommandEvent& event);
|
void OnButtonClear(wxCommandEvent& event);
|
||||||
|
void OnButtonClearLog(wxCommandEvent& event);
|
||||||
void OnButtonAdd(wxCommandEvent& event);
|
void OnButtonAdd(wxCommandEvent& event);
|
||||||
void OnButtonAddSeveral(wxCommandEvent& event);
|
void OnButtonAddSeveral(wxCommandEvent& event);
|
||||||
|
void OnButtonQuit(wxCommandEvent& event);
|
||||||
|
|
||||||
void OnListbox(wxCommandEvent& event);
|
void OnListbox(wxCommandEvent& event);
|
||||||
|
void OnListboxDClick(wxCommandEvent& event);
|
||||||
|
|
||||||
void OnCheckOrRadioBox(wxCommandEvent& event);
|
void OnCheckOrRadioBox(wxCommandEvent& event);
|
||||||
|
|
||||||
@@ -163,15 +170,71 @@ protected:
|
|||||||
wxListBox *m_lbox;
|
wxListBox *m_lbox;
|
||||||
wxSizer *m_sizerLbox;
|
wxSizer *m_sizerLbox;
|
||||||
|
|
||||||
|
// the listbox for logging messages
|
||||||
|
wxListBox *m_lboxLog;
|
||||||
|
|
||||||
// the text entries for "Add string" and "Delete" buttons
|
// the text entries for "Add string" and "Delete" buttons
|
||||||
wxTextCtrl *m_textAdd,
|
wxTextCtrl *m_textAdd,
|
||||||
*m_textDelete;
|
*m_textDelete;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
// the log target we use to redirect messages to the listbox
|
||||||
|
wxLog *m_logTarget;
|
||||||
|
|
||||||
// any class wishing to process wxWindows events must use this macro
|
// any class wishing to process wxWindows events must use this macro
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// A log target which just redirects the messages to a listbox
|
||||||
|
class LboxLogger : public wxLog
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
LboxLogger(wxListBox *lbox, wxLog *logOld)
|
||||||
|
{
|
||||||
|
m_lbox = lbox;
|
||||||
|
m_logOld = logOld;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~LboxLogger()
|
||||||
|
{
|
||||||
|
wxLog::SetActiveTarget(m_logOld);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
// implement sink functions
|
||||||
|
virtual void DoLog(wxLogLevel level, const wxChar *szString, time_t t)
|
||||||
|
{
|
||||||
|
// don't put trace messages into listbox or we can get into infinite
|
||||||
|
// recursion
|
||||||
|
if ( level == wxLOG_Trace )
|
||||||
|
{
|
||||||
|
if ( m_logOld )
|
||||||
|
{
|
||||||
|
// cast is needed to call protected method
|
||||||
|
((LboxLogger *)m_logOld)->DoLog(level, szString, t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wxLog::DoLog(level, szString, t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void DoLogString(const wxChar *szString, time_t t)
|
||||||
|
{
|
||||||
|
wxString msg;
|
||||||
|
TimeStamp(&msg);
|
||||||
|
msg += szString;
|
||||||
|
m_lbox->Append(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
// the control we use
|
||||||
|
wxListBox *m_lbox;
|
||||||
|
|
||||||
|
// the old log target
|
||||||
|
wxLog *m_logOld;
|
||||||
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// misc macros
|
// misc macros
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -193,8 +256,10 @@ BEGIN_EVENT_TABLE(LboxTestFrame, wxFrame)
|
|||||||
EVT_BUTTON(LboxTest_Delete, LboxTestFrame::OnButtonDelete)
|
EVT_BUTTON(LboxTest_Delete, LboxTestFrame::OnButtonDelete)
|
||||||
EVT_BUTTON(LboxTest_DeleteSel, LboxTestFrame::OnButtonDeleteSel)
|
EVT_BUTTON(LboxTest_DeleteSel, LboxTestFrame::OnButtonDeleteSel)
|
||||||
EVT_BUTTON(LboxTest_Clear, LboxTestFrame::OnButtonClear)
|
EVT_BUTTON(LboxTest_Clear, LboxTestFrame::OnButtonClear)
|
||||||
|
EVT_BUTTON(LboxTest_ClearLog, LboxTestFrame::OnButtonClearLog)
|
||||||
EVT_BUTTON(LboxTest_Add, LboxTestFrame::OnButtonAdd)
|
EVT_BUTTON(LboxTest_Add, LboxTestFrame::OnButtonAdd)
|
||||||
EVT_BUTTON(LboxTest_AddSeveral, LboxTestFrame::OnButtonAddSeveral)
|
EVT_BUTTON(LboxTest_AddSeveral, LboxTestFrame::OnButtonAddSeveral)
|
||||||
|
EVT_BUTTON(LboxTest_Quit, LboxTestFrame::OnButtonQuit)
|
||||||
|
|
||||||
EVT_TEXT_ENTER(LboxTest_AddText, LboxTestFrame::OnButtonAdd)
|
EVT_TEXT_ENTER(LboxTest_AddText, LboxTestFrame::OnButtonAdd)
|
||||||
EVT_TEXT_ENTER(LboxTest_DeleteText, LboxTestFrame::OnButtonDelete)
|
EVT_TEXT_ENTER(LboxTest_DeleteText, LboxTestFrame::OnButtonDelete)
|
||||||
@@ -204,10 +269,12 @@ BEGIN_EVENT_TABLE(LboxTestFrame, wxFrame)
|
|||||||
|
|
||||||
EVT_UPDATE_UI(LboxTest_AddSeveral, LboxTestFrame::OnUpdateUIAddSeveral)
|
EVT_UPDATE_UI(LboxTest_AddSeveral, LboxTestFrame::OnUpdateUIAddSeveral)
|
||||||
EVT_UPDATE_UI(LboxTest_Clear, LboxTestFrame::OnUpdateUIClearButton)
|
EVT_UPDATE_UI(LboxTest_Clear, LboxTestFrame::OnUpdateUIClearButton)
|
||||||
|
EVT_UPDATE_UI(LboxTest_DeleteText, LboxTestFrame::OnUpdateUIClearButton)
|
||||||
EVT_UPDATE_UI(LboxTest_Delete, LboxTestFrame::OnUpdateUIDeleteButton)
|
EVT_UPDATE_UI(LboxTest_Delete, LboxTestFrame::OnUpdateUIDeleteButton)
|
||||||
EVT_UPDATE_UI(LboxTest_DeleteSel, LboxTestFrame::OnUpdateUIDeleteSelButton)
|
EVT_UPDATE_UI(LboxTest_DeleteSel, LboxTestFrame::OnUpdateUIDeleteSelButton)
|
||||||
|
|
||||||
EVT_LISTBOX(-1, LboxTestFrame::OnListbox)
|
EVT_LISTBOX(LboxTest_Listbox, LboxTestFrame::OnListbox)
|
||||||
|
EVT_LISTBOX_DCLICK(-1, LboxTestFrame::OnListboxDClick)
|
||||||
EVT_CHECKBOX(-1, LboxTestFrame::OnCheckOrRadioBox)
|
EVT_CHECKBOX(-1, LboxTestFrame::OnCheckOrRadioBox)
|
||||||
EVT_RADIOBOX(-1, LboxTestFrame::OnCheckOrRadioBox)
|
EVT_RADIOBOX(-1, LboxTestFrame::OnCheckOrRadioBox)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
@@ -246,9 +313,14 @@ LboxTestFrame::LboxTestFrame(const wxString& title)
|
|||||||
m_chkHScroll =
|
m_chkHScroll =
|
||||||
m_chkSort = (wxCheckBox *)NULL;
|
m_chkSort = (wxCheckBox *)NULL;
|
||||||
|
|
||||||
m_lbox = (wxListBox *)NULL;
|
m_lbox =
|
||||||
|
m_lboxLog = (wxListBox *)NULL;
|
||||||
m_sizerLbox = (wxSizer *)NULL;
|
m_sizerLbox = (wxSizer *)NULL;
|
||||||
|
|
||||||
|
m_logTarget = (wxLog *)NULL;
|
||||||
|
|
||||||
|
wxPanel *panel = new wxPanel(this, -1);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
What we create here is a frame having 3 panes: the explanatory pane to
|
What we create here is a frame having 3 panes: the explanatory pane to
|
||||||
the left allowing to set the listbox styles and recreate the control,
|
the left allowing to set the listbox styles and recreate the control,
|
||||||
@@ -268,15 +340,15 @@ LboxTestFrame::LboxTestFrame(const wxString& title)
|
|||||||
_T("multiple"),
|
_T("multiple"),
|
||||||
};
|
};
|
||||||
|
|
||||||
wxStaticBox *box = new wxStaticBox(this, -1, _T("&Set listbox parameters"));
|
wxStaticBox *box = new wxStaticBox(panel, -1, _T("&Set listbox parameters"));
|
||||||
m_radioSelMode = new wxRadioBox(this, -1, _T("Selection &mode:"),
|
m_radioSelMode = new wxRadioBox(panel, -1, _T("Selection &mode:"),
|
||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
WXSIZEOF(modes), modes,
|
WXSIZEOF(modes), modes,
|
||||||
1, wxRA_SPECIFY_COLS);
|
1, wxRA_SPECIFY_COLS);
|
||||||
|
|
||||||
m_chkVScroll = new wxCheckBox(this, -1, _T("Always show &vertical scrollbar"));
|
m_chkVScroll = new wxCheckBox(panel, -1, _T("Always show &vertical scrollbar"));
|
||||||
m_chkHScroll = new wxCheckBox(this, -1, _T("Show &horizontal scrollbar"));
|
m_chkHScroll = new wxCheckBox(panel, -1, _T("Show &horizontal scrollbar"));
|
||||||
m_chkSort = new wxCheckBox(this, -1, _T("&Sort items"));
|
m_chkSort = new wxCheckBox(panel, -1, _T("&Sort items"));
|
||||||
|
|
||||||
sizerLeft = new wxStaticBoxSizer(box, wxVERTICAL);
|
sizerLeft = new wxStaticBoxSizer(box, wxVERTICAL);
|
||||||
|
|
||||||
@@ -287,61 +359,93 @@ LboxTestFrame::LboxTestFrame(const wxString& title)
|
|||||||
sizerLeft->Add(m_radioSelMode, 0, wxGROW | wxALL, 5);
|
sizerLeft->Add(m_radioSelMode, 0, wxGROW | wxALL, 5);
|
||||||
|
|
||||||
wxSizer *sizerBtn = new wxBoxSizer(wxHORIZONTAL);
|
wxSizer *sizerBtn = new wxBoxSizer(wxHORIZONTAL);
|
||||||
wxButton *btn = new wxButton(this, LboxTest_Reset, _T("&Reset"));
|
wxButton *btn = new wxButton(panel, LboxTest_Reset, _T("&Reset"));
|
||||||
sizerBtn->Add(btn, 0, wxLEFT | wxRIGHT, 5);
|
sizerBtn->Add(btn, 0, wxLEFT | wxRIGHT, 5);
|
||||||
btn = new wxButton(this, LboxTest_Create, _T("&Create"));
|
btn = new wxButton(panel, LboxTest_Create, _T("&Create"));
|
||||||
sizerBtn->Add(btn, 0, wxLEFT | wxRIGHT, 5);
|
sizerBtn->Add(btn, 0, wxLEFT | wxRIGHT, 5);
|
||||||
sizerLeft->Add(sizerBtn, 0, wxALIGN_CENTRE_HORIZONTAL | wxALL, 15);
|
sizerLeft->Add(sizerBtn, 0, wxALIGN_CENTRE_HORIZONTAL | wxALL, 15);
|
||||||
|
|
||||||
|
// middle pane
|
||||||
|
wxStaticBox *box2 = new wxStaticBox(panel, -1, _T("&Change listbox contents"));
|
||||||
|
wxSizer *sizerMiddle = new wxStaticBoxSizer(box2, wxVERTICAL);
|
||||||
|
|
||||||
|
wxSizer *sizerRow = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
btn = new wxButton(panel, LboxTest_Add, _T("&Add panel string"));
|
||||||
|
m_textAdd = new wxTextCtrl(panel, LboxTest_AddText, _T("test string 0"));
|
||||||
|
sizerRow->Add(btn, 0, wxRIGHT, 5);
|
||||||
|
sizerRow->Add(m_textAdd, 1, wxLEFT, 5);
|
||||||
|
sizerMiddle->Add(sizerRow, 0, wxALL | wxGROW, 5);
|
||||||
|
|
||||||
|
btn = new wxButton(panel, LboxTest_AddSeveral, _T("&Insert a few strings"));
|
||||||
|
sizerMiddle->Add(btn, 0, wxALL | wxGROW, 5);
|
||||||
|
|
||||||
|
sizerRow = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
btn = new wxButton(panel, LboxTest_Delete, _T("&Delete panel item"));
|
||||||
|
m_textDelete = new wxTextCtrl(panel, LboxTest_DeleteText, _T(""));
|
||||||
|
sizerRow->Add(btn, 0, wxRIGHT, 5);
|
||||||
|
sizerRow->Add(m_textDelete, 1, wxLEFT, 5);
|
||||||
|
sizerMiddle->Add(sizerRow, 0, wxALL | wxGROW, 5);
|
||||||
|
|
||||||
|
btn = new wxButton(panel, LboxTest_DeleteSel, _T("Delete &selection"));
|
||||||
|
sizerMiddle->Add(btn, 0, wxALL | wxGROW, 5);
|
||||||
|
|
||||||
|
btn = new wxButton(panel, LboxTest_Clear, _T("&Clear"));
|
||||||
|
sizerMiddle->Add(btn, 0, wxALL | wxGROW, 5);
|
||||||
|
|
||||||
// right pane
|
// right pane
|
||||||
m_lbox = new wxListBox(this, -1);
|
m_lbox = new wxListBox(panel, LboxTest_Listbox,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
0, NULL,
|
||||||
|
wxLB_HSCROLL);
|
||||||
sizerRight->Add(m_lbox, 1, wxGROW | wxALL, 5);
|
sizerRight->Add(m_lbox, 1, wxGROW | wxALL, 5);
|
||||||
sizerRight->SetMinSize(250, 0);
|
sizerRight->SetMinSize(250, 0);
|
||||||
m_sizerLbox = sizerRight; // save it to modify it later
|
m_sizerLbox = sizerRight; // save it to modify it later
|
||||||
|
|
||||||
// left + right panes compose the upper one
|
// the 3 panes panes compose the upper part of the window
|
||||||
sizerUp->Add(sizerLeft, 0, wxGROW | wxALL, 10);
|
sizerUp->Add(sizerLeft, 0, wxGROW | (wxALL & ~wxLEFT), 10);
|
||||||
sizerUp->Add(sizerRight, 1, wxGROW | wxALL, 10);
|
sizerUp->Add(sizerMiddle, 1, wxGROW | wxALL, 10);
|
||||||
|
sizerUp->Add(sizerRight, 1, wxGROW | (wxALL & ~wxRIGHT), 10);
|
||||||
|
|
||||||
// lower pane
|
// the lower one only has the log listbox and a button to clear it
|
||||||
wxStaticBox *box2 = new wxStaticBox(this, -1, _T("&Change listbox contents"));
|
wxSizer *sizerDown = new wxStaticBoxSizer
|
||||||
wxSizer *sizerDown = new wxStaticBoxSizer(box2, wxVERTICAL);
|
(
|
||||||
|
new wxStaticBox(panel, -1, _T("&Log window")),
|
||||||
|
wxVERTICAL
|
||||||
|
);
|
||||||
|
m_lboxLog = new wxListBox(panel, -1);
|
||||||
|
sizerDown->Add(m_lboxLog, 1, wxGROW | wxALL, 5);
|
||||||
|
wxBoxSizer *sizerBtns = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
btn = new wxButton(panel, LboxTest_ClearLog, _T("Clear &log"));
|
||||||
|
sizerBtns->Add(btn);
|
||||||
|
sizerBtns->Add(10, 0); // spacer
|
||||||
|
btn = new wxButton(panel, LboxTest_Quit, _T("E&xit"));
|
||||||
|
sizerBtns->Add(btn);
|
||||||
|
sizerDown->Add(sizerBtns, 0, wxALL | wxALIGN_RIGHT, 5);
|
||||||
|
|
||||||
wxSizer *sizerRow = new wxBoxSizer(wxHORIZONTAL);
|
// put everything together
|
||||||
btn = new wxButton(this, LboxTest_Add, _T("&Add this string"));
|
sizerTop->Add(sizerUp, 1, wxGROW | (wxALL & ~wxBOTTOM), 10);
|
||||||
m_textAdd = new wxTextCtrl(this, LboxTest_AddText, _T("test string 0"));
|
sizerTop->Add(0, 5, 0, wxGROW); // spacer in between
|
||||||
sizerRow->Add(btn, 0, wxRIGHT, 5);
|
sizerTop->Add(sizerDown, 0, wxGROW | (wxALL & ~wxTOP), 10);
|
||||||
sizerRow->Add(m_textAdd, 1, wxLEFT, 5);
|
|
||||||
sizerDown->Add(sizerRow, 0, wxALL | wxGROW, 5);
|
|
||||||
|
|
||||||
btn = new wxButton(this, LboxTest_AddSeveral, _T("&Insert a few strings"));
|
|
||||||
sizerDown->Add(btn, 0, wxALL | wxGROW, 5);
|
|
||||||
|
|
||||||
sizerRow = new wxBoxSizer(wxHORIZONTAL);
|
|
||||||
btn = new wxButton(this, LboxTest_Delete, _T("&Delete this item"));
|
|
||||||
m_textDelete = new wxTextCtrl(this, LboxTest_DeleteText, _T(""));
|
|
||||||
sizerRow->Add(btn, 0, wxRIGHT, 5);
|
|
||||||
sizerRow->Add(m_textDelete, 1, wxLEFT, 5);
|
|
||||||
sizerDown->Add(sizerRow, 0, wxALL | wxGROW, 5);
|
|
||||||
|
|
||||||
btn = new wxButton(this, LboxTest_DeleteSel, _T("Delete &selection"));
|
|
||||||
sizerDown->Add(btn, 0, wxALL | wxGROW, 5);
|
|
||||||
|
|
||||||
btn = new wxButton(this, LboxTest_Clear, _T("&Clear"));
|
|
||||||
sizerDown->Add(btn, 0, wxALL | wxGROW, 5);
|
|
||||||
|
|
||||||
sizerTop->Add(sizerUp, 1, wxGROW | wxALL, 10);
|
|
||||||
sizerTop->Add(sizerDown, 0, wxGROW | wxALL, 10);
|
|
||||||
|
|
||||||
// final initialization
|
// final initialization
|
||||||
Reset();
|
Reset();
|
||||||
m_dirty = FALSE;
|
m_dirty = FALSE;
|
||||||
|
|
||||||
SetAutoLayout(TRUE);
|
panel->SetAutoLayout(TRUE);
|
||||||
SetSizer(sizerTop);
|
panel->SetSizer(sizerTop);
|
||||||
|
|
||||||
sizerTop->Fit(this);
|
sizerTop->Fit(this);
|
||||||
sizerTop->SetSizeHints(this);
|
sizerTop->SetSizeHints(this);
|
||||||
|
|
||||||
|
// now that everything is created we can redirect the log messages to the
|
||||||
|
// listbox
|
||||||
|
m_logTarget = new LboxLogger(m_lboxLog, wxLog::GetActiveTarget());
|
||||||
|
wxLog::SetActiveTarget(m_logTarget);
|
||||||
|
}
|
||||||
|
|
||||||
|
LboxTestFrame::~LboxTestFrame()
|
||||||
|
{
|
||||||
|
delete m_logTarget;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -352,7 +456,7 @@ void LboxTestFrame::Reset()
|
|||||||
{
|
{
|
||||||
if ( m_radioSelMode->GetSelection() == LboxSel_Single &&
|
if ( m_radioSelMode->GetSelection() == LboxSel_Single &&
|
||||||
!m_chkSort->GetValue() &&
|
!m_chkSort->GetValue() &&
|
||||||
!m_chkHScroll->GetValue() &&
|
m_chkHScroll->GetValue() &&
|
||||||
!m_chkVScroll->GetValue() )
|
!m_chkVScroll->GetValue() )
|
||||||
{
|
{
|
||||||
// nothing to do
|
// nothing to do
|
||||||
@@ -361,7 +465,7 @@ void LboxTestFrame::Reset()
|
|||||||
|
|
||||||
m_radioSelMode->SetSelection(LboxSel_Single);
|
m_radioSelMode->SetSelection(LboxSel_Single);
|
||||||
m_chkSort->SetValue(FALSE);
|
m_chkSort->SetValue(FALSE);
|
||||||
m_chkHScroll->SetValue(FALSE);
|
m_chkHScroll->SetValue(TRUE);
|
||||||
m_chkVScroll->SetValue(FALSE);
|
m_chkVScroll->SetValue(FALSE);
|
||||||
|
|
||||||
m_dirty = TRUE;
|
m_dirty = TRUE;
|
||||||
@@ -415,6 +519,11 @@ void LboxTestFrame::CreateLbox()
|
|||||||
// event handlers
|
// event handlers
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void LboxTestFrame::OnButtonQuit(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
Close();
|
||||||
|
}
|
||||||
|
|
||||||
void LboxTestFrame::OnButtonReset(wxCommandEvent& WXUNUSED(event))
|
void LboxTestFrame::OnButtonReset(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
Reset();
|
Reset();
|
||||||
@@ -452,6 +561,11 @@ void LboxTestFrame::OnButtonClear(wxCommandEvent& event)
|
|||||||
m_lbox->Clear();
|
m_lbox->Clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LboxTestFrame::OnButtonClearLog(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
m_lboxLog->Clear();
|
||||||
|
}
|
||||||
|
|
||||||
void LboxTestFrame::OnButtonAdd(wxCommandEvent& event)
|
void LboxTestFrame::OnButtonAdd(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
static size_t s_item = 0;
|
static size_t s_item = 0;
|
||||||
@@ -505,7 +619,15 @@ void LboxTestFrame::OnUpdateUIAddSeveral(wxUpdateUIEvent& event)
|
|||||||
|
|
||||||
void LboxTestFrame::OnListbox(wxCommandEvent& event)
|
void LboxTestFrame::OnListbox(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
m_textDelete->SetValue(wxString::Format(_T("%ld"), event.GetInt()));
|
int sel = event.GetInt();
|
||||||
|
m_textDelete->SetValue(wxString::Format(_T("%ld"), sel));
|
||||||
|
|
||||||
|
wxLogMessage(_T("Listbox item %d selected"), sel);
|
||||||
|
}
|
||||||
|
|
||||||
|
void LboxTestFrame::OnListboxDClick(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
wxLogMessage(_T("Listbox item %d double clicked"), event.GetInt());
|
||||||
}
|
}
|
||||||
|
|
||||||
void LboxTestFrame::OnCheckOrRadioBox(wxCommandEvent& event)
|
void LboxTestFrame::OnCheckOrRadioBox(wxCommandEvent& event)
|
||||||
|
@@ -239,6 +239,7 @@ MyUnivFrame::MyUnivFrame(const wxString& title)
|
|||||||
{
|
{
|
||||||
SetBackgroundColour(wxGetApp().GetBgColour());
|
SetBackgroundColour(wxGetApp().GetBgColour());
|
||||||
|
|
||||||
|
new wxStaticText(this, _T("Test static text"), wxPoint(10, 10));
|
||||||
#ifndef TEST_TEXT_ONLY
|
#ifndef TEST_TEXT_ONLY
|
||||||
new wxStaticText(this, _T("Test static text"), wxPoint(10, 10));
|
new wxStaticText(this, _T("Test static text"), wxPoint(10, 10));
|
||||||
new wxStaticText(this,
|
new wxStaticText(this,
|
||||||
@@ -383,7 +384,7 @@ MyUnivFrame::MyUnivFrame(const wxString& title)
|
|||||||
new wxTextCtrl(this, -1, _T("Hello, Universe!"),
|
new wxTextCtrl(this, -1, _T("Hello, Universe!"),
|
||||||
wxPoint(550, 150), wxDefaultSize);
|
wxPoint(550, 150), wxDefaultSize);
|
||||||
#else // TEST_TEXT_ONLY
|
#else // TEST_TEXT_ONLY
|
||||||
#if 0
|
#if 1
|
||||||
wxTextCtrl *text = new wxTextCtrl(this, -1, _T("Hello, Universe!"),
|
wxTextCtrl *text = new wxTextCtrl(this, -1, _T("Hello, Universe!"),
|
||||||
wxPoint(10, 40));
|
wxPoint(10, 40));
|
||||||
text->SetFont(wxFont(24, wxFONTFAMILY_DEFAULT,
|
text->SetFont(wxFont(24, wxFONTFAMILY_DEFAULT,
|
||||||
@@ -392,12 +393,12 @@ MyUnivFrame::MyUnivFrame(const wxString& title)
|
|||||||
sizeText.x = 200;
|
sizeText.x = 200;
|
||||||
text->SetSize(sizeText);
|
text->SetSize(sizeText);
|
||||||
#else
|
#else
|
||||||
wxTextCtrl *
|
wxTextCtrl *text = new wxTextCtrl(this, -1, _T("Hello,\nMultiverse!"),
|
||||||
|
wxPoint(10, 10), wxDefaultSize,
|
||||||
|
wxTE_MULTILINE);
|
||||||
#endif
|
#endif
|
||||||
text = new wxTextCtrl(this, -1, _T("Hello,\nMultiverse!"),
|
|
||||||
wxPoint(10, 10), wxDefaultSize,
|
|
||||||
wxTE_MULTILINE);
|
|
||||||
text->SetFocus();
|
text->SetFocus();
|
||||||
|
text->SetEditable(FALSE);
|
||||||
#endif // !TEST_TEXT_ONLY/TEST_TEXT_ONLY
|
#endif // !TEST_TEXT_ONLY/TEST_TEXT_ONLY
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -287,8 +287,31 @@ void wxListBox::Delete(int n)
|
|||||||
}
|
}
|
||||||
//else: current item may stay
|
//else: current item may stay
|
||||||
|
|
||||||
m_selections.Remove(n);
|
// update the selections array: the indices of all seletected items after
|
||||||
|
// the one being deleted must change and the item itselfm ust be removed
|
||||||
|
int index = wxNOT_FOUND;
|
||||||
|
size_t count = m_selections.GetCount();
|
||||||
|
for ( size_t item = 0; item < count; item++ )
|
||||||
|
{
|
||||||
|
if ( m_selections[item] == n )
|
||||||
|
{
|
||||||
|
// remember to delete it later
|
||||||
|
index = item;
|
||||||
|
}
|
||||||
|
else if ( m_selections[item] > n )
|
||||||
|
{
|
||||||
|
// to account for the index shift
|
||||||
|
m_selections[item]--;
|
||||||
|
}
|
||||||
|
//else: nothing changed for this one
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( index != wxNOT_FOUND )
|
||||||
|
{
|
||||||
|
m_selections.RemoveAt(index);
|
||||||
|
}
|
||||||
|
|
||||||
|
// the number of items has changed, hence the scrollbar may disappear
|
||||||
m_updateScrollbarY = TRUE;
|
m_updateScrollbarY = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -961,7 +961,8 @@ bool wxTextCtrl::IsModified() const
|
|||||||
|
|
||||||
bool wxTextCtrl::IsEditable() const
|
bool wxTextCtrl::IsEditable() const
|
||||||
{
|
{
|
||||||
return m_isEditable;
|
// disabled control can never be edited
|
||||||
|
return m_isEditable && IsEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxTextCtrl::DiscardEdits()
|
void wxTextCtrl::DiscardEdits()
|
||||||
@@ -1878,6 +1879,8 @@ void wxTextCtrl::OnIdle(wxIdleEvent& event)
|
|||||||
m_updateScrollbarX =
|
m_updateScrollbarX =
|
||||||
m_updateScrollbarY = FALSE;
|
m_updateScrollbarY = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
event.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -2303,7 +2306,8 @@ bool wxTextCtrl::PerformAction(const wxControlAction& actionOrig,
|
|||||||
sel = FALSE;
|
sel = FALSE;
|
||||||
if ( actionOrig.StartsWith(wxACTION_TEXT_PREFIX_DEL, &action) )
|
if ( actionOrig.StartsWith(wxACTION_TEXT_PREFIX_DEL, &action) )
|
||||||
{
|
{
|
||||||
del = TRUE;
|
if ( IsEditable() )
|
||||||
|
del = TRUE;
|
||||||
}
|
}
|
||||||
else if ( actionOrig.StartsWith(wxACTION_TEXT_PREFIX_SEL, &action) )
|
else if ( actionOrig.StartsWith(wxACTION_TEXT_PREFIX_SEL, &action) )
|
||||||
{
|
{
|
||||||
@@ -2356,7 +2360,7 @@ bool wxTextCtrl::PerformAction(const wxControlAction& actionOrig,
|
|||||||
}
|
}
|
||||||
else if ( action == wxACTION_TEXT_INSERT )
|
else if ( action == wxACTION_TEXT_INSERT )
|
||||||
{
|
{
|
||||||
if ( !strArg.empty() )
|
if ( IsEditable() && !strArg.empty() )
|
||||||
{
|
{
|
||||||
WriteText(strArg);
|
WriteText(strArg);
|
||||||
|
|
||||||
@@ -2381,11 +2385,13 @@ bool wxTextCtrl::PerformAction(const wxControlAction& actionOrig,
|
|||||||
}
|
}
|
||||||
else if ( action == wxACTION_TEXT_CUT )
|
else if ( action == wxACTION_TEXT_CUT )
|
||||||
{
|
{
|
||||||
Cut();
|
if ( IsEditable() )
|
||||||
|
Cut();
|
||||||
}
|
}
|
||||||
else if ( action == wxACTION_TEXT_PASTE )
|
else if ( action == wxACTION_TEXT_PASTE )
|
||||||
{
|
{
|
||||||
Paste();
|
if ( IsEditable() )
|
||||||
|
Paste();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -2440,6 +2446,8 @@ bool wxTextCtrl::PerformAction(const wxControlAction& actionOrig,
|
|||||||
|
|
||||||
if ( textChanged )
|
if ( textChanged )
|
||||||
{
|
{
|
||||||
|
wxASSERT_MSG( IsEditable(), _T("non editable control changed?") );
|
||||||
|
|
||||||
wxCommandEvent event(wxEVT_COMMAND_TEXT_UPDATED, GetId());
|
wxCommandEvent event(wxEVT_COMMAND_TEXT_UPDATED, GetId());
|
||||||
InitCommandEvent(event);
|
InitCommandEvent(event);
|
||||||
event.SetString(GetValue());
|
event.SetString(GetValue());
|
||||||
|
@@ -34,6 +34,7 @@
|
|||||||
|
|
||||||
#include "wx/button.h"
|
#include "wx/button.h"
|
||||||
#include "wx/scrolbar.h"
|
#include "wx/scrolbar.h"
|
||||||
|
#include "wx/textctrl.h"
|
||||||
#endif // WX_PRECOMP
|
#endif // WX_PRECOMP
|
||||||
|
|
||||||
#include "wx/univ/renderer.h"
|
#include "wx/univ/renderer.h"
|
||||||
@@ -697,9 +698,17 @@ wxColour wxWin32ColourScheme::GetBackground(wxWindow *win) const
|
|||||||
|
|
||||||
if ( win->IsContainerWindow() )
|
if ( win->IsContainerWindow() )
|
||||||
{
|
{
|
||||||
// doesn't depend on the state
|
wxTextCtrl *text = wxDynamicCast(win, wxTextCtrl);
|
||||||
|
if ( text )
|
||||||
|
{
|
||||||
|
if ( !text->IsEditable() )
|
||||||
|
col = Get(CONTROL);
|
||||||
|
//else: execute code below
|
||||||
|
}
|
||||||
|
|
||||||
if ( !col.Ok() )
|
if ( !col.Ok() )
|
||||||
{
|
{
|
||||||
|
// doesn't depend on the state
|
||||||
col = Get(WINDOW);
|
col = Get(WINDOW);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -88,7 +88,9 @@ bool wxWindow::Create(wxWindow *parent,
|
|||||||
// we add wxCLIP_CHILDREN and wxNO_FULL_REPAINT_ON_RESIZE because without
|
// we add wxCLIP_CHILDREN and wxNO_FULL_REPAINT_ON_RESIZE because without
|
||||||
// these styles we can't get rid of flicker on wxMSW
|
// these styles we can't get rid of flicker on wxMSW
|
||||||
if ( !wxWindowNative::Create(parent, id, pos, size,
|
if ( !wxWindowNative::Create(parent, id, pos, size,
|
||||||
style | wxCLIP_CHILDREN, name) )
|
style |
|
||||||
|
wxCLIP_CHILDREN |
|
||||||
|
wxNO_FULL_REPAINT_ON_RESIZE, name) )
|
||||||
{
|
{
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@@ -309,6 +311,12 @@ bool wxWindow::Enable(bool enable)
|
|||||||
if ( !wxWindowBase::Enable(enable) )
|
if ( !wxWindowBase::Enable(enable) )
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
|
// disabled window can't keep focus
|
||||||
|
if ( FindFocus() == this )
|
||||||
|
{
|
||||||
|
GetParent()->SetFocus();
|
||||||
|
}
|
||||||
|
|
||||||
if ( m_renderer )
|
if ( m_renderer )
|
||||||
{
|
{
|
||||||
// a window with renderer is drawn by ourselves and it has to be
|
// a window with renderer is drawn by ourselves and it has to be
|
||||||
|
Reference in New Issue
Block a user