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 /shared | |
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 'shared')
-rw-r--r-- | shared/backing_store_qt.cpp | 143 | ||||
-rw-r--r-- | shared/backing_store_qt.h | 69 | ||||
-rw-r--r-- | shared/render_widget_host_view_qt.cpp | 468 | ||||
-rw-r--r-- | shared/render_widget_host_view_qt.h | 148 | ||||
-rw-r--r-- | shared/render_widget_host_view_qt_delegate.h | 19 | ||||
-rw-r--r-- | shared/shared.pro | 14 | ||||
-rw-r--r-- | shared/shared_globals.cpp | 2 | ||||
-rw-r--r-- | shared/web_event_factory.cpp | 600 | ||||
-rw-r--r-- | shared/web_event_factory.h | 61 |
9 files changed, 4 insertions, 1520 deletions
diff --git a/shared/backing_store_qt.cpp b/shared/backing_store_qt.cpp deleted file mode 100644 index cee0d093e..000000000 --- a/shared/backing_store_qt.cpp +++ /dev/null @@ -1,143 +0,0 @@ -/**************************************************************************** -** -** 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/shared/backing_store_qt.h b/shared/backing_store_qt.h deleted file mode 100644 index d2fa52f38..000000000 --- a/shared/backing_store_qt.h +++ /dev/null @@ -1,69 +0,0 @@ -/**************************************************************************** -** -** 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/shared/render_widget_host_view_qt.cpp b/shared/render_widget_host_view_qt.cpp deleted file mode 100644 index 9be9d6f35..000000000 --- a/shared/render_widget_host_view_qt.cpp +++ /dev/null @@ -1,468 +0,0 @@ -/**************************************************************************** -** -** 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 "shared_globals.h" -#include "web_event_factory.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/shared/render_widget_host_view_qt.h b/shared/render_widget_host_view_qt.h deleted file mode 100644 index 9ff200c32..000000000 --- a/shared/render_widget_host_view_qt.h +++ /dev/null @@ -1,148 +0,0 @@ -/**************************************************************************** -** -** 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/shared/render_widget_host_view_qt_delegate.h b/shared/render_widget_host_view_qt_delegate.h deleted file mode 100644 index 7f147dae6..000000000 --- a/shared/render_widget_host_view_qt_delegate.h +++ /dev/null @@ -1,19 +0,0 @@ -#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/shared/shared.pro b/shared/shared.pro index f51032417..fd394ae63 100644 --- a/shared/shared.pro +++ b/shared/shared.pro @@ -18,18 +18,10 @@ PER_CONFIG_DEFINES = QTWEBENGINEPROCESS_PATH=\\\"$$getOutDir()/%config/$$QTWEBEN # Keep Skia happy CONFIG(release, debug|release): DEFINES += NDEBUG -QT += widgets quick +QT += gui SOURCES = \ - backing_store_qt.cpp \ - render_widget_host_view_qt.cpp \ - shared_globals.cpp \ - web_event_factory.cpp + shared_globals.cpp HEADERS = \ - backing_store_qt.h \ - render_widget_host_view_qt.h \ - render_widget_host_view_qt_delegate.h \ - shared_globals.h \ - web_event_factory.h - + shared_globals.h diff --git a/shared/shared_globals.cpp b/shared/shared_globals.cpp index 9a23c8db1..eab332869 100644 --- a/shared/shared_globals.cpp +++ b/shared/shared_globals.cpp @@ -44,7 +44,7 @@ #include "content/browser/renderer_host/render_widget_host_view_base.h" #include <QScreen> -#include <QQuickWindow> +#include <QWindow> namespace content { diff --git a/shared/web_event_factory.cpp b/shared/web_event_factory.cpp deleted file mode 100644 index ed24c5b6d..000000000 --- a/shared/web_event_factory.cpp +++ /dev/null @@ -1,600 +0,0 @@ -/**************************************************************************** -** -** 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/shared/web_event_factory.h b/shared/web_event_factory.h deleted file mode 100644 index 061200ccc..000000000 --- a/shared/web_event_factory.h +++ /dev/null @@ -1,61 +0,0 @@ -/**************************************************************************** -** -** 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 |