Add file drop functionality

Adds the ability to drag and drop files from windows in order to attempt
to execute them
This commit is contained in:
Leighton Hancock 2016-11-14 16:50:58 +13:00
parent f5168c5768
commit 524ba0c88c
7 changed files with 51 additions and 0 deletions

View File

@ -32,6 +32,7 @@ using xe::ui::KeyEvent;
using xe::ui::MenuItem; using xe::ui::MenuItem;
using xe::ui::MouseEvent; using xe::ui::MouseEvent;
using xe::ui::UIEvent; using xe::ui::UIEvent;
using xe::ui::FileDropEvent;
const std::wstring kBaseTitle = L"xenia"; const std::wstring kBaseTitle = L"xenia";
@ -81,6 +82,9 @@ bool EmulatorWindow::Initialize() {
}); });
loop_->on_quit.AddListener([this](UIEvent* e) { window_.reset(); }); loop_->on_quit.AddListener([this](UIEvent* e) { window_.reset(); });
window_->on_file_drop.AddListener(
[this](FileDropEvent* e) { FileDrop(e->filename()); });
window_->on_key_down.AddListener([this](KeyEvent* e) { window_->on_key_down.AddListener([this](KeyEvent* e) {
bool handled = true; bool handled = true;
switch (e->key_code()) { switch (e->key_code()) {
@ -257,6 +261,15 @@ bool EmulatorWindow::Initialize() {
return true; return true;
} }
void EmulatorWindow::FileDrop(wchar_t* filename) {
std::wstring path = filename;
auto result = emulator_->LaunchPath(path);
if (XFAILED(result)) {
// TODO: Display a message box.
XELOGE("Failed to launch target: %.8X", result);
}
}
void EmulatorWindow::FileOpen() { void EmulatorWindow::FileOpen() {
std::wstring path; std::wstring path;

View File

@ -42,6 +42,7 @@ class EmulatorWindow {
bool Initialize(); bool Initialize();
void FileDrop(wchar_t* filename);
void FileOpen(); void FileOpen();
void CheckHideCursor(); void CheckHideCursor();
void CpuTimeScalarReset(); void CpuTimeScalarReset();

View File

@ -26,6 +26,18 @@ class UIEvent {
Window* target_ = nullptr; Window* target_ = nullptr;
}; };
class FileDropEvent : public UIEvent {
public:
FileDropEvent(Window* target, wchar_t* filename)
: UIEvent(target), filename_(filename) {}
~FileDropEvent() override = default;
wchar_t* filename() const { return filename_; }
private:
wchar_t* filename_ = nullptr;
};
class KeyEvent : public UIEvent { class KeyEvent : public UIEvent {
public: public:
KeyEvent(Window* target, int key_code, int repeat_count, bool prev_state) KeyEvent(Window* target, int key_code, int repeat_count, bool prev_state)

View File

@ -213,6 +213,11 @@ void Window::OnPaint(UIEvent* e) {
} }
} }
void Window::OnFileDrop(FileDropEvent* e) {
on_file_drop(e);
ForEachListener([e](auto listener) { listener->OnFileDrop(e); });
}
void Window::OnVisible(UIEvent* e) { void Window::OnVisible(UIEvent* e) {
ForEachListener([e](auto listener) { listener->OnVisible(e); }); ForEachListener([e](auto listener) { listener->OnVisible(e); });
} }

View File

@ -102,6 +102,7 @@ class Window {
Delegate<UIEvent*> on_painting; Delegate<UIEvent*> on_painting;
Delegate<UIEvent*> on_paint; Delegate<UIEvent*> on_paint;
Delegate<UIEvent*> on_painted; Delegate<UIEvent*> on_painted;
Delegate<FileDropEvent*> on_file_drop;
Delegate<KeyEvent*> on_key_down; Delegate<KeyEvent*> on_key_down;
Delegate<KeyEvent*> on_key_up; Delegate<KeyEvent*> on_key_up;
@ -128,6 +129,7 @@ class Window {
virtual void OnResize(UIEvent* e); virtual void OnResize(UIEvent* e);
virtual void OnLayout(UIEvent* e); virtual void OnLayout(UIEvent* e);
virtual void OnPaint(UIEvent* e); virtual void OnPaint(UIEvent* e);
virtual void OnFileDrop(FileDropEvent* e);
virtual void OnVisible(UIEvent* e); virtual void OnVisible(UIEvent* e);
virtual void OnHidden(UIEvent* e); virtual void OnHidden(UIEvent* e);

View File

@ -31,6 +31,7 @@ class WindowListener {
virtual void OnPainting(UIEvent* e) {} virtual void OnPainting(UIEvent* e) {}
virtual void OnPaint(UIEvent* e) {} virtual void OnPaint(UIEvent* e) {}
virtual void OnPainted(UIEvent* e) {} virtual void OnPainted(UIEvent* e) {}
virtual void OnFileDrop(UIEvent* e) {}
virtual void OnVisible(UIEvent* e) {} virtual void OnVisible(UIEvent* e) {}
virtual void OnHidden(UIEvent* e) {} virtual void OnHidden(UIEvent* e) {}

View File

@ -101,6 +101,8 @@ bool Win32Window::OnCreate() {
// Enable DWM elevation. // Enable DWM elevation.
EnableMMCSS(); EnableMMCSS();
// Enable file dragging from external sources
DragAcceptFiles(hwnd_, true);
ShowWindow(hwnd_, SW_SHOWNORMAL); ShowWindow(hwnd_, SW_SHOWNORMAL);
UpdateWindow(hwnd_); UpdateWindow(hwnd_);
@ -378,6 +380,21 @@ LRESULT Win32Window::WndProc(HWND hWnd, UINT message, WPARAM wParam,
} }
switch (message) { switch (message) {
case WM_DROPFILES: {
TCHAR lpszFile[MAX_PATH] = {0};
UINT uFiles = 0;
HDROP hDrop = (HDROP)wParam;
// Get number of files dropped
uFiles = DragQueryFile(hDrop, -1, NULL, NULL);
// Only getting first file dropped (other files ignored)
if (DragQueryFile(hDrop, 0, lpszFile, MAX_PATH)) {
auto e = FileDropEvent(this, lpszFile);
OnFileDrop(&e);
}
DragFinish(hDrop);
} break;
case WM_NCCREATE: case WM_NCCREATE:
break; break;
case WM_CREATE: case WM_CREATE: