OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/renderer_host/render_widget_host_view_views.h" | 5 #include "chrome/browser/renderer_host/render_widget_host_view_views.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #include "base/logging.h" | 11 #include "base/logging.h" |
12 #include "base/message_loop.h" | 12 #include "base/message_loop.h" |
13 #include "base/metrics/histogram.h" | 13 #include "base/metrics/histogram.h" |
14 #include "base/string_number_conversions.h" | 14 #include "base/string_number_conversions.h" |
15 #include "base/task.h" | 15 #include "base/task.h" |
16 #include "base/time.h" | 16 #include "base/time.h" |
17 #include "chrome/browser/renderer_host/backing_store_skia.h" | 17 #include "chrome/browser/renderer_host/backing_store_skia.h" |
18 #include "chrome/browser/renderer_host/backing_store_x.h" | 18 #include "chrome/browser/renderer_host/backing_store_x.h" |
19 #include "chrome/browser/renderer_host/render_widget_host.h" | 19 #include "chrome/browser/renderer_host/render_widget_host.h" |
20 #include "chrome/common/native_web_keyboard_event.h" | 20 #include "chrome/common/native_web_keyboard_event.h" |
21 #include "chrome/common/render_messages.h" | 21 #include "chrome/common/render_messages.h" |
22 #include "chrome/common/result_codes.h" | 22 #include "chrome/common/result_codes.h" |
23 #include "third_party/WebKit/Source/WebKit/chromium/public/gtk/WebInputEventFact
ory.h" | 23 #include "third_party/WebKit/Source/WebKit/chromium/public/gtk/WebInputEventFact
ory.h" |
24 #include "third_party/WebKit/Source/WebKit/chromium/public/WebInputEvent.h" | 24 #include "third_party/WebKit/Source/WebKit/chromium/public/WebInputEvent.h" |
25 #include "ui/base/keycodes/keyboard_code_conversion_gtk.h" | 25 #include "ui/base/keycodes/keyboard_code_conversion_gtk.h" |
26 #include "ui/base/l10n/l10n_util.h" | 26 #include "ui/base/l10n/l10n_util.h" |
27 #include "ui/base/x/x11_util.h" | 27 #include "ui/base/x/x11_util.h" |
28 #include "ui/gfx/canvas.h" | 28 #include "ui/gfx/canvas.h" |
29 #include "ui/gfx/canvas_skia.h" | 29 #include "ui/gfx/canvas_skia.h" |
| 30 #include "ui/gfx/gtk_native_view_id_manager.h" |
30 #include "views/events/event.h" | 31 #include "views/events/event.h" |
31 #include "views/ime/ime_context.h" | 32 #include "views/ime/ime_context.h" |
32 #include "views/widget/widget.h" | 33 #include "views/widget/widget.h" |
33 #include "views/widget/widget_gtk.h" | 34 #include "views/widget/widget_gtk.h" |
34 | 35 |
35 static const int kMaxWindowWidth = 4000; | 36 static const int kMaxWindowWidth = 4000; |
36 static const int kMaxWindowHeight = 4000; | 37 static const int kMaxWindowHeight = 4000; |
37 static const char kRenderWidgetHostViewKey[] = "__RENDER_WIDGET_HOST_VIEW__"; | 38 static const char kRenderWidgetHostViewKey[] = "__RENDER_WIDGET_HOST_VIEW__"; |
38 static const char kBackingStoreSkiaSwitch[] = "use-backing-store-skia"; | 39 static const char kBackingStoreSkiaSwitch[] = "use-backing-store-skia"; |
39 | 40 |
(...skipping 739 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
779 return false; | 780 return false; |
780 } | 781 } |
781 | 782 |
782 void RenderWidgetHostViewViews::AcceleratedCompositingActivated( | 783 void RenderWidgetHostViewViews::AcceleratedCompositingActivated( |
783 bool activated) { | 784 bool activated) { |
784 // TODO(anicolao): figure out if we need something here | 785 // TODO(anicolao): figure out if we need something here |
785 if (activated) | 786 if (activated) |
786 NOTIMPLEMENTED(); | 787 NOTIMPLEMENTED(); |
787 } | 788 } |
788 | 789 |
| 790 gfx::PluginWindowHandle RenderWidgetHostViewViews::AcquireCompositingSurface() { |
| 791 GtkNativeViewManager* manager = GtkNativeViewManager::GetInstance(); |
| 792 gfx::PluginWindowHandle surface = gfx::kNullPluginWindow; |
| 793 gfx::NativeViewId view_id = gfx::IdFromNativeView(GetInnerNativeView()); |
| 794 |
| 795 if (!manager->GetXIDForId(&surface, view_id)) { |
| 796 DLOG(ERROR) << "Can't find XID for view id " << view_id; |
| 797 } |
| 798 return surface; |
| 799 } |
| 800 |
| 801 void RenderWidgetHostViewViews::ReleaseCompositingSurface( |
| 802 gfx::PluginWindowHandle surface) { |
| 803 } |
| 804 |
789 WebKit::WebMouseEvent RenderWidgetHostViewViews::WebMouseEventFromViewsEvent( | 805 WebKit::WebMouseEvent RenderWidgetHostViewViews::WebMouseEventFromViewsEvent( |
790 const views::MouseEvent& event) { | 806 const views::MouseEvent& event) { |
791 WebKit::WebMouseEvent wmevent; | 807 WebKit::WebMouseEvent wmevent; |
792 InitializeWebMouseEventFromViewsEvent(event, GetMirroredPosition(), &wmevent); | 808 InitializeWebMouseEventFromViewsEvent(event, GetMirroredPosition(), &wmevent); |
793 | 809 |
794 // Setting |wmevent.button| is not necessary for -move events, but it is | 810 // Setting |wmevent.button| is not necessary for -move events, but it is |
795 // necessary for -clicks and -drags. | 811 // necessary for -clicks and -drags. |
796 if (event.IsMiddleMouseButton()) { | 812 if (event.IsMiddleMouseButton()) { |
797 wmevent.modifiers |= WebKit::WebInputEvent::MiddleButtonDown; | 813 wmevent.modifiers |= WebKit::WebInputEvent::MiddleButtonDown; |
798 wmevent.button = WebKit::WebMouseEvent::ButtonMiddle; | 814 wmevent.button = WebKit::WebMouseEvent::ButtonMiddle; |
(...skipping 169 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
968 } | 984 } |
969 | 985 |
970 // static | 986 // static |
971 RenderWidgetHostView* | 987 RenderWidgetHostView* |
972 RenderWidgetHostView::GetRenderWidgetHostViewFromNativeView( | 988 RenderWidgetHostView::GetRenderWidgetHostViewFromNativeView( |
973 gfx::NativeView widget) { | 989 gfx::NativeView widget) { |
974 gpointer user_data = g_object_get_data(G_OBJECT(widget), | 990 gpointer user_data = g_object_get_data(G_OBJECT(widget), |
975 kRenderWidgetHostViewKey); | 991 kRenderWidgetHostViewKey); |
976 return reinterpret_cast<RenderWidgetHostView*>(user_data); | 992 return reinterpret_cast<RenderWidgetHostView*>(user_data); |
977 } | 993 } |
OLD | NEW |