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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
// Copyright (c) 2012 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/gfx/point_base.h"
#include "base/basictypes.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "ui/gfx/point.h"
#include "ui/gfx/point_conversions.h"
#include "ui/gfx/point_f.h"
namespace ui {
namespace {
int TestPointF(const gfx::PointF& p) {
return p.x();
}
} // namespace
TEST(PointTest, ToPointF) {
// Check that implicit conversion from integer to float compiles.
gfx::Point a(10, 20);
float x = TestPointF(a);
EXPECT_EQ(x, a.x());
gfx::PointF b(10, 20);
EXPECT_EQ(a, b);
EXPECT_EQ(b, a);
}
TEST(PointTest, IsOrigin) {
EXPECT_FALSE(gfx::Point(1, 0).IsOrigin());
EXPECT_FALSE(gfx::Point(0, 1).IsOrigin());
EXPECT_FALSE(gfx::Point(1, 2).IsOrigin());
EXPECT_FALSE(gfx::Point(-1, 0).IsOrigin());
EXPECT_FALSE(gfx::Point(0, -1).IsOrigin());
EXPECT_FALSE(gfx::Point(-1, -2).IsOrigin());
EXPECT_TRUE(gfx::Point(0, 0).IsOrigin());
EXPECT_FALSE(gfx::PointF(0.1f, 0).IsOrigin());
EXPECT_FALSE(gfx::PointF(0, 0.1f).IsOrigin());
EXPECT_FALSE(gfx::PointF(0.1f, 2).IsOrigin());
EXPECT_FALSE(gfx::PointF(-0.1f, 0).IsOrigin());
EXPECT_FALSE(gfx::PointF(0, -0.1f).IsOrigin());
EXPECT_FALSE(gfx::PointF(-0.1f, -2).IsOrigin());
EXPECT_TRUE(gfx::PointF(0, 0).IsOrigin());
}
TEST(PointTest, VectorArithmetic) {
gfx::Point a(1, 5);
gfx::Vector2d v1(3, -3);
gfx::Vector2d v2(-8, 1);
static const struct {
gfx::Point expected;
gfx::Point actual;
} tests[] = {
{ gfx::Point(4, 2), a + v1 },
{ gfx::Point(-2, 8), a - v1 },
{ a, a - v1 + v1 },
{ a, a + v1 - v1 },
{ a, a + gfx::Vector2d() },
{ gfx::Point(12, 1), a + v1 - v2 },
{ gfx::Point(-10, 9), a - v1 + v2 }
};
for (size_t i = 0; i < ARRAYSIZE_UNSAFE(tests); ++i)
EXPECT_EQ(tests[i].expected.ToString(),
tests[i].actual.ToString());
}
TEST(PointTest, OffsetFromPoint) {
gfx::Point a(1, 5);
gfx::Point b(-20, 8);
EXPECT_EQ(gfx::Vector2d(-20 - 1, 8 - 5).ToString(),
b.OffsetFrom(a).ToString());
EXPECT_EQ(gfx::Vector2d(-20 - 1, 8 - 5).ToString(),
(b - a).ToString());
}
TEST(PointTest, ToRoundedPoint) {
EXPECT_EQ(gfx::Point(0, 0),
gfx::ToRoundedPoint(gfx::PointF(0, 0)));
EXPECT_EQ(gfx::Point(0, 0),
gfx::ToRoundedPoint(gfx::PointF(0.0001f, 0.0001f)));
EXPECT_EQ(gfx::Point(0, 0),
gfx::ToRoundedPoint(gfx::PointF(0.4999f, 0.4999f)));
EXPECT_EQ(gfx::Point(1, 1),
gfx::ToRoundedPoint(gfx::PointF(0.5f, 0.5f)));
EXPECT_EQ(gfx::Point(1, 1),
gfx::ToRoundedPoint(gfx::PointF(0.9999f, 0.9999f)));
EXPECT_EQ(gfx::Point(10, 10),
gfx::ToRoundedPoint(gfx::PointF(10, 10)));
EXPECT_EQ(gfx::Point(10, 10),
gfx::ToRoundedPoint(gfx::PointF(10.0001f, 10.0001f)));
EXPECT_EQ(gfx::Point(10, 10),
gfx::ToRoundedPoint(gfx::PointF(10.4999f, 10.4999f)));
EXPECT_EQ(gfx::Point(11, 11),
gfx::ToRoundedPoint(gfx::PointF(10.5f, 10.5f)));
EXPECT_EQ(gfx::Point(11, 11),
gfx::ToRoundedPoint(gfx::PointF(10.9999f, 10.9999f)));
EXPECT_EQ(gfx::Point(-10, -10),
gfx::ToRoundedPoint(gfx::PointF(-10, -10)));
EXPECT_EQ(gfx::Point(-10, -10),
gfx::ToRoundedPoint(gfx::PointF(-10.0001f, -10.0001f)));
EXPECT_EQ(gfx::Point(-10, -10),
gfx::ToRoundedPoint(gfx::PointF(-10.4999f, -10.4999f)));
EXPECT_EQ(gfx::Point(-11, -11),
gfx::ToRoundedPoint(gfx::PointF(-10.5f, -10.5f)));
EXPECT_EQ(gfx::Point(-11, -11),
gfx::ToRoundedPoint(gfx::PointF(-10.9999f, -10.9999f)));
}
} // namespace ui
|