small corrections for dnd code and added wxFileDataObject demo to the sample
(wxMSW only) git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@4329 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
c03648c251
commit
51edda6af0
@ -95,11 +95,15 @@ public:
|
|||||||
void OnNewFrame(wxCommandEvent& event);
|
void OnNewFrame(wxCommandEvent& event);
|
||||||
void OnHelp (wxCommandEvent& event);
|
void OnHelp (wxCommandEvent& event);
|
||||||
void OnLogClear(wxCommandEvent& event);
|
void OnLogClear(wxCommandEvent& event);
|
||||||
|
|
||||||
void OnCopy(wxCommandEvent& event);
|
void OnCopy(wxCommandEvent& event);
|
||||||
void OnPaste(wxCommandEvent& event);
|
void OnPaste(wxCommandEvent& event);
|
||||||
|
|
||||||
void OnCopyBitmap(wxCommandEvent& event);
|
void OnCopyBitmap(wxCommandEvent& event);
|
||||||
void OnPasteBitmap(wxCommandEvent& event);
|
void OnPasteBitmap(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnCopyFiles(wxCommandEvent& event);
|
||||||
|
|
||||||
void OnLeftDown(wxMouseEvent& event);
|
void OnLeftDown(wxMouseEvent& event);
|
||||||
void OnRightDown(wxMouseEvent& event);
|
void OnRightDown(wxMouseEvent& event);
|
||||||
|
|
||||||
@ -577,8 +581,7 @@ enum
|
|||||||
Menu_Paste,
|
Menu_Paste,
|
||||||
Menu_CopyBitmap,
|
Menu_CopyBitmap,
|
||||||
Menu_PasteBitmap,
|
Menu_PasteBitmap,
|
||||||
Menu_ToBeGreyed, /* for testing */
|
Menu_CopyFiles,
|
||||||
Menu_ToBeDeleted, /* for testing */
|
|
||||||
Menu_Shape_New = 500,
|
Menu_Shape_New = 500,
|
||||||
Menu_Shape_Edit,
|
Menu_Shape_Edit,
|
||||||
Menu_Shape_Clear,
|
Menu_Shape_Clear,
|
||||||
@ -598,6 +601,7 @@ BEGIN_EVENT_TABLE(DnDFrame, wxFrame)
|
|||||||
EVT_MENU(Menu_Paste, DnDFrame::OnPaste)
|
EVT_MENU(Menu_Paste, DnDFrame::OnPaste)
|
||||||
EVT_MENU(Menu_CopyBitmap, DnDFrame::OnCopyBitmap)
|
EVT_MENU(Menu_CopyBitmap, DnDFrame::OnCopyBitmap)
|
||||||
EVT_MENU(Menu_PasteBitmap,DnDFrame::OnPasteBitmap)
|
EVT_MENU(Menu_PasteBitmap,DnDFrame::OnPasteBitmap)
|
||||||
|
EVT_MENU(Menu_CopyFiles, DnDFrame::OnCopyFiles)
|
||||||
|
|
||||||
EVT_UPDATE_UI(Menu_Paste, DnDFrame::OnUpdateUIPasteText)
|
EVT_UPDATE_UI(Menu_Paste, DnDFrame::OnUpdateUIPasteText)
|
||||||
EVT_UPDATE_UI(Menu_PasteBitmap, DnDFrame::OnUpdateUIPasteBitmap)
|
EVT_UPDATE_UI(Menu_PasteBitmap, DnDFrame::OnUpdateUIPasteBitmap)
|
||||||
@ -702,6 +706,8 @@ DnDFrame::DnDFrame(wxFrame *frame, char *title, int x, int y, int w, int h)
|
|||||||
clip_menu->AppendSeparator();
|
clip_menu->AppendSeparator();
|
||||||
clip_menu->Append(Menu_CopyBitmap, "&Copy bitmap\tAlt+C");
|
clip_menu->Append(Menu_CopyBitmap, "&Copy bitmap\tAlt+C");
|
||||||
clip_menu->Append(Menu_PasteBitmap, "&Paste bitmap\tAlt+V");
|
clip_menu->Append(Menu_PasteBitmap, "&Paste bitmap\tAlt+V");
|
||||||
|
clip_menu->AppendSeparator();
|
||||||
|
clip_menu->Append(Menu_CopyFiles, "&Copy files\tCtrl+F");
|
||||||
|
|
||||||
wxMenuBar *menu_bar = new wxMenuBar;
|
wxMenuBar *menu_bar = new wxMenuBar;
|
||||||
menu_bar->Append(file_menu, "&File");
|
menu_bar->Append(file_menu, "&File");
|
||||||
@ -897,18 +903,13 @@ void DnDFrame::OnLeftDown(wxMouseEvent &WXUNUSED(event) )
|
|||||||
|
|
||||||
void DnDFrame::OnRightDown(wxMouseEvent &event )
|
void DnDFrame::OnRightDown(wxMouseEvent &event )
|
||||||
{
|
{
|
||||||
wxMenu *menu = new wxMenu;
|
wxMenu menu("Dnd sample menu");
|
||||||
|
|
||||||
menu->Append(Menu_Drag, "&Test drag...");
|
menu.Append(Menu_Drag, "&Test drag...");
|
||||||
menu->Append(Menu_About, "&About");
|
menu.AppendSeparator();
|
||||||
menu->Append(Menu_Quit, "E&xit");
|
menu.Append(Menu_About, "&About");
|
||||||
menu->Append(Menu_ToBeDeleted, "To be deleted");
|
|
||||||
menu->Append(Menu_ToBeGreyed, "To be greyed");
|
|
||||||
|
|
||||||
menu->Delete( Menu_ToBeDeleted );
|
PopupMenu( &menu, event.GetX(), event.GetY() );
|
||||||
menu->Enable( Menu_ToBeGreyed, FALSE );
|
|
||||||
|
|
||||||
PopupMenu( menu, event.GetX(), event.GetY() );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DnDFrame::~DnDFrame()
|
DnDFrame::~DnDFrame()
|
||||||
@ -1024,6 +1025,50 @@ void DnDFrame::OnPasteBitmap(wxCommandEvent& WXUNUSED(event))
|
|||||||
wxTheClipboard->Close();
|
wxTheClipboard->Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// file clipboard
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void DnDFrame::OnCopyFiles(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
#ifdef __WXMSW__
|
||||||
|
wxFileDataObject *dobj = new wxFileDataObject;
|
||||||
|
|
||||||
|
wxFileDialog dialog(this, "Select a file to copy", "", "",
|
||||||
|
"All files (*.*)|*.*", 0);
|
||||||
|
|
||||||
|
if ( dialog.ShowModal() == wxID_OK )
|
||||||
|
{
|
||||||
|
wxString filename = dialog.GetPath();
|
||||||
|
dobj->AddFile(filename);
|
||||||
|
|
||||||
|
wxClipboardLocker locker;
|
||||||
|
if ( !locker )
|
||||||
|
{
|
||||||
|
wxLogError("Can't open clipboard");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( !wxTheClipboard->AddData(dobj) )
|
||||||
|
{
|
||||||
|
wxLogError("Can't copy file to the clipboard");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wxLogStatus(this, "File '%s' copied to the clipboard",
|
||||||
|
filename.c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wxLogStatus(this, "Aborted");
|
||||||
|
}
|
||||||
|
#else // !MSW
|
||||||
|
wxLogError("Sorry, not implemented");
|
||||||
|
#endif // MSW/!MSW
|
||||||
|
}
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
// text clipboard
|
// text clipboard
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
|
@ -483,7 +483,9 @@ bool wxClipboard::IsOpened() const
|
|||||||
|
|
||||||
bool wxClipboard::SetData( wxDataObject *data )
|
bool wxClipboard::SetData( wxDataObject *data )
|
||||||
{
|
{
|
||||||
|
#if !wxUSE_OLE_CLIPBOARD
|
||||||
(void)wxEmptyClipboard();
|
(void)wxEmptyClipboard();
|
||||||
|
#endif // wxUSE_OLE_CLIPBOARD
|
||||||
|
|
||||||
if ( data )
|
if ( data )
|
||||||
return AddData(data);
|
return AddData(data);
|
||||||
|
@ -433,6 +433,19 @@ STDMETHODIMP wxIDataObject::SetData(FORMATETC *pformatetc,
|
|||||||
|
|
||||||
case TYMED_HGLOBAL:
|
case TYMED_HGLOBAL:
|
||||||
{
|
{
|
||||||
|
wxDataFormat format = pformatetc->cfFormat;
|
||||||
|
|
||||||
|
// this is quite weird, but for file drag and drop, explorer
|
||||||
|
// calls our SetData() with the formats we do *not* support!
|
||||||
|
//
|
||||||
|
// as we can't fix this bug in explorer (it's a bug because it
|
||||||
|
// should only use formats returned by EnumFormatEtc), do the
|
||||||
|
// check here
|
||||||
|
if ( !m_pDataObject->IsSupportedFormat(format) ) {
|
||||||
|
// go away!
|
||||||
|
return DV_E_FORMATETC;
|
||||||
|
}
|
||||||
|
|
||||||
// copy data
|
// copy data
|
||||||
void *pBuf = GlobalLock(pmedium->hGlobal);
|
void *pBuf = GlobalLock(pmedium->hGlobal);
|
||||||
if ( pBuf == NULL ) {
|
if ( pBuf == NULL ) {
|
||||||
@ -447,7 +460,7 @@ STDMETHODIMP wxIDataObject::SetData(FORMATETC *pformatetc,
|
|||||||
// synthetise it for known formats and we suppose that all data
|
// synthetise it for known formats and we suppose that all data
|
||||||
// in custom formats starts with a DWORD containing the size
|
// in custom formats starts with a DWORD containing the size
|
||||||
size_t size;
|
size_t size;
|
||||||
switch ( pformatetc->cfFormat )
|
switch ( format )
|
||||||
{
|
{
|
||||||
case CF_TEXT:
|
case CF_TEXT:
|
||||||
case CF_OEMTEXT:
|
case CF_OEMTEXT:
|
||||||
@ -480,7 +493,6 @@ STDMETHODIMP wxIDataObject::SetData(FORMATETC *pformatetc,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
wxDataFormat format = pformatetc->cfFormat;
|
|
||||||
bool ok = m_pDataObject->SetData(format, size, pBuf);
|
bool ok = m_pDataObject->SetData(format, size, pBuf);
|
||||||
|
|
||||||
GlobalUnlock(pmedium->hGlobal);
|
GlobalUnlock(pmedium->hGlobal);
|
||||||
@ -928,6 +940,8 @@ bool wxFileDataObject::SetData(size_t WXUNUSED(size), const void *pData)
|
|||||||
// get number of files (magic value -1)
|
// get number of files (magic value -1)
|
||||||
UINT nFiles = ::DragQueryFile(hdrop, (unsigned)-1, NULL, 0u);
|
UINT nFiles = ::DragQueryFile(hdrop, (unsigned)-1, NULL, 0u);
|
||||||
|
|
||||||
|
wxCHECK_MSG ( nFiles != (UINT)-1, FALSE, wxT("wrong HDROP handle") );
|
||||||
|
|
||||||
// for each file get the length, allocate memory and then get the name
|
// for each file get the length, allocate memory and then get the name
|
||||||
wxString str;
|
wxString str;
|
||||||
UINT len, n;
|
UINT len, n;
|
||||||
|
Loading…
Reference in New Issue
Block a user