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:
Vadim Zeitlin
2000-10-18 17:46:08 +00:00
parent 85df8658e0
commit 3b56ef075a
7 changed files with 240 additions and 67 deletions

6
TODO
View File

@@ -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

View File

@@ -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)

View File

@@ -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
} }

View File

@@ -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;
} }

View File

@@ -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());

View File

@@ -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);
} }
} }

View File

@@ -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