blob: d1431387fde6448fc0ed036c9515e98323a93274 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
// Copyright 2018 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/keyboard/display_util.h"
#include "ui/aura/window.h"
#include "ui/display/display.h"
#include "ui/display/screen.h"
#include "ui/display/types/display_constants.h"
namespace {
constexpr int kWindowMargin = 10;
} // namespace
namespace keyboard {
DisplayUtil::DisplayUtil() {}
int64_t DisplayUtil::GetNearestDisplayIdToWindow(aura::Window* window) const {
return GetNearestDisplayToWindow(window).id();
}
display::Display DisplayUtil::GetNearestDisplayToWindow(
aura::Window* window) const {
return display::Screen::GetScreen()->GetDisplayNearestWindow(window);
}
display::Display DisplayUtil::FindAdjacentDisplayIfPointIsNearMargin(
const display::Display& current_display,
const gfx::Point& point_in_local) const {
const gfx::Rect current_bounds = current_display.bounds();
const gfx::Point point =
point_in_local + current_display.bounds().origin().OffsetFromOrigin();
int representative_x = point.x();
int representative_y = point.y();
int current_left = current_bounds.x();
int current_right = current_left + current_bounds.width();
int current_top = current_bounds.y();
int current_bottom = current_top + current_bounds.height();
// If the point is close to
if (point.x() - current_left <= kWindowMargin) {
representative_x = current_left - kWindowMargin;
} else if (current_right - point.x() <= kWindowMargin) {
representative_x = current_right + kWindowMargin;
} else if (point.y() - current_top <= kWindowMargin) {
representative_y = current_top - kWindowMargin;
} else if (current_bottom - point.y() <= kWindowMargin) {
representative_y = current_bottom + kWindowMargin;
} else {
return current_display;
}
for (const display::Display& display :
display::Screen::GetScreen()->GetAllDisplays()) {
const gfx::Rect& new_bounds = display.work_area();
if (display.touch_support() == display::Display::TouchSupport::AVAILABLE &&
display.id() != current_display.id() &&
new_bounds.Contains(representative_x, representative_y)) {
return display;
}
}
return current_display;
}
} // namespace keyboard
|