OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "components/view_manager/native_viewport/platform_viewport.h" | 5 #include "components/view_manager/native_viewport/platform_viewport.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
9 #include "components/view_manager/native_viewport/platform_viewport_headless.h" | |
10 #include "components/view_manager/public/interfaces/view_manager.mojom.h" | |
11 #include "mojo/converters/geometry/geometry_type_converters.h" | 9 #include "mojo/converters/geometry/geometry_type_converters.h" |
12 #include "mojo/converters/input_events/input_events_type_converters.h" | 10 #include "mojo/converters/input_events/input_events_type_converters.h" |
13 #include "mojo/converters/input_events/mojo_extended_key_event_data.h" | 11 #include "mojo/converters/input_events/mojo_extended_key_event_data.h" |
14 #include "ui/events/event.h" | 12 #include "ui/events/event.h" |
15 #include "ui/events/event_utils.h" | 13 #include "ui/events/event_utils.h" |
16 #include "ui/events/platform/platform_event_dispatcher.h" | 14 #include "ui/events/platform/platform_event_dispatcher.h" |
17 #include "ui/gfx/geometry/rect.h" | 15 #include "ui/gfx/geometry/rect.h" |
18 #include "ui/platform_window/platform_window.h" | 16 #include "ui/platform_window/platform_window.h" |
19 #include "ui/platform_window/platform_window_delegate.h" | 17 #include "ui/platform_window/platform_window_delegate.h" |
20 #include "ui/platform_window/x11/x11_window.h" | 18 #include "ui/platform_window/x11/x11_window.h" |
(...skipping 23 matching lines...) Expand all Loading... |
44 } | 42 } |
45 | 43 |
46 private: | 44 private: |
47 // Overridden from PlatformViewport: | 45 // Overridden from PlatformViewport: |
48 void Init(const gfx::Rect& bounds) override { | 46 void Init(const gfx::Rect& bounds) override { |
49 CHECK(!platform_window_); | 47 CHECK(!platform_window_); |
50 | 48 |
51 metrics_ = mojo::ViewportMetrics::New(); | 49 metrics_ = mojo::ViewportMetrics::New(); |
52 // TODO(sky): make density real. | 50 // TODO(sky): make density real. |
53 metrics_->device_pixel_ratio = 1.f; | 51 metrics_->device_pixel_ratio = 1.f; |
54 metrics_->size_in_pixels = mojo::Size::From(bounds.size()); | 52 metrics_->size = mojo::Size::From(bounds.size()); |
55 | 53 |
56 platform_window_.reset(new ui::X11Window(this)); | 54 platform_window_.reset(new ui::X11Window(this)); |
57 platform_window_->SetBounds(bounds); | 55 platform_window_->SetBounds(bounds); |
58 } | 56 } |
59 | 57 |
60 void Show() override { platform_window_->Show(); } | 58 void Show() override { platform_window_->Show(); } |
61 | 59 |
62 void Hide() override { platform_window_->Hide(); } | 60 void Hide() override { platform_window_->Hide(); } |
63 | 61 |
64 void Close() override { platform_window_->Close(); } | 62 void Close() override { platform_window_->Close(); } |
65 | 63 |
66 gfx::Size GetSize() override { | 64 gfx::Size GetSize() override { return metrics_->size.To<gfx::Size>(); } |
67 return metrics_->size_in_pixels.To<gfx::Size>(); | |
68 } | |
69 | 65 |
70 void SetBounds(const gfx::Rect& bounds) override { | 66 void SetBounds(const gfx::Rect& bounds) override { |
71 platform_window_->SetBounds(bounds); | 67 platform_window_->SetBounds(bounds); |
72 } | 68 } |
73 | 69 |
74 // ui::PlatformWindowDelegate: | 70 // ui::PlatformWindowDelegate: |
75 void OnBoundsChanged(const gfx::Rect& new_bounds) override { | 71 void OnBoundsChanged(const gfx::Rect& new_bounds) override { |
76 // TODO(fsamuel): Use the real device_scale_factor. | 72 metrics_->size = mojo::Size::From(new_bounds.size()); |
77 delegate_->OnMetricsChanged(new_bounds.size(), | 73 delegate_->OnMetricsChanged(metrics_.Clone()); |
78 1.f /* device_scale_factor */); | |
79 } | 74 } |
80 | 75 |
81 void OnDamageRect(const gfx::Rect& damaged_region) override {} | 76 void OnDamageRect(const gfx::Rect& damaged_region) override {} |
82 | 77 |
83 void DispatchEvent(ui::Event* event) override { | 78 void DispatchEvent(ui::Event* event) override { |
84 mojo::EventPtr mojo_event(mojo::Event::From(*event)); | 79 mojo::EventPtr mojo_event(mojo::Event::From(*event)); |
85 if (event->IsMouseWheelEvent()) { | 80 if (event->IsMouseWheelEvent()) { |
86 // Mojo's event type has a different meaning for wheel events. Convert | 81 // Mojo's event type has a different meaning for wheel events. Convert |
87 // between the two. | 82 // between the two. |
88 ui::MouseWheelEvent* wheel_event = | 83 ui::MouseWheelEvent* wheel_event = |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
156 void OnActivationChanged(bool active) override {} | 151 void OnActivationChanged(bool active) override {} |
157 | 152 |
158 scoped_ptr<ui::PlatformWindow> platform_window_; | 153 scoped_ptr<ui::PlatformWindow> platform_window_; |
159 Delegate* delegate_; | 154 Delegate* delegate_; |
160 mojo::ViewportMetricsPtr metrics_; | 155 mojo::ViewportMetricsPtr metrics_; |
161 | 156 |
162 DISALLOW_COPY_AND_ASSIGN(PlatformViewportX11); | 157 DISALLOW_COPY_AND_ASSIGN(PlatformViewportX11); |
163 }; | 158 }; |
164 | 159 |
165 // static | 160 // static |
166 scoped_ptr<PlatformViewport> PlatformViewport::Create(Delegate* delegate, | 161 scoped_ptr<PlatformViewport> PlatformViewport::Create(Delegate* delegate) { |
167 bool headless) { | |
168 if (headless) | |
169 return PlatformViewportHeadless::Create(delegate); | |
170 return make_scoped_ptr(new PlatformViewportX11(delegate)); | 162 return make_scoped_ptr(new PlatformViewportX11(delegate)); |
171 } | 163 } |
172 | 164 |
173 } // namespace native_viewport | 165 } // namespace native_viewport |
OLD | NEW |