made CopySelection() always available (otherwise it wouldn't compile when wxUSE_CLIPBOARD == 0); copy double/triple clicked selection to primary X11 clipboard under Unix as well; minor code cleanup
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@21037 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -221,7 +221,7 @@ protected:
|
|||||||
void OnCopy(wxCommandEvent& event);
|
void OnCopy(wxCommandEvent& event);
|
||||||
void OnMouseEnter(wxMouseEvent& event);
|
void OnMouseEnter(wxMouseEvent& event);
|
||||||
void OnMouseLeave(wxMouseEvent& event);
|
void OnMouseLeave(wxMouseEvent& event);
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
|
|
||||||
// Returns new filter (will be stored into m_DefaultFilter variable)
|
// Returns new filter (will be stored into m_DefaultFilter variable)
|
||||||
virtual wxHtmlFilter *GetDefaultFilter() {return new wxHtmlFilterPlainText;}
|
virtual wxHtmlFilter *GetDefaultFilter() {return new wxHtmlFilterPlainText;}
|
||||||
@@ -233,26 +233,26 @@ protected:
|
|||||||
// and wxHW_NO_SELECTION not used)
|
// and wxHW_NO_SELECTION not used)
|
||||||
bool IsSelectionEnabled() const;
|
bool IsSelectionEnabled() const;
|
||||||
|
|
||||||
#if wxUSE_CLIPBOARD
|
|
||||||
// Convert selection to text:
|
|
||||||
wxString SelectionToText();
|
|
||||||
|
|
||||||
enum ClipboardType
|
enum ClipboardType
|
||||||
{
|
{
|
||||||
Primary,
|
Primary,
|
||||||
Secondary
|
Secondary
|
||||||
};
|
};
|
||||||
|
|
||||||
// Copies selection to clipboard:
|
// Copies selection to clipboard if the clipboard support is available
|
||||||
void CopySelection(ClipboardType t = Secondary);
|
void CopySelection(ClipboardType t = Secondary);
|
||||||
|
|
||||||
|
#if wxUSE_CLIPBOARD
|
||||||
|
// Convert selection to text:
|
||||||
|
wxString SelectionToText();
|
||||||
|
|
||||||
// Helper functions to select parts of page:
|
// Helper functions to select parts of page:
|
||||||
void SelectWord(const wxPoint& pos);
|
void SelectWord(const wxPoint& pos);
|
||||||
void SelectLine(const wxPoint& pos);
|
void SelectLine(const wxPoint& pos);
|
||||||
|
|
||||||
// Automatic scrolling during selection:
|
// Automatic scrolling during selection:
|
||||||
void StopAutoScrolling();
|
void StopAutoScrolling();
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// This is pointer to the first cell in parsed data. (Note: the first cell
|
// This is pointer to the first cell in parsed data. (Note: the first cell
|
||||||
@@ -297,16 +297,16 @@ protected:
|
|||||||
// helper class to automatically scroll the window if the user is selecting
|
// helper class to automatically scroll the window if the user is selecting
|
||||||
// text and the mouse leaves wxHtmlWindow:
|
// text and the mouse leaves wxHtmlWindow:
|
||||||
wxHtmlWinAutoScrollTimer *m_timerAutoScroll;
|
wxHtmlWinAutoScrollTimer *m_timerAutoScroll;
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// window content for double buffered rendering:
|
// window content for double buffered rendering:
|
||||||
wxBitmap *m_backBuffer;
|
wxBitmap *m_backBuffer;
|
||||||
|
|
||||||
// variables used when user is selecting text
|
// variables used when user is selecting text
|
||||||
wxPoint m_tmpSelFromPos;
|
wxPoint m_tmpSelFromPos;
|
||||||
wxHtmlCell *m_tmpSelFromCell;
|
wxHtmlCell *m_tmpSelFromCell;
|
||||||
|
|
||||||
// a flag indicated if mouse moved
|
// a flag indicated if mouse moved
|
||||||
// (if TRUE we will try to change cursor in last call to OnIdle)
|
// (if TRUE we will try to change cursor in last call to OnIdle)
|
||||||
bool m_tmpMouseMoved;
|
bool m_tmpMouseMoved;
|
||||||
@@ -338,7 +338,7 @@ private:
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif // wxUSE_HTML
|
||||||
|
|
||||||
#endif // _WX_HTMLWIN_H_
|
#endif // _WX_HTMLWIN_H_
|
||||||
|
|
||||||
|
@@ -110,7 +110,8 @@ void wxHtmlWinAutoScrollTimer::Notify()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
#endif // wxUSE_CLIPBOARD
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -175,7 +176,7 @@ void wxHtmlWindow::Init()
|
|||||||
#if wxUSE_CLIPBOARD
|
#if wxUSE_CLIPBOARD
|
||||||
m_timerAutoScroll = NULL;
|
m_timerAutoScroll = NULL;
|
||||||
m_lastDoubleClick = 0;
|
m_lastDoubleClick = 0;
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
m_backBuffer = NULL;
|
m_backBuffer = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -197,7 +198,7 @@ wxHtmlWindow::~wxHtmlWindow()
|
|||||||
{
|
{
|
||||||
#if wxUSE_CLIPBOARD
|
#if wxUSE_CLIPBOARD
|
||||||
StopAutoScrolling();
|
StopAutoScrolling();
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
HistoryClear();
|
HistoryClear();
|
||||||
|
|
||||||
if (m_Cell) delete m_Cell;
|
if (m_Cell) delete m_Cell;
|
||||||
@@ -717,7 +718,7 @@ bool wxHtmlWindow::IsSelectionEnabled() const
|
|||||||
return false;
|
return false;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#if wxUSE_CLIPBOARD
|
#if wxUSE_CLIPBOARD
|
||||||
wxString wxHtmlWindow::SelectionToText()
|
wxString wxHtmlWindow::SelectionToText()
|
||||||
@@ -747,22 +748,35 @@ wxString wxHtmlWindow::SelectionToText()
|
|||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif // wxUSE_CLIPBOARD
|
||||||
|
|
||||||
void wxHtmlWindow::CopySelection(ClipboardType t)
|
void wxHtmlWindow::CopySelection(ClipboardType t)
|
||||||
{
|
{
|
||||||
|
#if wxUSE_CLIPBOARD
|
||||||
if ( m_selection )
|
if ( m_selection )
|
||||||
{
|
{
|
||||||
|
#ifdef __UNIX__
|
||||||
wxTheClipboard->UsePrimarySelection(t == Primary);
|
wxTheClipboard->UsePrimarySelection(t == Primary);
|
||||||
wxString txt(SelectionToText());
|
#else // !__UNIX__
|
||||||
|
// Primary selection exists only under X11, so don't do anything under
|
||||||
|
// the other platforms when we try to access it
|
||||||
|
//
|
||||||
|
// TODO: this should be abstracted at wxClipboard level!
|
||||||
|
if ( t == Primary )
|
||||||
|
return;
|
||||||
|
#endif // __UNIX__/!__UNIX__
|
||||||
|
|
||||||
if ( wxTheClipboard->Open() )
|
if ( wxTheClipboard->Open() )
|
||||||
{
|
{
|
||||||
|
const wxString txt(SelectionToText());
|
||||||
wxTheClipboard->SetData(new wxTextDataObject(txt));
|
wxTheClipboard->SetData(new wxTextDataObject(txt));
|
||||||
wxTheClipboard->Close();
|
wxTheClipboard->Close();
|
||||||
wxLogTrace(_T("wxhtmlselection"),
|
wxLogTrace(_T("wxhtmlselection"),
|
||||||
_("Copied to clipboard:\"%s\""), txt.c_str());
|
_("Copied to clipboard:\"%s\""), txt.c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // wxUSE_CLIPBOARD
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
void wxHtmlWindow::OnLinkClicked(const wxHtmlLinkInfo& link)
|
void wxHtmlWindow::OnLinkClicked(const wxHtmlLinkInfo& link)
|
||||||
@@ -805,13 +819,13 @@ void wxHtmlWindow::OnPaint(wxPaintEvent& WXUNUSED(event))
|
|||||||
wxMemoryDC dcm;
|
wxMemoryDC dcm;
|
||||||
if ( !m_backBuffer )
|
if ( !m_backBuffer )
|
||||||
m_backBuffer = new wxBitmap(sz.x, sz.y);
|
m_backBuffer = new wxBitmap(sz.x, sz.y);
|
||||||
dcm.SelectObject(*m_backBuffer);
|
dcm.SelectObject(*m_backBuffer);
|
||||||
dcm.SetBackground(wxBrush(GetBackgroundColour(), wxSOLID));
|
dcm.SetBackground(wxBrush(GetBackgroundColour(), wxSOLID));
|
||||||
dcm.Clear();
|
dcm.Clear();
|
||||||
PrepareDC(dcm);
|
PrepareDC(dcm);
|
||||||
dcm.SetMapMode(wxMM_TEXT);
|
dcm.SetMapMode(wxMM_TEXT);
|
||||||
dcm.SetBackgroundMode(wxTRANSPARENT);
|
dcm.SetBackgroundMode(wxTRANSPARENT);
|
||||||
|
|
||||||
wxHtmlRenderingInfo rinfo;
|
wxHtmlRenderingInfo rinfo;
|
||||||
wxDefaultHtmlRenderingStyle rstyle;
|
wxDefaultHtmlRenderingStyle rstyle;
|
||||||
rinfo.SetSelection(m_selection);
|
rinfo.SetSelection(m_selection);
|
||||||
@@ -845,7 +859,7 @@ void wxHtmlWindow::OnSize(wxSizeEvent& event)
|
|||||||
m_selection->GetToCell());
|
m_selection->GetToCell());
|
||||||
m_selection->ClearPrivPos();
|
m_selection->ClearPrivPos();
|
||||||
}
|
}
|
||||||
|
|
||||||
Refresh();
|
Refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -864,11 +878,13 @@ void wxHtmlWindow::OnMouseDown(wxMouseEvent& event)
|
|||||||
if ( wxGetLocalTimeMillis() - m_lastDoubleClick <= TRIPLECLICK_LEN )
|
if ( wxGetLocalTimeMillis() - m_lastDoubleClick <= TRIPLECLICK_LEN )
|
||||||
{
|
{
|
||||||
SelectLine(CalcUnscrolledPosition(event.GetPosition()));
|
SelectLine(CalcUnscrolledPosition(event.GetPosition()));
|
||||||
|
|
||||||
|
CopySelection();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_makingSelection = true;
|
m_makingSelection = true;
|
||||||
|
|
||||||
if ( m_selection )
|
if ( m_selection )
|
||||||
{
|
{
|
||||||
wxDELETE(m_selection);
|
wxDELETE(m_selection);
|
||||||
@@ -880,7 +896,7 @@ void wxHtmlWindow::OnMouseDown(wxMouseEvent& event)
|
|||||||
CaptureMouse();
|
CaptureMouse();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxHtmlWindow::OnMouseUp(wxMouseEvent& event)
|
void wxHtmlWindow::OnMouseUp(wxMouseEvent& event)
|
||||||
@@ -894,25 +910,24 @@ void wxHtmlWindow::OnMouseUp(wxMouseEvent& event)
|
|||||||
// did the user move the mouse far enough from starting point?
|
// did the user move the mouse far enough from starting point?
|
||||||
if ( m_selection )
|
if ( m_selection )
|
||||||
{
|
{
|
||||||
#ifdef __UNIX__
|
|
||||||
CopySelection(Primary);
|
CopySelection(Primary);
|
||||||
#endif
|
|
||||||
// we don't want mouse up event that ended selecting to be
|
// we don't want mouse up event that ended selecting to be
|
||||||
// handled as mouse click and e.g. follow hyperlink:
|
// handled as mouse click and e.g. follow hyperlink:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
|
|
||||||
SetFocus();
|
SetFocus();
|
||||||
if ( m_Cell )
|
if ( m_Cell )
|
||||||
{
|
{
|
||||||
wxPoint pos = CalcUnscrolledPosition(event.GetPosition());
|
wxPoint pos = CalcUnscrolledPosition(event.GetPosition());
|
||||||
wxHtmlCell *cell = m_Cell->FindCellByPos(pos.x, pos.y);
|
wxHtmlCell *cell = m_Cell->FindCellByPos(pos.x, pos.y);
|
||||||
|
|
||||||
// VZ: is it possible that we don't find anything at all?
|
// check is needed because FindCellByPos returns terminal cell and
|
||||||
// VS: yes. FindCellByPos returns terminal cell and
|
// containers may have empty borders -- in this case NULL will be
|
||||||
// containers may have empty borders
|
// returned
|
||||||
if ( cell )
|
if ( cell )
|
||||||
OnCellClicked(cell, pos.x, pos.y, event);
|
OnCellClicked(cell, pos.x, pos.y, event);
|
||||||
}
|
}
|
||||||
@@ -978,9 +993,9 @@ void wxHtmlWindow::OnIdle(wxIdleEvent& WXUNUSED(event))
|
|||||||
|
|
||||||
// NB: it may *rarely* happen that the code above didn't find one
|
// NB: it may *rarely* happen that the code above didn't find one
|
||||||
// of the cells, e.g. if wxHtmlWindow doesn't contain any
|
// of the cells, e.g. if wxHtmlWindow doesn't contain any
|
||||||
// visible cells.
|
// visible cells.
|
||||||
if ( selcell && m_tmpSelFromCell )
|
if ( selcell && m_tmpSelFromCell )
|
||||||
{
|
{
|
||||||
if ( !m_selection )
|
if ( !m_selection )
|
||||||
{
|
{
|
||||||
// start selecting only if mouse movement was big enough
|
// start selecting only if mouse movement was big enough
|
||||||
@@ -1008,7 +1023,7 @@ void wxHtmlWindow::OnIdle(wxIdleEvent& WXUNUSED(event))
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// handle cursor and status bar text changes:
|
// handle cursor and status bar text changes:
|
||||||
if ( cell != m_tmpLastCell )
|
if ( cell != m_tmpLastCell )
|
||||||
{
|
{
|
||||||
@@ -1144,13 +1159,16 @@ void wxHtmlWindow::OnCopy(wxCommandEvent& event)
|
|||||||
if ( m_selection )
|
if ( m_selection )
|
||||||
CopySelection();
|
CopySelection();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxHtmlWindow::OnDoubleClick(wxMouseEvent& event)
|
void wxHtmlWindow::OnDoubleClick(wxMouseEvent& event)
|
||||||
{
|
{
|
||||||
// select word under cursor:
|
// select word under cursor:
|
||||||
if ( IsSelectionEnabled() )
|
if ( IsSelectionEnabled() )
|
||||||
{
|
{
|
||||||
SelectWord(CalcUnscrolledPosition(event.GetPosition()));
|
SelectWord(CalcUnscrolledPosition(event.GetPosition()));
|
||||||
|
|
||||||
|
CopySelection(Primary);
|
||||||
|
|
||||||
m_lastDoubleClick = wxGetLocalTimeMillis();
|
m_lastDoubleClick = wxGetLocalTimeMillis();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -1179,7 +1197,7 @@ void wxHtmlWindow::SelectLine(const wxPoint& pos)
|
|||||||
// cells in same container as the cell under mouse cursor that are
|
// cells in same container as the cell under mouse cursor that are
|
||||||
// neither completely above nor completely bellow the clicked cell
|
// neither completely above nor completely bellow the clicked cell
|
||||||
// (i.e. are likely to be words positioned on same line of text).
|
// (i.e. are likely to be words positioned on same line of text).
|
||||||
|
|
||||||
int y1 = cell->GetAbsPos().y;
|
int y1 = cell->GetAbsPos().y;
|
||||||
int y2 = y1 + cell->GetHeight();
|
int y2 = y1 + cell->GetHeight();
|
||||||
int y;
|
int y;
|
||||||
@@ -1214,15 +1232,15 @@ void wxHtmlWindow::SelectLine(const wxPoint& pos)
|
|||||||
}
|
}
|
||||||
if ( !before )
|
if ( !before )
|
||||||
before = cell;
|
before = cell;
|
||||||
|
|
||||||
delete m_selection;
|
delete m_selection;
|
||||||
m_selection = new wxHtmlSelection();
|
m_selection = new wxHtmlSelection();
|
||||||
m_selection->Set(before, after);
|
m_selection->Set(before, after);
|
||||||
|
|
||||||
Refresh();
|
Refresh();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1245,7 +1263,7 @@ BEGIN_EVENT_TABLE(wxHtmlWindow, wxScrolledWindow)
|
|||||||
EVT_LEAVE_WINDOW(wxHtmlWindow::OnMouseLeave)
|
EVT_LEAVE_WINDOW(wxHtmlWindow::OnMouseLeave)
|
||||||
EVT_KEY_UP(wxHtmlWindow::OnKeyUp)
|
EVT_KEY_UP(wxHtmlWindow::OnKeyUp)
|
||||||
EVT_MENU(wxID_COPY, wxHtmlWindow::OnCopy)
|
EVT_MENU(wxID_COPY, wxHtmlWindow::OnCopy)
|
||||||
#endif
|
#endif // wxUSE_CLIPBOARD
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
|
||||||
@@ -1273,4 +1291,5 @@ IMPLEMENT_DYNAMIC_CLASS(wxHtmlWinModule, wxModule)
|
|||||||
#include "wx/html/forcelnk.h"
|
#include "wx/html/forcelnk.h"
|
||||||
FORCE_WXHTML_MODULES()
|
FORCE_WXHTML_MODULES()
|
||||||
|
|
||||||
#endif
|
#endif // wxUSE_HTML
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user