Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1068)

Unified Diff: ui/android/dummy_screen_android.cc

Issue 2416403002: Reland of Android: support multiple displays on C++ side (Closed)
Patch Set: Rebased and fixed webkit_tests Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ui/android/dummy_screen_android.h ('k') | ui/android/java/src/org/chromium/ui/base/WindowAndroid.java » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/android/dummy_screen_android.cc
diff --git a/ui/android/dummy_screen_android.cc b/ui/android/dummy_screen_android.cc
new file mode 100644
index 0000000000000000000000000000000000000000..28520b8abb9a8e8ba0fa15f9303c5acc11cc9644
--- /dev/null
+++ b/ui/android/dummy_screen_android.cc
@@ -0,0 +1,67 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ui/android/dummy_screen_android.h"
+#include "ui/display/display.h"
+#include "ui/display/screen.h"
+
+namespace ui {
+
+using display::Display;
+using display::DisplayObserver;
+
+// A Screen for Android unit tests that do not talk to Java. The class contains
+// one primary display with default Display configuration and 256x512 dip size.
+class DummyScreenAndroid : public display::Screen {
+ public:
+ DummyScreenAndroid() {
+ const int display_id = 0;
+ const gfx::Rect bounds_in_dip(256, 512);
+ displays_.push_back(Display(display_id, bounds_in_dip));
+ }
+
+ ~DummyScreenAndroid() override {}
+
+ // Screen interface.
+
+ gfx::Point GetCursorScreenPoint() override { return gfx::Point(); }
+
+ bool IsWindowUnderCursor(gfx::NativeWindow window) override { return false; }
+
+ gfx::NativeWindow GetWindowAtScreenPoint(const gfx::Point& point) override {
+ return NULL;
+ }
+
+ int GetNumDisplays() const override { return 1; }
+
+ const std::vector<Display>& GetAllDisplays() const override {
+ return displays_;
+ }
+
+ Display GetDisplayNearestWindow(gfx::NativeView view) const override {
+ return GetPrimaryDisplay();
+ }
+
+ Display GetDisplayNearestPoint(const gfx::Point& point) const override {
+ return GetPrimaryDisplay();
+ }
+
+ Display GetDisplayMatching(const gfx::Rect& match_rect) const override {
+ return GetPrimaryDisplay();
+ }
+
+ Display GetPrimaryDisplay() const override { return displays_[0]; }
+
+ void AddObserver(DisplayObserver* observer) override {}
+ void RemoveObserver(DisplayObserver* observer) override {}
+
+ private:
+ std::vector<Display> displays_;
+};
+
+display::Screen* CreateDummyScreenAndroid() {
+ return new DummyScreenAndroid;
+}
+
+} // namespace ui
« no previous file with comments | « ui/android/dummy_screen_android.h ('k') | ui/android/java/src/org/chromium/ui/base/WindowAndroid.java » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698