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 OnMouseEnter(wxMouseEvent& event);
|
||||
void OnMouseLeave(wxMouseEvent& event);
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
|
||||
// Returns new filter (will be stored into m_DefaultFilter variable)
|
||||
virtual wxHtmlFilter *GetDefaultFilter() {return new wxHtmlFilterPlainText;}
|
||||
@@ -233,26 +233,26 @@ protected:
|
||||
// and wxHW_NO_SELECTION not used)
|
||||
bool IsSelectionEnabled() const;
|
||||
|
||||
#if wxUSE_CLIPBOARD
|
||||
// Convert selection to text:
|
||||
wxString SelectionToText();
|
||||
|
||||
enum ClipboardType
|
||||
{
|
||||
Primary,
|
||||
Secondary
|
||||
};
|
||||
|
||||
// Copies selection to clipboard:
|
||||
// Copies selection to clipboard if the clipboard support is available
|
||||
void CopySelection(ClipboardType t = Secondary);
|
||||
|
||||
#if wxUSE_CLIPBOARD
|
||||
// Convert selection to text:
|
||||
wxString SelectionToText();
|
||||
|
||||
// Helper functions to select parts of page:
|
||||
void SelectWord(const wxPoint& pos);
|
||||
void SelectLine(const wxPoint& pos);
|
||||
|
||||
// Automatic scrolling during selection:
|
||||
void StopAutoScrolling();
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
|
||||
protected:
|
||||
// This is pointer to the first cell in parsed data. (Note: the first cell
|
||||
@@ -297,7 +297,7 @@ protected:
|
||||
// helper class to automatically scroll the window if the user is selecting
|
||||
// text and the mouse leaves wxHtmlWindow:
|
||||
wxHtmlWinAutoScrollTimer *m_timerAutoScroll;
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
|
||||
private:
|
||||
// window content for double buffered rendering:
|
||||
@@ -338,7 +338,7 @@ private:
|
||||
};
|
||||
|
||||
|
||||
#endif
|
||||
#endif // wxUSE_HTML
|
||||
|
||||
#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
|
||||
m_timerAutoScroll = NULL;
|
||||
m_lastDoubleClick = 0;
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
m_backBuffer = NULL;
|
||||
}
|
||||
|
||||
@@ -197,7 +198,7 @@ wxHtmlWindow::~wxHtmlWindow()
|
||||
{
|
||||
#if wxUSE_CLIPBOARD
|
||||
StopAutoScrolling();
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
HistoryClear();
|
||||
|
||||
if (m_Cell) delete m_Cell;
|
||||
@@ -747,22 +748,35 @@ wxString wxHtmlWindow::SelectionToText()
|
||||
return text;
|
||||
}
|
||||
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
|
||||
void wxHtmlWindow::CopySelection(ClipboardType t)
|
||||
{
|
||||
#if wxUSE_CLIPBOARD
|
||||
if ( m_selection )
|
||||
{
|
||||
#ifdef __UNIX__
|
||||
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() )
|
||||
{
|
||||
const wxString txt(SelectionToText());
|
||||
wxTheClipboard->SetData(new wxTextDataObject(txt));
|
||||
wxTheClipboard->Close();
|
||||
wxLogTrace(_T("wxhtmlselection"),
|
||||
_("Copied to clipboard:\"%s\""), txt.c_str());
|
||||
}
|
||||
}
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void wxHtmlWindow::OnLinkClicked(const wxHtmlLinkInfo& link)
|
||||
@@ -864,6 +878,8 @@ void wxHtmlWindow::OnMouseDown(wxMouseEvent& event)
|
||||
if ( wxGetLocalTimeMillis() - m_lastDoubleClick <= TRIPLECLICK_LEN )
|
||||
{
|
||||
SelectLine(CalcUnscrolledPosition(event.GetPosition()));
|
||||
|
||||
CopySelection();
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -880,7 +896,7 @@ void wxHtmlWindow::OnMouseDown(wxMouseEvent& event)
|
||||
CaptureMouse();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
}
|
||||
|
||||
void wxHtmlWindow::OnMouseUp(wxMouseEvent& event)
|
||||
@@ -894,15 +910,14 @@ void wxHtmlWindow::OnMouseUp(wxMouseEvent& event)
|
||||
// did the user move the mouse far enough from starting point?
|
||||
if ( m_selection )
|
||||
{
|
||||
#ifdef __UNIX__
|
||||
CopySelection(Primary);
|
||||
#endif
|
||||
|
||||
// we don't want mouse up event that ended selecting to be
|
||||
// handled as mouse click and e.g. follow hyperlink:
|
||||
return;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
|
||||
SetFocus();
|
||||
if ( m_Cell )
|
||||
@@ -910,9 +925,9 @@ void wxHtmlWindow::OnMouseUp(wxMouseEvent& event)
|
||||
wxPoint pos = CalcUnscrolledPosition(event.GetPosition());
|
||||
wxHtmlCell *cell = m_Cell->FindCellByPos(pos.x, pos.y);
|
||||
|
||||
// VZ: is it possible that we don't find anything at all?
|
||||
// VS: yes. FindCellByPos returns terminal cell and
|
||||
// containers may have empty borders
|
||||
// check is needed because FindCellByPos returns terminal cell and
|
||||
// containers may have empty borders -- in this case NULL will be
|
||||
// returned
|
||||
if ( cell )
|
||||
OnCellClicked(cell, pos.x, pos.y, event);
|
||||
}
|
||||
@@ -1151,6 +1166,9 @@ void wxHtmlWindow::OnDoubleClick(wxMouseEvent& event)
|
||||
if ( IsSelectionEnabled() )
|
||||
{
|
||||
SelectWord(CalcUnscrolledPosition(event.GetPosition()));
|
||||
|
||||
CopySelection(Primary);
|
||||
|
||||
m_lastDoubleClick = wxGetLocalTimeMillis();
|
||||
}
|
||||
else
|
||||
@@ -1222,7 +1240,7 @@ void wxHtmlWindow::SelectLine(const wxPoint& pos)
|
||||
Refresh();
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
|
||||
|
||||
|
||||
@@ -1245,7 +1263,7 @@ BEGIN_EVENT_TABLE(wxHtmlWindow, wxScrolledWindow)
|
||||
EVT_LEAVE_WINDOW(wxHtmlWindow::OnMouseLeave)
|
||||
EVT_KEY_UP(wxHtmlWindow::OnKeyUp)
|
||||
EVT_MENU(wxID_COPY, wxHtmlWindow::OnCopy)
|
||||
#endif
|
||||
#endif // wxUSE_CLIPBOARD
|
||||
END_EVENT_TABLE()
|
||||
|
||||
|
||||
@@ -1273,4 +1291,5 @@ IMPLEMENT_DYNAMIC_CLASS(wxHtmlWinModule, wxModule)
|
||||
#include "wx/html/forcelnk.h"
|
||||
FORCE_WXHTML_MODULES()
|
||||
|
||||
#endif
|
||||
#endif // wxUSE_HTML
|
||||
|
||||
|
Reference in New Issue
Block a user