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:
Vadim Zeitlin
2003-06-11 11:34:44 +00:00
parent 63b8dd39b8
commit d659d703ef
2 changed files with 60 additions and 41 deletions

View File

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

View File

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