mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-01-23 07:50:44 +01:00
Fix bug when dragging to a window before mouse events have been detected (issue #262).
git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@256 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
This commit is contained in:
parent
02d6f3e384
commit
2a0299fc29
@ -59,6 +59,7 @@ DWORD WebDropTarget::OnDragEnter(IDataObject* data_object,
|
||||
POINT cursor_position,
|
||||
DWORD effects) {
|
||||
current_wvh_ = _Context->current_webviewhost();
|
||||
DCHECK(current_wvh_);
|
||||
|
||||
// TODO(tc): PopulateWebDropData can be slow depending on what is in the
|
||||
// IDataObject. Maybe we can do this in a background thread.
|
||||
|
@ -56,9 +56,7 @@ class WebViewHost : public WebWidgetHost {
|
||||
WebViewHost();
|
||||
|
||||
#if defined(OS_WIN)
|
||||
virtual bool WndProc(UINT message, WPARAM wparam, LPARAM lparam) {
|
||||
return false;
|
||||
}
|
||||
virtual bool WndProc(UINT message, WPARAM wparam, LPARAM lparam);
|
||||
virtual void MouseEvent(UINT message, WPARAM wparam, LPARAM lparam);
|
||||
#endif
|
||||
|
||||
|
@ -64,6 +64,17 @@ WebView* WebViewHost::webview() const {
|
||||
return static_cast<WebView*>(webwidget_);
|
||||
}
|
||||
|
||||
bool WebViewHost::WndProc(UINT message, WPARAM wparam, LPARAM lparam) {
|
||||
switch (message) {
|
||||
case WM_SETFOCUS:
|
||||
// Set the current WebViewHost in case a drag action is started before mouse
|
||||
// events are detected for the window.
|
||||
_Context->set_current_webviewhost(this);
|
||||
break;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void WebViewHost::MouseEvent(UINT message, WPARAM wparam, LPARAM lparam) {
|
||||
_Context->set_current_webviewhost(this);
|
||||
WebWidgetHost::MouseEvent(message, wparam, lparam);
|
||||
|
Loading…
Reference in New Issue
Block a user