Attempted to improve tip window behaviour, but kill focus still not working in wxGTK.
wxTipWindow now has wxTipWindowView child. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@9415 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -25,24 +25,27 @@
|
|||||||
|
|
||||||
class WXDLLEXPORT wxTipWindow : public wxFrame
|
class WXDLLEXPORT wxTipWindow : public wxFrame
|
||||||
{
|
{
|
||||||
|
friend class wxTipWindowView;
|
||||||
public:
|
public:
|
||||||
|
// Supply windowPtr for it to null the given address
|
||||||
|
// when the window has closed.
|
||||||
wxTipWindow(wxWindow *parent,
|
wxTipWindow(wxWindow *parent,
|
||||||
const wxString& text,
|
const wxString& text,
|
||||||
wxCoord maxLength = 100);
|
wxCoord maxLength = 100, wxTipWindow** windowPtr = NULL);
|
||||||
|
~wxTipWindow();
|
||||||
|
|
||||||
|
void SetTipWindowPtr(wxTipWindow** windowPtr) { m_windowPtr = windowPtr; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// event handlers
|
// event handlers
|
||||||
void OnPaint(wxPaintEvent& event);
|
|
||||||
void OnMouseClick(wxMouseEvent& event);
|
void OnMouseClick(wxMouseEvent& event);
|
||||||
void OnActivate(wxActivateEvent& event);
|
void OnActivate(wxActivateEvent& event);
|
||||||
void OnKillFocus(wxFocusEvent& event);
|
void OnKillFocus(wxFocusEvent& event);
|
||||||
|
|
||||||
// calculate the client rect we need to display the text
|
|
||||||
void Adjust(const wxString& text, wxCoord maxLength);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
wxArrayString m_textLines;
|
wxArrayString m_textLines;
|
||||||
wxCoord m_heightLine;
|
wxCoord m_heightLine;
|
||||||
|
wxTipWindow** m_windowPtr;
|
||||||
|
|
||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
};
|
};
|
||||||
|
@@ -305,10 +305,21 @@ void wxSimpleHelpProvider::AddHelp(wxWindowID id, const wxString& text)
|
|||||||
|
|
||||||
bool wxSimpleHelpProvider::ShowHelp(wxWindowBase *window)
|
bool wxSimpleHelpProvider::ShowHelp(wxWindowBase *window)
|
||||||
{
|
{
|
||||||
|
static wxTipWindow* s_tipWindow = NULL;
|
||||||
|
|
||||||
|
if (s_tipWindow)
|
||||||
|
{
|
||||||
|
// Prevent s_tipWindow being nulled in OnIdle,
|
||||||
|
// thereby removing the chance for the window to be closed by ShowHelp
|
||||||
|
s_tipWindow->SetTipWindowPtr(NULL);
|
||||||
|
s_tipWindow->Close();
|
||||||
|
}
|
||||||
|
s_tipWindow = NULL;
|
||||||
|
|
||||||
wxString text = GetHelp(window);
|
wxString text = GetHelp(window);
|
||||||
if ( !text.empty() )
|
if ( !text.empty() )
|
||||||
{
|
{
|
||||||
new wxTipWindow((wxWindow *)window, text);
|
s_tipWindow = new wxTipWindow((wxWindow *)window, text, 100, & s_tipWindow);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@@ -33,6 +33,7 @@
|
|||||||
#endif // WX_PRECOMP
|
#endif // WX_PRECOMP
|
||||||
|
|
||||||
#include "wx/tipwin.h"
|
#include "wx/tipwin.h"
|
||||||
|
#include "wx/timer.h"
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// constants
|
// constants
|
||||||
@@ -50,8 +51,6 @@ static const wxCoord TEXT_MARGIN_Y = 3;
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(wxTipWindow, wxFrame)
|
BEGIN_EVENT_TABLE(wxTipWindow, wxFrame)
|
||||||
EVT_PAINT(wxTipWindow::OnPaint)
|
|
||||||
|
|
||||||
EVT_LEFT_DOWN(wxTipWindow::OnMouseClick)
|
EVT_LEFT_DOWN(wxTipWindow::OnMouseClick)
|
||||||
EVT_RIGHT_DOWN(wxTipWindow::OnMouseClick)
|
EVT_RIGHT_DOWN(wxTipWindow::OnMouseClick)
|
||||||
EVT_MIDDLE_DOWN(wxTipWindow::OnMouseClick)
|
EVT_MIDDLE_DOWN(wxTipWindow::OnMouseClick)
|
||||||
@@ -59,20 +58,48 @@ BEGIN_EVENT_TABLE(wxTipWindow, wxFrame)
|
|||||||
EVT_ACTIVATE(wxTipWindow::OnActivate)
|
EVT_ACTIVATE(wxTipWindow::OnActivate)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
// Viewer window to put in the frame
|
||||||
|
class wxTipWindowView: public wxWindow
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxTipWindowView(wxWindow *parent);
|
||||||
|
|
||||||
|
// event handlers
|
||||||
|
void OnPaint(wxPaintEvent& event);
|
||||||
|
void OnMouseClick(wxMouseEvent& event);
|
||||||
|
void OnKillFocus(wxFocusEvent& event);
|
||||||
|
|
||||||
|
// calculate the client rect we need to display the text
|
||||||
|
void Adjust(const wxString& text, wxCoord maxLength);
|
||||||
|
|
||||||
|
long m_creationTime;
|
||||||
|
|
||||||
|
DECLARE_EVENT_TABLE()
|
||||||
|
};
|
||||||
|
|
||||||
|
BEGIN_EVENT_TABLE(wxTipWindowView, wxWindow)
|
||||||
|
EVT_PAINT(wxTipWindowView::OnPaint)
|
||||||
|
EVT_LEFT_DOWN(wxTipWindowView::OnMouseClick)
|
||||||
|
EVT_RIGHT_DOWN(wxTipWindowView::OnMouseClick)
|
||||||
|
EVT_MIDDLE_DOWN(wxTipWindowView::OnMouseClick)
|
||||||
|
EVT_KILL_FOCUS(wxTipWindowView::OnKillFocus)
|
||||||
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxTipWindow
|
// wxTipWindow
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
wxTipWindow::wxTipWindow(wxWindow *parent,
|
wxTipWindow::wxTipWindow(wxWindow *parent,
|
||||||
const wxString& text,
|
const wxString& text,
|
||||||
wxCoord maxLength)
|
wxCoord maxLength, wxTipWindow** windowPtr)
|
||||||
: wxFrame(parent, -1, _T(""),
|
: wxFrame(parent, -1, _T(""),
|
||||||
wxDefaultPosition, wxDefaultSize,
|
wxDefaultPosition, wxDefaultSize,
|
||||||
wxNO_BORDER | wxFRAME_FLOAT_ON_PARENT)
|
wxNO_BORDER | wxFRAME_FLOAT_ON_PARENT)
|
||||||
{
|
{
|
||||||
// set colours
|
// set colours
|
||||||
SetForegroundColour(*wxBLACK);
|
SetForegroundColour(*wxBLACK);
|
||||||
#if !defined(__WXPM__) && !defined(__WXMAC__)
|
#if !defined(__WXPM__)
|
||||||
SetBackgroundColour(wxColour(0xc3ffff));
|
SetBackgroundColour(wxColour(0xc3ffff));
|
||||||
#else
|
#else
|
||||||
// What is 0xc3ffff, try some legable documentation for those of us who don't memorize hex codes??
|
// What is 0xc3ffff, try some legable documentation for those of us who don't memorize hex codes??
|
||||||
@@ -83,15 +110,62 @@ wxTipWindow::wxTipWindow(wxWindow *parent,
|
|||||||
wxGetMousePosition(&x, &y);
|
wxGetMousePosition(&x, &y);
|
||||||
Move(x, y + 20);
|
Move(x, y + 20);
|
||||||
|
|
||||||
Adjust(text, maxLength);
|
wxTipWindowView* tipWindowView = new wxTipWindowView(this);
|
||||||
|
tipWindowView->Adjust(text, maxLength);
|
||||||
|
|
||||||
SetFocus();
|
m_windowPtr = windowPtr;
|
||||||
|
|
||||||
Show(TRUE);
|
Show(TRUE);
|
||||||
|
tipWindowView->SetFocus();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxTipWindow::Adjust(const wxString& text, wxCoord maxLength)
|
wxTipWindow::~wxTipWindow()
|
||||||
{
|
{
|
||||||
|
if (m_windowPtr)
|
||||||
|
{
|
||||||
|
*m_windowPtr = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTipWindow::OnMouseClick(wxMouseEvent& event)
|
||||||
|
{
|
||||||
|
Close();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTipWindow::OnActivate(wxActivateEvent& event)
|
||||||
|
{
|
||||||
|
if (!event.GetActive())
|
||||||
|
Close();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTipWindow::OnKillFocus(wxFocusEvent& event)
|
||||||
|
{
|
||||||
|
Close();
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxTipWindowView
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
wxTipWindowView::wxTipWindowView(wxWindow *parent)
|
||||||
|
: wxWindow(parent, -1,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxNO_BORDER)
|
||||||
|
{
|
||||||
|
// set colours
|
||||||
|
SetForegroundColour(*wxBLACK);
|
||||||
|
#if !defined(__WXPM__)
|
||||||
|
SetBackgroundColour(wxColour(0xc3ffff));
|
||||||
|
#else
|
||||||
|
// What is 0xc3ffff, try some legable documentation for those of us who don't memorize hex codes??
|
||||||
|
SetBackgroundColour(wxColour(*wxWHITE));
|
||||||
|
#endif
|
||||||
|
m_creationTime = wxGetLocalTime();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxTipWindowView::Adjust(const wxString& text, wxCoord maxLength)
|
||||||
|
{
|
||||||
|
wxTipWindow* parent = (wxTipWindow*) GetParent();
|
||||||
wxClientDC dc(this);
|
wxClientDC dc(this);
|
||||||
dc.SetFont(GetFont());
|
dc.SetFont(GetFont());
|
||||||
|
|
||||||
@@ -100,7 +174,7 @@ void wxTipWindow::Adjust(const wxString& text, wxCoord maxLength)
|
|||||||
wxString current;
|
wxString current;
|
||||||
wxCoord height, width,
|
wxCoord height, width,
|
||||||
widthMax = 0;
|
widthMax = 0;
|
||||||
m_heightLine = 0;
|
parent->m_heightLine = 0;
|
||||||
|
|
||||||
bool breakLine = FALSE;
|
bool breakLine = FALSE;
|
||||||
for ( const wxChar *p = text.c_str(); ; p++ )
|
for ( const wxChar *p = text.c_str(); ; p++ )
|
||||||
@@ -111,10 +185,10 @@ void wxTipWindow::Adjust(const wxString& text, wxCoord maxLength)
|
|||||||
if ( width > widthMax )
|
if ( width > widthMax )
|
||||||
widthMax = width;
|
widthMax = width;
|
||||||
|
|
||||||
if ( height > m_heightLine )
|
if ( height > parent->m_heightLine )
|
||||||
m_heightLine = height;
|
parent->m_heightLine = height;
|
||||||
|
|
||||||
m_textLines.Add(current);
|
parent->m_textLines.Add(current);
|
||||||
|
|
||||||
if ( !*p )
|
if ( !*p )
|
||||||
{
|
{
|
||||||
@@ -128,7 +202,7 @@ void wxTipWindow::Adjust(const wxString& text, wxCoord maxLength)
|
|||||||
else if ( breakLine && (*p == _T(' ') || *p == _T('\t')) )
|
else if ( breakLine && (*p == _T(' ') || *p == _T('\t')) )
|
||||||
{
|
{
|
||||||
// word boundary - break the line here
|
// word boundary - break the line here
|
||||||
m_textLines.Add(current);
|
parent->m_textLines.Add(current);
|
||||||
current.clear();
|
current.clear();
|
||||||
breakLine = FALSE;
|
breakLine = FALSE;
|
||||||
}
|
}
|
||||||
@@ -142,18 +216,22 @@ void wxTipWindow::Adjust(const wxString& text, wxCoord maxLength)
|
|||||||
if ( width > widthMax )
|
if ( width > widthMax )
|
||||||
widthMax = width;
|
widthMax = width;
|
||||||
|
|
||||||
if ( height > m_heightLine )
|
if ( height > parent->m_heightLine )
|
||||||
m_heightLine = height;
|
parent->m_heightLine = height;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// take into account the border size and the margins
|
// take into account the border size and the margins
|
||||||
SetClientSize(2*(TEXT_MARGIN_X + 1) + widthMax,
|
GetParent()->SetClientSize(2*(TEXT_MARGIN_X + 1) + widthMax,
|
||||||
2*(TEXT_MARGIN_Y + 1) + m_textLines.GetCount()*m_heightLine);
|
2*(TEXT_MARGIN_Y + 1) + parent->m_textLines.GetCount()*parent->m_heightLine);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxTipWindow::OnPaint(wxPaintEvent& event)
|
void wxTipWindowView::OnPaint(wxPaintEvent& event)
|
||||||
{
|
{
|
||||||
|
wxTipWindow* parent = (wxTipWindow*) GetParent();
|
||||||
|
if (!parent)
|
||||||
|
return;
|
||||||
|
|
||||||
wxPaintDC dc(this);
|
wxPaintDC dc(this);
|
||||||
|
|
||||||
wxRect rect;
|
wxRect rect;
|
||||||
@@ -178,27 +256,23 @@ void wxTipWindow::OnPaint(wxPaintEvent& event)
|
|||||||
wxPoint pt;
|
wxPoint pt;
|
||||||
pt.x = TEXT_MARGIN_X;
|
pt.x = TEXT_MARGIN_X;
|
||||||
pt.y = TEXT_MARGIN_Y;
|
pt.y = TEXT_MARGIN_Y;
|
||||||
size_t count = m_textLines.GetCount();
|
size_t count = parent->m_textLines.GetCount();
|
||||||
for ( size_t n = 0; n < count; n++ )
|
for ( size_t n = 0; n < count; n++ )
|
||||||
{
|
{
|
||||||
dc.DrawText(m_textLines[n], pt);
|
dc.DrawText(parent->m_textLines[n], pt);
|
||||||
|
|
||||||
pt.y += m_heightLine;
|
pt.y += parent->m_heightLine;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxTipWindow::OnMouseClick(wxMouseEvent& event)
|
void wxTipWindowView::OnMouseClick(wxMouseEvent& event)
|
||||||
{
|
{
|
||||||
Close();
|
GetParent()->Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxTipWindow::OnActivate(wxActivateEvent& event)
|
void wxTipWindowView::OnKillFocus(wxFocusEvent& event)
|
||||||
{
|
{
|
||||||
if (!event.GetActive())
|
// Workaround the kill focus event happening just after creation in wxGTK
|
||||||
Close();
|
if (wxGetLocalTime() > m_creationTime + 1)
|
||||||
}
|
GetParent()->Close();
|
||||||
|
|
||||||
void wxTipWindow::OnKillFocus(wxFocusEvent& event)
|
|
||||||
{
|
|
||||||
Close();
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user