diff options
author | Jocelyn Turcotte <jocelyn.turcotte@digia.com> | 2013-06-19 13:47:04 +0200 |
---|---|---|
committer | Jocelyn Turcotte <jocelyn.turcotte@digia.com> | 2013-06-19 13:47:04 +0200 |
commit | 90022906e060ae0dc8ad60b5770b3b23ffd6cde1 (patch) | |
tree | 48544460bc71732cf2e30bc190125b5a1a531f0a /lib | |
parent | eb530b3752e1af68956feaa833e5b86b1e49e2e1 (diff) |
Move API layer-only classes back from the shared static lib.
Since ContentBrowserClientQt::OverrideCreateWebContentsView now
takes care of using our Qt layer at runtime without relying on
the static RenderWidgetHostView::CreateViewForWidget, we can
now avoid linking this layer into the render process.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/backing_store_qt.cpp | 143 | ||||
-rw-r--r-- | lib/backing_store_qt.h | 69 | ||||
-rw-r--r-- | lib/lib.pro | 11 | ||||
-rw-r--r-- | lib/render_widget_host_view_qt.cpp | 469 | ||||
-rw-r--r-- | lib/render_widget_host_view_qt.h | 148 | ||||
-rw-r--r-- | lib/render_widget_host_view_qt_delegate.h | 19 | ||||
-rw-r--r-- | lib/render_widget_host_view_qt_delegate_quick.cpp | 4 | ||||
-rw-r--r-- | lib/render_widget_host_view_qt_delegate_quick.h | 2 | ||||
-rw-r--r-- | lib/render_widget_host_view_qt_delegate_widget.cpp | 4 | ||||
-rw-r--r-- | lib/render_widget_host_view_qt_delegate_widget.h | 2 | ||||
-rw-r--r-- | lib/web_contents_view_qt.h | 2 | ||||
-rw-r--r-- | lib/web_event_factory.cpp | 600 | ||||
-rw-r--r-- | lib/web_event_factory.h | 61 |
13 files changed, 1525 insertions, 9 deletions
diff --git a/lib/backing_store_qt.cpp b/lib/backing_store_qt.cpp new file mode 100644 index 000000000..cee0d093e --- /dev/null +++ b/lib/backing_store_qt.cpp @@ -0,0 +1,143 @@ +/**************************************************************************** +** +** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/legal +** +** This file is part of the QtWebEngine module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and Digia. For licensing terms and +** conditions see http://qt.digia.com/licensing. For further information +** use the contact form at http://qt.digia.com/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Digia gives you certain additional +** rights. These rights are described in the Digia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include "backing_store_qt.h" + +#include "content/browser/renderer_host/render_widget_host_impl.h" +#include "content/public/browser/render_process_host.h" +#include "ui/gfx/rect.h" +#include "ui/gfx/rect_conversions.h" + +#include <QPainter> + +BackingStoreQt::BackingStoreQt(content::RenderWidgetHost *host, const gfx::Size &size, QWindow* parent) + : content::BackingStore(host, size) + , m_pixelBuffer(size.width(), size.height()) +{ +} + +BackingStoreQt::~BackingStoreQt() +{ +} + +void BackingStoreQt::paintToTarget(QPainter* painter, const QRectF& rect) +{ + if (m_pixelBuffer.isNull()) + return; + painter->drawPixmap(rect, m_pixelBuffer, rect); +} + +void BackingStoreQt::PaintToBackingStore(content::RenderProcessHost *process, + TransportDIB::Id bitmap, + const gfx::Rect &bitmap_rect, + const std::vector<gfx::Rect> ©_rects, + float scale_factor, + const base::Closure &completion_callback, + bool *scheduled_completion_callback) +{ + if (bitmap_rect.IsEmpty()) + return; + + *scheduled_completion_callback = false; + TransportDIB* dib = process->GetTransportDIB(bitmap); + if (!dib) + return; + + gfx::Rect pixel_bitmap_rect = bitmap_rect; + + uint8_t* bitmapData = static_cast<uint8_t*>(dib->memory()); + int width = m_pixelBuffer.size().width(); + int height = m_pixelBuffer.size().height(); + const QImage img(bitmapData, pixel_bitmap_rect.width(), pixel_bitmap_rect.height(), QImage::Format_ARGB32); + + QPainter painter(&m_pixelBuffer); + + for (size_t i = 0; i < copy_rects.size(); ++i) { + gfx::Rect copy_rect = gfx::ToEnclosedRect(gfx::ScaleRect(copy_rects[i], scale_factor)); + + QRect source = QRect( copy_rect.x() - pixel_bitmap_rect.x() + , copy_rect.y() - pixel_bitmap_rect.y() + , copy_rect.width() + , copy_rect.height()); + + QRect destination = QRect( copy_rect.x() + , copy_rect.y() + , copy_rect.width() + , copy_rect.height()); + + painter.drawImage(destination, img, source); + } +} + +void BackingStoreQt::ScrollBackingStore(const gfx::Vector2d &delta, const gfx::Rect &clip_rect, const gfx::Size &view_size) +{ + DCHECK(delta.x() == 0 || delta.y() == 0); + + m_pixelBuffer.scroll(delta.x(), delta.y(), clip_rect.x(), clip_rect.y(), clip_rect.width(), clip_rect.height()); +} + +bool BackingStoreQt::CopyFromBackingStore(const gfx::Rect &rect, skia::PlatformBitmap *output) +{ + // const int width = std::min(m_pixelBuffer.width(), rect.width()); + // const int height = std::min(m_pixelBuffer.height(), rect.height()); + + // if (!output->Allocate(width, height, true)) + // return false; + + // // This code assumes a visual mode where a pixel is + // // represented using a 32-bit unsigned int, with a byte per component. + // const SkBitmap& bitmap = output->GetBitmap(); + // SkAutoLockPixels alp(bitmap); + + // QPixmap cpy = m_pixelBuffer.copy(rect.x(), rect.y(), rect.width(), rect.height()); + // QImage img = cpy.toImage(); + + // // Convert the format and remove transparency. + // if (img.format() != QImage::Format_RGB32) + // img = img.convertToFormat(QImage::Format_RGB32); + + // const uint8_t* src = img.bits(); + // uint8_t* dst = reinterpret_cast<uint8_t*>(bitmap.getAddr32(0,0)); + // memcpy(dst, src, width*height*32); + + // return true; +} + diff --git a/lib/backing_store_qt.h b/lib/backing_store_qt.h new file mode 100644 index 000000000..d2fa52f38 --- /dev/null +++ b/lib/backing_store_qt.h @@ -0,0 +1,69 @@ +/**************************************************************************** +** +** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/legal +** +** This file is part of the QtWebEngine module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and Digia. For licensing terms and +** conditions see http://qt.digia.com/licensing. For further information +** use the contact form at http://qt.digia.com/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Digia gives you certain additional +** rights. These rights are described in the Digia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#ifndef CONTENT_BROWSER_RENDERER_HOST_BACKING_STORE_QT_H_ +#define CONTENT_BROWSER_RENDERER_HOST_BACKING_STORE_QT_H_ + +#include "content/browser/renderer_host/backing_store.h" + +#include <QPainter> +#include <QPixmap> + +class BackingStoreQt : public content::BackingStore +{ +public: + BackingStoreQt(content::RenderWidgetHost *host, const gfx::Size &size, QWindow* parent); + ~BackingStoreQt(); + + void paintToTarget(QPainter*, const QRectF& rect); + + virtual void PaintToBackingStore(content::RenderProcessHost *process, TransportDIB::Id bitmap, const gfx::Rect &bitmap_rect, + const std::vector<gfx::Rect> ©_rects, float scale_factor, const base::Closure &completion_callback, + bool *scheduled_completion_callback); + + virtual void ScrollBackingStore(const gfx::Vector2d &delta, const gfx::Rect &clip_rect, const gfx::Size &view_size); + virtual bool CopyFromBackingStore(const gfx::Rect &rect, skia::PlatformBitmap *output); + +private: + QPixmap m_pixelBuffer; +}; + +#endif diff --git a/lib/lib.pro b/lib/lib.pro index e4f75a65c..5f2507bbe 100644 --- a/lib/lib.pro +++ b/lib/lib.pro @@ -20,27 +20,34 @@ CONFIG(release, debug|release): DEFINES += NDEBUG QT += widgets quick SOURCES = \ + backing_store_qt.cpp \ content_browser_client_qt.cpp \ qquickwebcontentsview.cpp \ qwebcontentsview.cpp \ + render_widget_host_view_qt.cpp \ render_widget_host_view_qt_delegate_quick.cpp \ render_widget_host_view_qt_delegate_widget.cpp \ resource_context_qt.cpp \ url_request_context_getter_qt.cpp \ web_contents_delegate_qt.cpp \ - web_engine_context.cpp + web_engine_context.cpp \ + web_event_factory.cpp HEADERS = \ + backing_store_qt.h \ browser_context_qt.h \ content_browser_client_qt.h \ qquickwebcontentsview.h \ qwebcontentsview.h \ qwebcontentsview_p.h \ + render_widget_host_view_qt.h \ + render_widget_host_view_qt_delegate.h \ render_widget_host_view_qt_delegate_quick.h \ render_widget_host_view_qt_delegate_widget.h \ resource_context_qt.h \ url_request_context_getter_qt.h \ web_contents_delegate_qt.h \ web_contents_view_qt.h \ - web_engine_context.h + web_engine_context.h \ + web_event_factory.h diff --git a/lib/render_widget_host_view_qt.cpp b/lib/render_widget_host_view_qt.cpp new file mode 100644 index 000000000..2d21410d0 --- /dev/null +++ b/lib/render_widget_host_view_qt.cpp @@ -0,0 +1,469 @@ +/**************************************************************************** +** +** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/legal +** +** This file is part of the QtWebEngine module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and Digia. For licensing terms and +** conditions see http://qt.digia.com/licensing. For further information +** use the contact form at http://qt.digia.com/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Digia gives you certain additional +** rights. These rights are described in the Digia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include "render_widget_host_view_qt.h" + +#include "backing_store_qt.h" +#include "render_widget_host_view_qt_delegate.h" +#include "web_event_factory.h" + +#include "shared/shared_globals.h" + +#include "content/browser/renderer_host/render_view_host_impl.h" +#include "content/common/gpu/gpu_messages.h" + +#include <QEvent> +#include <QFocusEvent> +#include <QKeyEvent> +#include <QMouseEvent> +#include <QWheelEvent> +#include <QWindow> + +namespace content { + +RenderWidgetHostViewQt::RenderWidgetHostViewQt(content::RenderWidgetHost* widget) + : m_host(content::RenderWidgetHostImpl::From(widget)) + , m_delegate(0) +{ + m_host->SetView(this); +} + +RenderWidgetHostViewQt::~RenderWidgetHostViewQt() +{ +} + +bool RenderWidgetHostViewQt::handleEvent(QEvent* event) { + + switch(event->type()) { + case QEvent::MouseButtonDblClick: + case QEvent::MouseButtonPress: + case QEvent::MouseButtonRelease: + case QEvent::MouseMove: + handleMouseEvent(static_cast<QMouseEvent*>(event)); + break; + case QEvent::KeyPress: + case QEvent::KeyRelease: + handleKeyEvent(static_cast<QKeyEvent*>(event)); + break; + case QEvent::Wheel: + handleWheelEvent(static_cast<QWheelEvent*>(event)); + break; + case QEvent::FocusIn: + case QEvent::FocusOut: + handleFocusEvent(static_cast<QFocusEvent*>(event)); + break; + default: + return false; + } + return true; +} + +BackingStoreQt* RenderWidgetHostViewQt::GetBackingStore() +{ + bool force_create = !m_host->empty(); + return static_cast<BackingStoreQt*>(m_host->GetBackingStore(force_create)); +} + +content::BackingStore *RenderWidgetHostViewQt::AllocBackingStore(const gfx::Size &size) +{ + return new BackingStoreQt(m_host, size, new QWindow); +} + +void RenderWidgetHostViewQt::InitAsChild(gfx::NativeView parent_view) +{ +} + +void RenderWidgetHostViewQt::InitAsPopup(content::RenderWidgetHostView*, const gfx::Rect&) +{ +} + +void RenderWidgetHostViewQt::InitAsFullscreen(content::RenderWidgetHostView*) +{ +} + +content::RenderWidgetHost* RenderWidgetHostViewQt::GetRenderWidgetHost() const +{ + return m_host; +} + +void RenderWidgetHostViewQt::SetSize(const gfx::Size& size) +{ + int width = size.width(); + int height = size.height(); + // int width = std::min(size.width(), kMaxWindowWidth); + // int height = std::min(size.height(), kMaxWindowHeight); + // if (IsPopup()) + // m_delegate->resize(width,height); + + if (m_requestedSize.width() != width || + m_requestedSize.height() != height) { + m_requestedSize = gfx::Size(width, height); + // m_host->SendScreenRects(); + m_host->WasResized(); + } +} + +void RenderWidgetHostViewQt::SetBounds(const gfx::Rect& rect) +{ + // This is called when webkit has sent us a Move message. + // if (IsPopup()) + // m_delegate->setGeometry(rect.x(), rect.y(), rect.width(), rect.height()); + SetSize(rect.size()); +} + +// FIXME: Should this really return a QWindow pointer? +gfx::NativeView RenderWidgetHostViewQt::GetNativeView() const +{ + QT_NOT_YET_IMPLEMENTED + return gfx::NativeView(); +} + +gfx::NativeViewId RenderWidgetHostViewQt::GetNativeViewId() const +{ + QT_NOT_YET_IMPLEMENTED + return gfx::NativeViewId(); +} + +gfx::NativeViewAccessible RenderWidgetHostViewQt::GetNativeViewAccessible() +{ + NOTIMPLEMENTED(); + return NULL; +} + +// Set focus to the associated View component. +void RenderWidgetHostViewQt::Focus() +{ + // m_delegate->setFocus(Qt::MouseFocusReason); +} + +bool RenderWidgetHostViewQt::HasFocus() const +{ + // return m_delegate->hasFocus(); + return true; +} + +bool RenderWidgetHostViewQt::IsSurfaceAvailableForCopy() const +{ + return true; +} + +void RenderWidgetHostViewQt::Show() +{ + m_delegate->show(); +} + +void RenderWidgetHostViewQt::Hide() +{ + m_delegate->hide(); +} + +bool RenderWidgetHostViewQt::IsShowing() +{ + return m_delegate->isVisible(); +} + +// Retrieve the bounds of the View, in screen coordinates. +gfx::Rect RenderWidgetHostViewQt::GetViewBounds() const +{ + QRectF p = m_delegate->screenRect(); + return gfx::Rect(p.x(), p.y(), p.width(), p.height()); +} + +// Subclasses should override this method to do what is appropriate to set +// the custom background for their platform. +void RenderWidgetHostViewQt::SetBackground(const SkBitmap& background) +{ + RenderWidgetHostViewBase::SetBackground(background); + // Send(new ViewMsg_SetBackground(m_host->GetRoutingID(), background)); +} + +// Return value indicates whether the mouse is locked successfully or not. +bool RenderWidgetHostViewQt::LockMouse() +{ + QT_NOT_YET_IMPLEMENTED + return false; +} +void RenderWidgetHostViewQt::UnlockMouse() +{ + QT_NOT_YET_IMPLEMENTED +} + +// Returns true if the mouse pointer is currently locked. +bool RenderWidgetHostViewQt::IsMouseLocked() +{ + QT_NOT_YET_IMPLEMENTED + return false; +} + +// FIXME: remove TOOLKIT_GTK related things. +#if defined(TOOLKIT_GTK) +// Gets the event for the last mouse down. +GdkEventButton* RenderWidgetHostViewQt::GetLastMouseDown() +{ + return 0; +} + +gfx::NativeView RenderWidgetHostViewQt::BuildInputMethodsGtkMenu() +{ +} +#endif // defined(TOOLKIT_GTK) + +void RenderWidgetHostViewQt::WasShown() +{ + if (m_delegate->isVisible()) + return; + + m_host->WasShown(); +} + +void RenderWidgetHostViewQt::WasHidden() +{ + if (!m_delegate->isVisible()) + return; + + m_host->WasHidden(); +} + +void RenderWidgetHostViewQt::MovePluginWindows(const gfx::Vector2d&, const std::vector<webkit::npapi::WebPluginGeometry>&) +{ + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::Blur() +{ + m_host->Blur(); +} + +void RenderWidgetHostViewQt::UpdateCursor(const WebCursor&) +{ + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::SetIsLoading(bool) +{ + QT_NOT_YET_IMPLEMENTED + // Give visual feedback for loading process. +} + +void RenderWidgetHostViewQt::TextInputStateChanged(const ViewHostMsg_TextInputState_Params&) +{ + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::ImeCancelComposition() +{ + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::ImeCompositionRangeChanged(const ui::Range&, const std::vector<gfx::Rect>&) +{ + // FIXME: not implemented? + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::DidUpdateBackingStore(const gfx::Rect& scroll_rect, const gfx::Vector2d& scroll_delta, const std::vector<gfx::Rect>& copy_rects) +{ + if (!m_delegate->isVisible()) + return; + + Paint(scroll_rect); + + for (size_t i = 0; i < copy_rects.size(); ++i) { + gfx::Rect rect = gfx::SubtractRects(copy_rects[i], scroll_rect); + if (rect.IsEmpty()) + continue; + Paint(rect); + } +} + +void RenderWidgetHostViewQt::RenderViewGone(base::TerminationStatus, int) +{ + Destroy(); +} + +void RenderWidgetHostViewQt::Destroy() +{ + delete m_delegate; + m_delegate = 0; +} + +void RenderWidgetHostViewQt::SetTooltipText(const string16&) +{ + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::SelectionBoundsChanged(const ViewHostMsg_SelectionBounds_Params&) +{ + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::ScrollOffsetChanged() +{ + // FIXME: not implemented? +} + +void RenderWidgetHostViewQt::CopyFromCompositingSurface(const gfx::Rect& src_subrect, const gfx::Size& /* dst_size */, const base::Callback<void(bool, const SkBitmap&)>& callback) +{ + // Grab the snapshot from the renderer as that's the only reliable way to + // readback from the GPU for this platform right now. + // FIXME: is this true? + GetRenderWidgetHost()->GetSnapshotFromRenderer(src_subrect, callback); +} + +void RenderWidgetHostViewQt::CopyFromCompositingSurfaceToVideoFrame(const gfx::Rect& src_subrect, const scoped_refptr<media::VideoFrame>& target, const base::Callback<void(bool)>& callback) +{ + NOTIMPLEMENTED(); + callback.Run(false); +} + +bool RenderWidgetHostViewQt::CanCopyToVideoFrame() const +{ + return false; +} + +void RenderWidgetHostViewQt::OnAcceleratedCompositingStateChange() +{ + // bool activated = m_host->is_accelerated_compositing_active(); + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::AcceleratedSurfaceBuffersSwapped(const GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params& params, int gpu_host_id) +{ + AcceleratedSurfaceMsg_BufferPresented_Params ack_params; + ack_params.sync_point = 0; + content::RenderWidgetHostImpl::AcknowledgeBufferPresent(params.route_id, gpu_host_id, ack_params); +} + +void RenderWidgetHostViewQt::AcceleratedSurfacePostSubBuffer(const GpuHostMsg_AcceleratedSurfacePostSubBuffer_Params& params, int gpu_host_id) +{ + AcceleratedSurfaceMsg_BufferPresented_Params ack_params; + ack_params.sync_point = 0; + content::RenderWidgetHostImpl::AcknowledgeBufferPresent(params.route_id, gpu_host_id, ack_params); +} + +void RenderWidgetHostViewQt::AcceleratedSurfaceSuspend() +{ + //FIXME: not implemented? +} + +void RenderWidgetHostViewQt::AcceleratedSurfaceRelease() +{ + //FIXME: not implemented? +} + +bool RenderWidgetHostViewQt::HasAcceleratedSurface(const gfx::Size&) +{ + return false; +} + +void RenderWidgetHostViewQt::GetScreenInfo(WebKit::WebScreenInfo* results) +{ + QWindow* window = m_delegate->window(); + if (!window) + return; + GetScreenInfoFromNativeWindow(window, results); +} + +gfx::Rect RenderWidgetHostViewQt::GetBoundsInRootWindow() +{ + if (!m_delegate->window()) + return gfx::Rect(); + + QRect r = m_delegate->window()->frameGeometry(); + return gfx::Rect(r.x(), r.y(), r.width(), r.height()); +} + +gfx::GLSurfaceHandle RenderWidgetHostViewQt::GetCompositingSurface() +{ + QT_NOT_YET_IMPLEMENTED + return gfx::GLSurfaceHandle(); +} + +void RenderWidgetHostViewQt::SetHasHorizontalScrollbar(bool) { } + +void RenderWidgetHostViewQt::SetScrollOffsetPinning(bool, bool) { } + +void RenderWidgetHostViewQt::OnAccessibilityNotifications(const std::vector<AccessibilityHostMsg_NotificationParams>&) +{ + QT_NOT_YET_IMPLEMENTED +} + +void RenderWidgetHostViewQt::Paint(const gfx::Rect& damage_rect) +{ + QRect r(damage_rect.x(), damage_rect.y(), damage_rect.width(), damage_rect.height()); + m_delegate->update(r); +} + +bool RenderWidgetHostViewQt::IsPopup() const +{ + return popup_type_ != WebKit::WebPopupTypeNone; +} + +void RenderWidgetHostViewQt::handleMouseEvent(QMouseEvent* ev) +{ + m_host->ForwardMouseEvent(WebEventFactory::toWebMouseEvent(ev)); +} + +void RenderWidgetHostViewQt::handleKeyEvent(QKeyEvent *ev) +{ + m_host->ForwardKeyboardEvent(WebEventFactory::toWebKeyboardEvent(ev)); +} + +void RenderWidgetHostViewQt::handleWheelEvent(QWheelEvent *ev) +{ + m_host->ForwardWheelEvent(WebEventFactory::toWebWheelEvent(ev)); +} + +void RenderWidgetHostViewQt::handleFocusEvent(QFocusEvent *ev) +{ + if (ev->gotFocus()) { + m_host->GotFocus(); + m_host->SetActive(true); + ev->accept(); + } else if (ev->lostFocus()) { + m_host->SetActive(false); + m_host->Blur(); + ev->accept(); + } +} + +} + diff --git a/lib/render_widget_host_view_qt.h b/lib/render_widget_host_view_qt.h new file mode 100644 index 000000000..9ff200c32 --- /dev/null +++ b/lib/render_widget_host_view_qt.h @@ -0,0 +1,148 @@ +/**************************************************************************** +** +** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/legal +** +** This file is part of the QtWebEngine module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and Digia. For licensing terms and +** conditions see http://qt.digia.com/licensing. For further information +** use the contact form at http://qt.digia.com/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Digia gives you certain additional +** rights. These rights are described in the Digia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#ifndef CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_QT_H_ +#define CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_QT_H_ + +#include "content/browser/renderer_host/render_widget_host_view_base.h" +#include <qglobal.h> + +#ifdef QT_WEBENGINE_LOGGING +#define QT_NOT_YET_IMPLEMENTED fprintf(stderr, "function %s not implemented! - %s:%d\n", __func__, __FILE__, __LINE__); +#else +#define QT_NOT_YET_IMPLEMENTED qt_noop(); +#endif + +class BackingStoreQt; +class QEvent; +class QFocusEvent; +class QKeyEvent; +class QMouseEvent; +class QWheelEvent; +class RenderWidgetHostViewQtDelegate; + +namespace content { + +class RenderWidgetHostViewQt + : public content::RenderWidgetHostViewBase +{ +public: + RenderWidgetHostViewQt(content::RenderWidgetHost* widget); + ~RenderWidgetHostViewQt(); + + void SetDelegate(RenderWidgetHostViewQtDelegate* delegate) { m_delegate = delegate; } + bool handleEvent(QEvent* event); + BackingStoreQt* GetBackingStore(); + + virtual content::BackingStore *AllocBackingStore(const gfx::Size &size); + + virtual void InitAsChild(gfx::NativeView parent_view); + virtual void InitAsPopup(content::RenderWidgetHostView*, const gfx::Rect&); + virtual void InitAsFullscreen(content::RenderWidgetHostView*); + virtual content::RenderWidgetHost* GetRenderWidgetHost() const; + virtual void SetSize(const gfx::Size& size); + virtual void SetBounds(const gfx::Rect& rect); + virtual gfx::NativeView GetNativeView() const; + virtual gfx::NativeViewId GetNativeViewId() const; + virtual gfx::NativeViewAccessible GetNativeViewAccessible(); + virtual void Focus(); + virtual bool HasFocus() const; + virtual bool IsSurfaceAvailableForCopy() const; + virtual void Show(); + virtual void Hide(); + virtual bool IsShowing(); + virtual gfx::Rect GetViewBounds() const; + virtual void SetBackground(const SkBitmap& background); + virtual bool LockMouse(); + virtual void UnlockMouse(); + virtual bool IsMouseLocked(); +#if defined(TOOLKIT_GTK) + virtual GdkEventButton* GetLastMouseDown(); + virtual gfx::NativeView BuildInputMethodsGtkMenu(); +#endif // defined(TOOLKIT_GTK) + virtual void WasShown(); + virtual void WasHidden(); + virtual void MovePluginWindows(const gfx::Vector2d&, const std::vector<webkit::npapi::WebPluginGeometry>&); + virtual void Blur(); + virtual void UpdateCursor(const WebCursor&); + virtual void SetIsLoading(bool); + virtual void TextInputStateChanged(const ViewHostMsg_TextInputState_Params&); + virtual void ImeCancelComposition(); + virtual void ImeCompositionRangeChanged(const ui::Range&, const std::vector<gfx::Rect>&); + virtual void DidUpdateBackingStore(const gfx::Rect& scroll_rect, const gfx::Vector2d& scroll_delta, const std::vector<gfx::Rect>& copy_rects); + virtual void RenderViewGone(base::TerminationStatus, int); + virtual void Destroy(); + virtual void SetTooltipText(const string16&); + virtual void SelectionBoundsChanged(const ViewHostMsg_SelectionBounds_Params&); + virtual void ScrollOffsetChanged(); + virtual void CopyFromCompositingSurface(const gfx::Rect& src_subrect, const gfx::Size& /* dst_size */, const base::Callback<void(bool, const SkBitmap&)>& callback); + virtual void CopyFromCompositingSurfaceToVideoFrame(const gfx::Rect& src_subrect, const scoped_refptr<media::VideoFrame>& target, const base::Callback<void(bool)>& callback); + virtual bool CanCopyToVideoFrame() const; + virtual void OnAcceleratedCompositingStateChange(); + virtual void AcceleratedSurfaceBuffersSwapped(const GpuHostMsg_AcceleratedSurfaceBuffersSwapped_Params& params, int gpu_host_id); + virtual void AcceleratedSurfacePostSubBuffer(const GpuHostMsg_AcceleratedSurfacePostSubBuffer_Params& params, int gpu_host_id); + virtual void AcceleratedSurfaceSuspend(); + virtual void AcceleratedSurfaceRelease(); + virtual bool HasAcceleratedSurface(const gfx::Size&); + virtual void GetScreenInfo(WebKit::WebScreenInfo* results); + virtual gfx::Rect GetBoundsInRootWindow(); + virtual gfx::GLSurfaceHandle GetCompositingSurface(); + virtual void SetHasHorizontalScrollbar(bool); + virtual void SetScrollOffsetPinning(bool, bool); + virtual void OnAccessibilityNotifications(const std::vector<AccessibilityHostMsg_NotificationParams>&); + + void handleMouseEvent(QMouseEvent*); + void handleKeyEvent(QKeyEvent*); + void handleWheelEvent(QWheelEvent*); + void handleFocusEvent(QFocusEvent*); +private: + void Paint(const gfx::Rect& damage_rect); + + bool IsPopup() const; + + content::RenderWidgetHostImpl *m_host; + RenderWidgetHostViewQtDelegate *m_delegate; + gfx::Size m_requestedSize; +}; + +} + +#endif diff --git a/lib/render_widget_host_view_qt_delegate.h b/lib/render_widget_host_view_qt_delegate.h new file mode 100644 index 000000000..7f147dae6 --- /dev/null +++ b/lib/render_widget_host_view_qt_delegate.h @@ -0,0 +1,19 @@ +#ifndef RENDER_WIDGET_HOST_VIEW_QT_DELEGATE_H +#define RENDER_WIDGET_HOST_VIEW_QT_DELEGATE_H + +#include <QRect> + +class QWindow; + +class RenderWidgetHostViewQtDelegate { +public: + virtual ~RenderWidgetHostViewQtDelegate() {} + virtual QRectF screenRect() const = 0; + virtual void show() = 0; + virtual void hide() = 0; + virtual bool isVisible() const = 0; + virtual QWindow* window() const = 0; + virtual void update(const QRect& rect = QRect()) = 0; +}; + +#endif diff --git a/lib/render_widget_host_view_qt_delegate_quick.cpp b/lib/render_widget_host_view_qt_delegate_quick.cpp index 13e4ef29f..c1b4c6627 100644 --- a/lib/render_widget_host_view_qt_delegate_quick.cpp +++ b/lib/render_widget_host_view_qt_delegate_quick.cpp @@ -1,7 +1,7 @@ #include "render_widget_host_view_qt_delegate_quick.h" -#include "shared/backing_store_qt.h" -#include "shared/render_widget_host_view_qt.h" +#include "backing_store_qt.h" +#include "render_widget_host_view_qt.h" #include "content/browser/renderer_host/render_view_host_impl.h" diff --git a/lib/render_widget_host_view_qt_delegate_quick.h b/lib/render_widget_host_view_qt_delegate_quick.h index 20bd263f8..9422a7eb4 100644 --- a/lib/render_widget_host_view_qt_delegate_quick.h +++ b/lib/render_widget_host_view_qt_delegate_quick.h @@ -1,7 +1,7 @@ #ifndef RENDER_WIDGET_HOST_VIEW_QT_DELEGATE_QUICK_H #define RENDER_WIDGET_HOST_VIEW_QT_DELEGATE_QUICK_H -#include "shared/render_widget_host_view_qt_delegate.h" +#include "render_widget_host_view_qt_delegate.h" #include <QQuickPaintedItem> diff --git a/lib/render_widget_host_view_qt_delegate_widget.cpp b/lib/render_widget_host_view_qt_delegate_widget.cpp index 9a659069f..fe093c6b6 100644 --- a/lib/render_widget_host_view_qt_delegate_widget.cpp +++ b/lib/render_widget_host_view_qt_delegate_widget.cpp @@ -1,7 +1,7 @@ #include "render_widget_host_view_qt_delegate_widget.h" -#include "shared/backing_store_qt.h" -#include "shared/render_widget_host_view_qt.h" +#include "backing_store_qt.h" +#include "render_widget_host_view_qt.h" #include "content/browser/renderer_host/render_view_host_impl.h" diff --git a/lib/render_widget_host_view_qt_delegate_widget.h b/lib/render_widget_host_view_qt_delegate_widget.h index f6da4f484..1cc894ce3 100644 --- a/lib/render_widget_host_view_qt_delegate_widget.h +++ b/lib/render_widget_host_view_qt_delegate_widget.h @@ -1,7 +1,7 @@ #ifndef RENDER_WIDGET_HOST_VIEW_QT_DELEGATE_WIDGET_H #define RENDER_WIDGET_HOST_VIEW_QT_DELEGATE_WIDGET_H -#include "shared/render_widget_host_view_qt_delegate.h" +#include "render_widget_host_view_qt_delegate.h" #include <QWidget> diff --git a/lib/web_contents_view_qt.h b/lib/web_contents_view_qt.h index d20f8fec6..08ffd4e78 100644 --- a/lib/web_contents_view_qt.h +++ b/lib/web_contents_view_qt.h @@ -48,7 +48,7 @@ #include "content/port/browser/render_view_host_delegate_view.h" #include "content/port/browser/web_contents_view_port.h" -#include "shared/render_widget_host_view_qt.h" +#include "render_widget_host_view_qt.h" class WebContentsViewQtClient { public: diff --git a/lib/web_event_factory.cpp b/lib/web_event_factory.cpp new file mode 100644 index 000000000..ed24c5b6d --- /dev/null +++ b/lib/web_event_factory.cpp @@ -0,0 +1,600 @@ +/**************************************************************************** +** +** Copyright (C) 2006 Nikolas Zimmermann <zimmermann@kde.org> +** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/legal +** +** This file is part of the QtWebEngine module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and Digia. For licensing terms and +** conditions see http://qt.digia.com/licensing. For further information +** use the contact form at http://qt.digia.com/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Digia gives you certain additional +** rights. These rights are described in the Digia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include "web_event_factory.h" +#include "third_party/WebKit/Source/core/platform/WindowsKeyboardCodes.h" + +#include <QMouseEvent> +#include <QKeyEvent> +#include <QElapsedTimer> +#include <QWheelEvent> +#include <QApplication> + +using namespace WebKit; + +static int windowsKeyCodeForKeyEvent(unsigned int keycode, bool isKeypad) +{ + // Determine wheter the event comes from the keypad + if (isKeypad) { + switch (keycode) { + case Qt::Key_0: + return VK_NUMPAD0; // (60) Numeric keypad 0 key + case Qt::Key_1: + return VK_NUMPAD1; // (61) Numeric keypad 1 key + case Qt::Key_2: + return VK_NUMPAD2; // (62) Numeric keypad 2 key + case Qt::Key_3: + return VK_NUMPAD3; // (63) Numeric keypad 3 key + case Qt::Key_4: + return VK_NUMPAD4; // (64) Numeric keypad 4 key + case Qt::Key_5: + return VK_NUMPAD5; // (65) Numeric keypad 5 key + case Qt::Key_6: + return VK_NUMPAD6; // (66) Numeric keypad 6 key + case Qt::Key_7: + return VK_NUMPAD7; // (67) Numeric keypad 7 key + case Qt::Key_8: + return VK_NUMPAD8; // (68) Numeric keypad 8 key + case Qt::Key_9: + return VK_NUMPAD9; // (69) Numeric keypad 9 key + case Qt::Key_Asterisk: + return VK_MULTIPLY; // (6A) Multiply key + case Qt::Key_Plus: + return VK_ADD; // (6B) Add key + case Qt::Key_Minus: + return VK_SUBTRACT; // (6D) Subtract key + case Qt::Key_Period: + return VK_DECIMAL; // (6E) Decimal key + case Qt::Key_Slash: + return VK_DIVIDE; // (6F) Divide key + case Qt::Key_PageUp: + return VK_PRIOR; // (21) PAGE UP key + case Qt::Key_PageDown: + return VK_NEXT; // (22) PAGE DOWN key + case Qt::Key_End: + return VK_END; // (23) END key + case Qt::Key_Home: + return VK_HOME; // (24) HOME key + case Qt::Key_Left: + return VK_LEFT; // (25) LEFT ARROW key + case Qt::Key_Up: + return VK_UP; // (26) UP ARROW key + case Qt::Key_Right: + return VK_RIGHT; // (27) RIGHT ARROW key + case Qt::Key_Down: + return VK_DOWN; // (28) DOWN ARROW key + case Qt::Key_Enter: + case Qt::Key_Return: + return VK_RETURN; // (0D) Return key + case Qt::Key_Insert: + return VK_INSERT; // (2D) INS key + case Qt::Key_Delete: + return VK_DELETE; // (2E) DEL key + default: + return 0; + } + + } else + + switch (keycode) { + case Qt::Key_Backspace: + return VK_BACK; // (08) BACKSPACE key + case Qt::Key_Backtab: + case Qt::Key_Tab: + return VK_TAB; // (09) TAB key + case Qt::Key_Clear: + return VK_CLEAR; // (0C) CLEAR key + case Qt::Key_Enter: + case Qt::Key_Return: + return VK_RETURN; // (0D) Return key + case Qt::Key_Shift: + return VK_SHIFT; // (10) SHIFT key + case Qt::Key_Control: + return VK_CONTROL; // (11) CTRL key + case Qt::Key_Menu: + case Qt::Key_Alt: + return VK_MENU; // (12) ALT key + + case Qt::Key_F1: + return VK_F1; + case Qt::Key_F2: + return VK_F2; + case Qt::Key_F3: + return VK_F3; + case Qt::Key_F4: + return VK_F4; + case Qt::Key_F5: + return VK_F5; + case Qt::Key_F6: + return VK_F6; + case Qt::Key_F7: + return VK_F7; + case Qt::Key_F8: + return VK_F8; + case Qt::Key_F9: + return VK_F9; + case Qt::Key_F10: + return VK_F10; + case Qt::Key_F11: + return VK_F11; + case Qt::Key_F12: + return VK_F12; + case Qt::Key_F13: + return VK_F13; + case Qt::Key_F14: + return VK_F14; + case Qt::Key_F15: + return VK_F15; + case Qt::Key_F16: + return VK_F16; + case Qt::Key_F17: + return VK_F17; + case Qt::Key_F18: + return VK_F18; + case Qt::Key_F19: + return VK_F19; + case Qt::Key_F20: + return VK_F20; + case Qt::Key_F21: + return VK_F21; + case Qt::Key_F22: + return VK_F22; + case Qt::Key_F23: + return VK_F23; + case Qt::Key_F24: + return VK_F24; + + case Qt::Key_Pause: + return VK_PAUSE; // (13) PAUSE key + case Qt::Key_CapsLock: + return VK_CAPITAL; // (14) CAPS LOCK key + case Qt::Key_Kana_Lock: + case Qt::Key_Kana_Shift: + return VK_KANA; // (15) Input Method Editor (IME) Kana mode + case Qt::Key_Hangul: + return VK_HANGUL; // VK_HANGUL (15) IME Hangul mode + // VK_JUNJA (17) IME Junja mode + // VK_FINAL (18) IME final mode + case Qt::Key_Hangul_Hanja: + return VK_HANJA; // (19) IME Hanja mode + case Qt::Key_Kanji: + return VK_KANJI; // (19) IME Kanji mode + case Qt::Key_Escape: + return VK_ESCAPE; // (1B) ESC key + // VK_CONVERT (1C) IME convert + // VK_NONCONVERT (1D) IME nonconvert + // VK_ACCEPT (1E) IME accept + // VK_MODECHANGE (1F) IME mode change request + case Qt::Key_Space: + return VK_SPACE; // (20) SPACEBAR + case Qt::Key_PageUp: + return VK_PRIOR; // (21) PAGE UP key + case Qt::Key_PageDown: + return VK_NEXT; // (22) PAGE DOWN key + case Qt::Key_End: + return VK_END; // (23) END key + case Qt::Key_Home: + return VK_HOME; // (24) HOME key + case Qt::Key_Left: + return VK_LEFT; // (25) LEFT ARROW key + case Qt::Key_Up: + return VK_UP; // (26) UP ARROW key + case Qt::Key_Right: + return VK_RIGHT; // (27) RIGHT ARROW key + case Qt::Key_Down: + return VK_DOWN; // (28) DOWN ARROW key + case Qt::Key_Select: + return VK_SELECT; // (29) SELECT key + case Qt::Key_Print: + return VK_SNAPSHOT; // (2A) PRINT key + case Qt::Key_Execute: + return VK_EXECUTE; // (2B) EXECUTE key + case Qt::Key_Insert: + return VK_INSERT; // (2D) INS key + case Qt::Key_Delete: + return VK_DELETE; // (2E) DEL key + case Qt::Key_Help: + return VK_HELP; // (2F) HELP key + case Qt::Key_0: + case Qt::Key_ParenLeft: + return VK_0; // (30) 0) key + case Qt::Key_1: + return VK_1; // (31) 1 ! key + case Qt::Key_2: + case Qt::Key_At: + return VK_2; // (32) 2 & key + case Qt::Key_3: + case Qt::Key_NumberSign: + return VK_3; // case '3': case '#'; + case Qt::Key_4: + case Qt::Key_Dollar: // (34) 4 key '$'; + return VK_4; + case Qt::Key_5: + case Qt::Key_Percent: + return VK_5; // (35) 5 key '%' + case Qt::Key_6: + case Qt::Key_AsciiCircum: + return VK_6; // (36) 6 key '^' + case Qt::Key_7: + case Qt::Key_Ampersand: + return VK_7; // (37) 7 key case '&' + case Qt::Key_8: + case Qt::Key_Asterisk: + return VK_8; // (38) 8 key '*' + case Qt::Key_9: + case Qt::Key_ParenRight: + return VK_9; // (39) 9 key '(' + case Qt::Key_A: + return VK_A; // (41) A key case 'a': case 'A': return 0x41; + case Qt::Key_B: + return VK_B; // (42) B key case 'b': case 'B': return 0x42; + case Qt::Key_C: + return VK_C; // (43) C key case 'c': case 'C': return 0x43; + case Qt::Key_D: + return VK_D; // (44) D key case 'd': case 'D': return 0x44; + case Qt::Key_E: + return VK_E; // (45) E key case 'e': case 'E': return 0x45; + case Qt::Key_F: + return VK_F; // (46) F key case 'f': case 'F': return 0x46; + case Qt::Key_G: + return VK_G; // (47) G key case 'g': case 'G': return 0x47; + case Qt::Key_H: + return VK_H; // (48) H key case 'h': case 'H': return 0x48; + case Qt::Key_I: + return VK_I; // (49) I key case 'i': case 'I': return 0x49; + case Qt::Key_J: + return VK_J; // (4A) J key case 'j': case 'J': return 0x4A; + case Qt::Key_K: + return VK_K; // (4B) K key case 'k': case 'K': return 0x4B; + case Qt::Key_L: + return VK_L; // (4C) L key case 'l': case 'L': return 0x4C; + case Qt::Key_M: + return VK_M; // (4D) M key case 'm': case 'M': return 0x4D; + case Qt::Key_N: + return VK_N; // (4E) N key case 'n': case 'N': return 0x4E; + case Qt::Key_O: + return VK_O; // (4F) O key case 'o': case 'O': return 0x4F; + case Qt::Key_P: + return VK_P; // (50) P key case 'p': case 'P': return 0x50; + case Qt::Key_Q: + return VK_Q; // (51) Q key case 'q': case 'Q': return 0x51; + case Qt::Key_R: + return VK_R; // (52) R key case 'r': case 'R': return 0x52; + case Qt::Key_S: + return VK_S; // (53) S key case 's': case 'S': return 0x53; + case Qt::Key_T: + return VK_T; // (54) T key case 't': case 'T': return 0x54; + case Qt::Key_U: + return VK_U; // (55) U key case 'u': case 'U': return 0x55; + case Qt::Key_V: + return VK_V; // (56) V key case 'v': case 'V': return 0x56; + case Qt::Key_W: + return VK_W; // (57) W key case 'w': case 'W': return 0x57; + case Qt::Key_X: + return VK_X; // (58) X key case 'x': case 'X': return 0x58; + case Qt::Key_Y: + return VK_Y; // (59) Y key case 'y': case 'Y': return 0x59; + case Qt::Key_Z: + return VK_Z; // (5A) Z key case 'z': case 'Z': return 0x5A; + case Qt::Key_Meta: + return VK_LWIN; // (5B) Left Windows key (Microsoft Natural keyboard) + // case Qt::Key_Meta_R: FIXME: What to do here? + // return VK_RWIN; // (5C) Right Windows key (Natural keyboard) + // VK_APPS (5D) Applications key (Natural keyboard) + // VK_SLEEP (5F) Computer Sleep key + // VK_SEPARATOR (6C) Separator key + // VK_SUBTRACT (6D) Subtract key + // VK_DECIMAL (6E) Decimal key + // VK_DIVIDE (6F) Divide key + // handled by key code above + + case Qt::Key_NumLock: + return VK_NUMLOCK; // (90) NUM LOCK key + + case Qt::Key_ScrollLock: + return VK_SCROLL; // (91) SCROLL LOCK key + + // VK_LSHIFT (A0) Left SHIFT key + // VK_RSHIFT (A1) Right SHIFT key + // VK_LCONTROL (A2) Left CONTROL key + // VK_RCONTROL (A3) Right CONTROL key + // VK_LMENU (A4) Left MENU key + // VK_RMENU (A5) Right MENU key + // VK_BROWSER_BACK (A6) Windows 2000/XP: Browser Back key + // VK_BROWSER_FORWARD (A7) Windows 2000/XP: Browser Forward key + // VK_BROWSER_REFRESH (A8) Windows 2000/XP: Browser Refresh key + // VK_BROWSER_STOP (A9) Windows 2000/XP: Browser Stop key + // VK_BROWSER_SEARCH (AA) Windows 2000/XP: Browser Search key + // VK_BROWSER_FAVORITES (AB) Windows 2000/XP: Browser Favorites key + // VK_BROWSER_HOME (AC) Windows 2000/XP: Browser Start and Home key + // VK_VOLUME_MUTE (AD) Windows 2000/XP: Volume Mute key + // VK_VOLUME_DOWN (AE) Windows 2000/XP: Volume Down key + // VK_VOLUME_UP (AF) Windows 2000/XP: Volume Up key + // VK_MEDIA_NEXT_TRACK (B0) Windows 2000/XP: Next Track key + // VK_MEDIA_PREV_TRACK (B1) Windows 2000/XP: Previous Track key + // VK_MEDIA_STOP (B2) Windows 2000/XP: Stop Media key + // VK_MEDIA_PLAY_PAUSE (B3) Windows 2000/XP: Play/Pause Media key + // VK_LAUNCH_MAIL (B4) Windows 2000/XP: Start Mail key + // VK_LAUNCH_MEDIA_SELECT (B5) Windows 2000/XP: Select Media key + // VK_LAUNCH_APP1 (B6) Windows 2000/XP: Start Application 1 key + // VK_LAUNCH_APP2 (B7) Windows 2000/XP: Start Application 2 key + + // VK_OEM_1 (BA) Used for miscellaneous characters; it can vary by keyboard. Windows 2000/XP: For the US standard keyboard, the ';:' key + case Qt::Key_Semicolon: + case Qt::Key_Colon: + return VK_OEM_1; // case ';': case ':': return 0xBA; + // VK_OEM_PLUS (BB) Windows 2000/XP: For any country/region, the '+' key + case Qt::Key_Plus: + case Qt::Key_Equal: + return VK_OEM_PLUS; // case '=': case '+': return 0xBB; + // VK_OEM_COMMA (BC) Windows 2000/XP: For any country/region, the ',' key + case Qt::Key_Comma: + case Qt::Key_Less: + return VK_OEM_COMMA; // case ',': case '<': return 0xBC; + // VK_OEM_MINUS (BD) Windows 2000/XP: For any country/region, the '-' key + case Qt::Key_Minus: + case Qt::Key_Underscore: + return VK_OEM_MINUS; // case '-': case '_': return 0xBD; + // VK_OEM_PERIOD (BE) Windows 2000/XP: For any country/region, the '.' key + case Qt::Key_Period: + case Qt::Key_Greater: + return VK_OEM_PERIOD; // case '.': case '>': return 0xBE; + // VK_OEM_2 (BF) Used for miscellaneous characters; it can vary by keyboard. Windows 2000/XP: For the US standard keyboard, the '/?' key + case Qt::Key_Slash: + case Qt::Key_Question: + return VK_OEM_2; // case '/': case '?': return 0xBF; + // VK_OEM_3 (C0) Used for miscellaneous characters; it can vary by keyboard. Windows 2000/XP: For the US standard keyboard, the '`~' key + case Qt::Key_AsciiTilde: + case Qt::Key_QuoteLeft: + return VK_OEM_3; // case '`': case '~': return 0xC0; + // VK_OEM_4 (DB) Used for miscellaneous characters; it can vary by keyboard. Windows 2000/XP: For the US standard keyboard, the '[{' key + case Qt::Key_BracketLeft: + case Qt::Key_BraceLeft: + return VK_OEM_4; // case '[': case '{': return 0xDB; + // VK_OEM_5 (DC) Used for miscellaneous characters; it can vary by keyboard. Windows 2000/XP: For the US standard keyboard, the '\|' key + case Qt::Key_Backslash: + case Qt::Key_Bar: + return VK_OEM_5; // case '\\': case '|': return 0xDC; + // VK_OEM_6 (DD) Used for miscellaneous characters; it can vary by keyboard. Windows 2000/XP: For the US standard keyboard, the ']}' key + case Qt::Key_BracketRight: + case Qt::Key_BraceRight: + return VK_OEM_6; // case ']': case '}': return 0xDD; + // VK_OEM_7 (DE) Used for miscellaneous characters; it can vary by keyboard. Windows 2000/XP: For the US standard keyboard, the 'single-quote/double-quote' key + case Qt::Key_QuoteDbl: + return VK_OEM_7; // case '\'': case '"': return 0xDE; + // VK_OEM_8 (DF) Used for miscellaneous characters; it can vary by keyboard. + // VK_OEM_102 (E2) Windows 2000/XP: Either the angle bracket key or the backslash key on the RT 102-key keyboard + // VK_PROCESSKEY (E5) Windows 95/98/Me, Windows NT 4.0, Windows 2000/XP: IME PROCESS key + // VK_PACKET (E7) Windows 2000/XP: Used to pass Unicode characters as if they were keystrokes. The VK_PACKET key is the low word of a 32-bit Virtual Key value used for non-keyboard input methods. For more information, see Remark in KEYBDINPUT,SendInput, WM_KEYDOWN, and WM_KEYUP + // VK_ATTN (F6) Attn key + // VK_CRSEL (F7) CrSel key + // VK_EXSEL (F8) ExSel key + // VK_EREOF (F9) Erase EOF key + // VK_PLAY (FA) Play key + // VK_ZOOM (FB) Zoom key + // VK_NONAME (FC) Reserved for future use + // VK_PA1 (FD) PA1 key + // VK_OEM_CLEAR (FE) Clear key + default: + return 0; + } +} + +static inline double currentTimeForEvent(const QInputEvent* event) +{ + Q_ASSERT(event); + + if (event->timestamp()) + return static_cast<double>(event->timestamp()) / 1000; + + static QElapsedTimer timer; + if (!timer.isValid()) + timer.start(); + return static_cast<double>(timer.elapsed()) / 1000; +} + +static WebMouseEvent::Button mouseButtonForEvent(QMouseEvent *event) +{ + if (event->button() == Qt::LeftButton || (event->buttons() & Qt::LeftButton)) + return WebMouseEvent::ButtonLeft; + else if (event->button() == Qt::RightButton || (event->buttons() & Qt::RightButton)) + return WebMouseEvent::ButtonRight; + else if (event->button() == Qt::MidButton || (event->buttons() & Qt::MidButton)) + return WebMouseEvent::ButtonMiddle; + return WebMouseEvent::ButtonNone; +} + +template <typename T> +static unsigned mouseButtonsModifiersForEvent(const T* event) +{ + unsigned ret = 0; + if (event->buttons() & Qt::LeftButton) + ret |= WebInputEvent::LeftButtonDown; + if (event->buttons() & Qt::RightButton) + ret |= WebInputEvent::RightButtonDown; + if (event->buttons() & Qt::MidButton) + ret |= WebInputEvent::MiddleButtonDown; + return ret; +} + +static inline WebInputEvent::Modifiers modifiersForEvent(const QInputEvent* event) +{ + unsigned result = 0; + Qt::KeyboardModifiers modifiers = event->modifiers(); + if (modifiers & Qt::ShiftModifier) + result |= WebInputEvent::ShiftKey; + if (modifiers & Qt::ControlModifier) + result |= WebInputEvent::ControlKey; + if (modifiers & Qt::AltModifier) + result |= WebInputEvent::AltKey; + if (modifiers & Qt::MetaModifier) + result |= WebInputEvent::MetaKey; + if (modifiers & Qt::KeypadModifier) + result |= WebInputEvent::IsKeyPad; + + switch (event->type()) { + case QEvent::MouseButtonPress: + case QEvent::MouseButtonRelease: + case QEvent::MouseMove: + result |= mouseButtonsModifiersForEvent(static_cast<const QMouseEvent*>(event)); + break; + case QEvent::Wheel: + result |= mouseButtonsModifiersForEvent(static_cast<const QWheelEvent*>(event)); + break; + case QEvent::KeyPress: + case QEvent::KeyRelease: + if (static_cast<const QKeyEvent*>(event)->isAutoRepeat()) + result |= WebInputEvent::IsAutoRepeat; + default: + break; + } + + return (WebInputEvent::Modifiers)result; +} + +static WebInputEvent::Type webEventTypeForEvent(const QEvent* event) +{ + switch (event->type()) { + case QEvent::MouseButtonPress: + return WebInputEvent::MouseDown; + case QEvent::MouseButtonRelease: + return WebInputEvent::MouseUp; + case QEvent::MouseMove: + return WebInputEvent::MouseMove; + case QEvent::Wheel: + return WebInputEvent::MouseWheel; + case QEvent::KeyPress: + return WebInputEvent::KeyDown; + case QEvent::KeyRelease: + return WebInputEvent::KeyUp; + case QEvent::TouchBegin: + return WebInputEvent::TouchStart; + case QEvent::TouchUpdate: + return WebInputEvent::TouchMove; + case QEvent::TouchEnd: + return WebInputEvent::TouchEnd; + case QEvent::TouchCancel: + return WebInputEvent::TouchCancel; + case QEvent::MouseButtonDblClick: + return WebInputEvent::Undefined; + default: + Q_ASSERT(false); + return WebInputEvent::MouseMove; + } +} + + +WebMouseEvent WebEventFactory::toWebMouseEvent(QMouseEvent *ev) +{ + WebMouseEvent webKitEvent; + webKitEvent.timeStampSeconds = currentTimeForEvent(ev); + webKitEvent.button = mouseButtonForEvent(ev); + webKitEvent.modifiers = modifiersForEvent(ev); + + webKitEvent.x = webKitEvent.windowX = ev->x(); + webKitEvent.y = webKitEvent.windowY = ev->y(); + webKitEvent.globalX = ev->globalX(); + webKitEvent.globalY = ev->globalY(); + + webKitEvent.type = webEventTypeForEvent(ev); + + switch (ev->type()) { + case QEvent::MouseButtonPress: + webKitEvent.clickCount = 1; + break; + case QEvent::MouseButtonDblClick: + webKitEvent.clickCount = 2; + break; + default: + webKitEvent.clickCount = 0; + break; + }; + + return webKitEvent; +} + +WebKit::WebMouseWheelEvent WebEventFactory::toWebWheelEvent(QWheelEvent *ev) +{ + WebMouseWheelEvent webEvent; + webEvent.type = webEventTypeForEvent(ev); + webEvent.deltaX = 0; + webEvent.deltaY = 0; + webEvent.wheelTicksX = 0; + webEvent.wheelTicksY = 0; + webEvent.modifiers = modifiersForEvent(ev); + webEvent.timeStampSeconds = currentTimeForEvent(ev); + + if (ev->orientation() == Qt::Horizontal) + webEvent.wheelTicksX = ev->delta() / 120.0f; + else + webEvent.wheelTicksY = ev->delta() / 120.0f; + + + // Since we report the scroll by the pixel, convert the delta to pixel distance using standard scroll step. + // Use the same single scroll step as QTextEdit (in QTextEditPrivate::init [h,v]bar->setSingleStep) + static const float cDefaultQtScrollStep = 20.f; + + const int wheelScrollLines = qApp->wheelScrollLines(); // can be hardcoded to 3 if we don't want to depend on QtWidgets + + webEvent.deltaX = webEvent.wheelTicksX * wheelScrollLines * cDefaultQtScrollStep; + webEvent.deltaY = webEvent.wheelTicksY * wheelScrollLines * cDefaultQtScrollStep; + + webEvent.x = webEvent.windowX = ev->x(); + webEvent.y = webEvent.windowY = ev->y(); + webEvent.globalX = ev->globalX(); + webEvent.globalY = ev->globalY(); + return webEvent; +} + +content::NativeWebKeyboardEvent WebEventFactory::toWebKeyboardEvent(QKeyEvent *ev) +{ + content::NativeWebKeyboardEvent webKitEvent; + webKitEvent.timeStampSeconds = currentTimeForEvent(ev); + webKitEvent.modifiers = modifiersForEvent(ev); + webKitEvent.type = webEventTypeForEvent(ev); + + webKitEvent.nativeKeyCode = ev->nativeVirtualKey(); + webKitEvent.windowsKeyCode = windowsKeyCodeForKeyEvent(ev->key(), ev->modifiers() & Qt::KeypadModifier); + + memcpy(&webKitEvent.text, ev->text().utf16(), qMin(sizeof(webKitEvent.text), sizeof(ev->text().utf16()))); + return webKitEvent; +} diff --git a/lib/web_event_factory.h b/lib/web_event_factory.h new file mode 100644 index 000000000..061200ccc --- /dev/null +++ b/lib/web_event_factory.h @@ -0,0 +1,61 @@ +/**************************************************************************** +** +** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/legal +** +** This file is part of the QtWebEngine module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and Digia. For licensing terms and +** conditions see http://qt.digia.com/licensing. For further information +** use the contact form at http://qt.digia.com/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Digia gives you certain additional +** rights. These rights are described in the Digia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#ifndef WEB_EVENT_FACTORY_H +#define WEB_EVENT_FACTORY_H + +#include "content/public/browser/native_web_keyboard_event.h" +#include "third_party/WebKit/Source/WebKit/chromium/public/WebInputEvent.h" + +class QMouseEvent; +class QKeyEvent; +class QWheelEvent; + +class WebEventFactory { + +public: + static WebKit::WebMouseEvent toWebMouseEvent(QMouseEvent*); + static WebKit::WebMouseWheelEvent toWebWheelEvent(QWheelEvent*); + static content::NativeWebKeyboardEvent toWebKeyboardEvent(QKeyEvent*); +}; + + +#endif |