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