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:
Vadim Zeitlin 1999-11-03 00:32:11 +00:00
parent c03648c251
commit 51edda6af0
3 changed files with 75 additions and 14 deletions

View File

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

View File

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

View File

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