Index: ui/views/controls/label_unittest.cc |
diff --git a/ui/views/controls/label_unittest.cc b/ui/views/controls/label_unittest.cc |
index 3a99557ad7157438b613c830e8c955953b7af51a..56fd144a13abba2cfdadae87ff48ba2575660ce8 100644 |
--- a/ui/views/controls/label_unittest.cc |
+++ b/ui/views/controls/label_unittest.cc |
@@ -360,23 +360,20 @@ TEST_F(LabelTest, MultiLineSizing) { |
TEST_F(LabelTest, DirectionalityFromText) { |
Label label; |
label.SetBounds(0, 0, 1000, 1000); |
- base::string16 paint_text; |
- gfx::Rect text_bounds; |
- int flags = -1; |
// Test text starts with RTL character. |
label.SetText(base::WideToUTF16(L" \x5d0\x5d1\x5d2 abc")); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
+ const Label::DrawStringParams* params = label.CalculateDrawStringParams(); |
EXPECT_EQ(gfx::Canvas::FORCE_RTL_DIRECTIONALITY, |
- flags & (gfx::Canvas::FORCE_RTL_DIRECTIONALITY | |
- gfx::Canvas::FORCE_LTR_DIRECTIONALITY)); |
+ params->flags & (gfx::Canvas::FORCE_RTL_DIRECTIONALITY | |
+ gfx::Canvas::FORCE_LTR_DIRECTIONALITY)); |
// Test text starts with LTR character. |
label.SetText(base::WideToUTF16(L"ltr \x5d0\x5d1\x5d2 abc")); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
+ params = label.CalculateDrawStringParams(); |
EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY, |
- flags & (gfx::Canvas::FORCE_RTL_DIRECTIONALITY | |
- gfx::Canvas::FORCE_LTR_DIRECTIONALITY)); |
+ params->flags & (gfx::Canvas::FORCE_RTL_DIRECTIONALITY | |
+ gfx::Canvas::FORCE_LTR_DIRECTIONALITY)); |
} |
TEST_F(LabelTest, DrawSingleLineString) { |
@@ -390,54 +387,48 @@ TEST_F(LabelTest, DrawSingleLineString) { |
required_size.height() + extra.height()); |
// Do some basic verifications for all three alignments. |
- base::string16 paint_text; |
- gfx::Rect text_bounds; |
- int flags = -1; |
- |
// Centered text. |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ const Label::DrawStringParams* params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be centered horizontally and vertically. |
- EXPECT_EQ(extra.width() / 2, text_bounds.x()); |
- EXPECT_EQ(0, text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.height(), text_bounds.height()); |
+ EXPECT_EQ(extra.width() / 2, params->bounds.x()); |
+ EXPECT_EQ(0, params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// Left aligned text. |
label.SetHorizontalAlignment(gfx::ALIGN_LEFT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be left aligned horizontally and centered vertically. |
- EXPECT_EQ(0, text_bounds.x()); |
- EXPECT_EQ(0, text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.height(), text_bounds.height()); |
+ EXPECT_EQ(0, params->bounds.x()); |
+ EXPECT_EQ(0, params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// Right aligned text. |
label.SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be right aligned horizontally and centered vertically. |
- EXPECT_EQ(extra.width(), text_bounds.x()); |
- EXPECT_EQ(0, text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.height(), text_bounds.height()); |
+ EXPECT_EQ(extra.width(), params->bounds.x()); |
+ EXPECT_EQ(0, params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// Test single line drawing with a border. |
gfx::Insets border(39, 34, 8, 96); |
@@ -454,51 +445,48 @@ TEST_F(LabelTest, DrawSingleLineString) { |
// Centered text with border. |
label.SetHorizontalAlignment(gfx::ALIGN_CENTER); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be centered horizontally and vertically within the border. |
- EXPECT_EQ(border.left() + extra.width() / 2, text_bounds.x()); |
- EXPECT_EQ(border.top(), text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.GetContentsBounds().height(), text_bounds.height()); |
+ EXPECT_EQ(border.left() + extra.width() / 2, params->bounds.x()); |
+ EXPECT_EQ(border.top(), params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.GetContentsBounds().height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// Left aligned text with border. |
label.SetHorizontalAlignment(gfx::ALIGN_LEFT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be left aligned horizontally and centered vertically. |
- EXPECT_EQ(border.left(), text_bounds.x()); |
- EXPECT_EQ(border.top(), text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.GetContentsBounds().height(), text_bounds.height()); |
+ EXPECT_EQ(border.left(), params->bounds.x()); |
+ EXPECT_EQ(border.top(), params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.GetContentsBounds().height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
- // Right aligned text. |
+ // Right aligned text with border. |
label.SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be right aligned horizontally and centered vertically. |
- EXPECT_EQ(border.left() + extra.width(), text_bounds.x()); |
- EXPECT_EQ(border.top(), text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.GetContentsBounds().height(), text_bounds.height()); |
+ EXPECT_EQ(border.left() + extra.width(), params->bounds.x()); |
+ EXPECT_EQ(border.top(), params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.GetContentsBounds().height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
} |
// Pango needs a max height to elide multiline text; that is not supported here. |
@@ -517,15 +505,12 @@ TEST_F(LabelTest, DrawMultiLineString) { |
label.height() + extra.height()); |
// Do some basic verifications for all three alignments. |
- base::string16 paint_text; |
- gfx::Rect text_bounds; |
- int flags = -1; |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(extra.width() / 2, text_bounds.x()); |
- EXPECT_EQ(extra.height() / 2, text_bounds.y()); |
- EXPECT_GT(text_bounds.width(), kMinTextDimension); |
- EXPECT_GT(text_bounds.height(), kMinTextDimension); |
+ const Label::DrawStringParams* params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(extra.width() / 2, params->bounds.x()); |
+ EXPECT_EQ(extra.height() / 2, params->bounds.y()); |
+ EXPECT_GT(params->bounds.width(), kMinTextDimension); |
+ EXPECT_GT(params->bounds.height(), kMinTextDimension); |
int expected_flags = gfx::Canvas::MULTI_LINE | |
gfx::Canvas::TEXT_ALIGN_CENTER | |
gfx::Canvas::FORCE_LTR_DIRECTIONALITY; |
@@ -533,17 +518,16 @@ TEST_F(LabelTest, DrawMultiLineString) { |
expected_flags |= gfx::Canvas::NO_ELLIPSIS; |
#endif |
EXPECT_EQ(expected_flags, expected_flags); |
- gfx::Rect center_bounds(text_bounds); |
+ gfx::Rect center_bounds(params->bounds); |
label.SetHorizontalAlignment(gfx::ALIGN_LEFT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(0, text_bounds.x()); |
- EXPECT_EQ(extra.height() / 2, text_bounds.y()); |
- EXPECT_GT(text_bounds.width(), kMinTextDimension); |
- EXPECT_GT(text_bounds.height(), kMinTextDimension); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(0, params->bounds.x()); |
+ EXPECT_EQ(extra.height() / 2, params->bounds.y()); |
+ EXPECT_GT(params->bounds.width(), kMinTextDimension); |
+ EXPECT_GT(params->bounds.height(), kMinTextDimension); |
expected_flags = gfx::Canvas::MULTI_LINE | |
gfx::Canvas::TEXT_ALIGN_LEFT | |
gfx::Canvas::FORCE_LTR_DIRECTIONALITY; |
@@ -553,14 +537,13 @@ TEST_F(LabelTest, DrawMultiLineString) { |
EXPECT_EQ(expected_flags, expected_flags); |
label.SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(extra.width(), text_bounds.x()); |
- EXPECT_EQ(extra.height() / 2, text_bounds.y()); |
- EXPECT_GT(text_bounds.width(), kMinTextDimension); |
- EXPECT_GT(text_bounds.height(), kMinTextDimension); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(extra.width(), params->bounds.x()); |
+ EXPECT_EQ(extra.height() / 2, params->bounds.y()); |
+ EXPECT_GT(params->bounds.width(), kMinTextDimension); |
+ EXPECT_GT(params->bounds.height(), kMinTextDimension); |
expected_flags = gfx::Canvas::MULTI_LINE | |
gfx::Canvas::TEXT_ALIGN_RIGHT | |
gfx::Canvas::FORCE_LTR_DIRECTIONALITY; |
@@ -579,14 +562,13 @@ TEST_F(LabelTest, DrawMultiLineString) { |
label.height() + extra.height()); |
label.SetHorizontalAlignment(gfx::ALIGN_CENTER); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(border.left() + extra.width() / 2, text_bounds.x()); |
- EXPECT_EQ(border.top() + extra.height() / 2, text_bounds.y()); |
- EXPECT_EQ(center_bounds.width(), text_bounds.width()); |
- EXPECT_EQ(center_bounds.height(), text_bounds.height()); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(border.left() + extra.width() / 2, params->bounds.x()); |
+ EXPECT_EQ(border.top() + extra.height() / 2, params->bounds.y()); |
+ EXPECT_EQ(center_bounds.width(), params->bounds.width()); |
+ EXPECT_EQ(center_bounds.height(), params->bounds.height()); |
expected_flags = gfx::Canvas::MULTI_LINE | |
gfx::Canvas::TEXT_ALIGN_CENTER | |
gfx::Canvas::FORCE_LTR_DIRECTIONALITY; |
@@ -596,14 +578,13 @@ TEST_F(LabelTest, DrawMultiLineString) { |
EXPECT_EQ(expected_flags, expected_flags); |
label.SetHorizontalAlignment(gfx::ALIGN_LEFT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(border.left(), text_bounds.x()); |
- EXPECT_EQ(border.top() + extra.height() / 2, text_bounds.y()); |
- EXPECT_EQ(center_bounds.width(), text_bounds.width()); |
- EXPECT_EQ(center_bounds.height(), text_bounds.height()); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(border.left(), params->bounds.x()); |
+ EXPECT_EQ(border.top() + extra.height() / 2, params->bounds.y()); |
+ EXPECT_EQ(center_bounds.width(), params->bounds.width()); |
+ EXPECT_EQ(center_bounds.height(), params->bounds.height()); |
expected_flags = gfx::Canvas::MULTI_LINE | |
gfx::Canvas::TEXT_ALIGN_LEFT | |
gfx::Canvas::FORCE_LTR_DIRECTIONALITY; |
@@ -613,14 +594,13 @@ TEST_F(LabelTest, DrawMultiLineString) { |
EXPECT_EQ(expected_flags, expected_flags); |
label.SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(extra.width() + border.left(), text_bounds.x()); |
- EXPECT_EQ(border.top() + extra.height() / 2, text_bounds.y()); |
- EXPECT_EQ(center_bounds.width(), text_bounds.width()); |
- EXPECT_EQ(center_bounds.height(), text_bounds.height()); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(extra.width() + border.left(), params->bounds.x()); |
+ EXPECT_EQ(border.top() + extra.height() / 2, params->bounds.y()); |
+ EXPECT_EQ(center_bounds.width(), params->bounds.width()); |
+ EXPECT_EQ(center_bounds.height(), params->bounds.height()); |
expected_flags = gfx::Canvas::MULTI_LINE | |
gfx::Canvas::TEXT_ALIGN_RIGHT | |
gfx::Canvas::FORCE_LTR_DIRECTIONALITY; |
@@ -644,54 +624,48 @@ TEST_F(LabelTest, DrawSingleLineStringInRTL) { |
required_size.height() + extra.height()); |
// Do some basic verifications for all three alignments. |
- base::string16 paint_text; |
- gfx::Rect text_bounds; |
- int flags = -1; |
- |
// Centered text. |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ const Label::DrawStringParams* params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be centered horizontally and vertically. |
- EXPECT_EQ(extra.width() / 2, text_bounds.x()); |
- EXPECT_EQ(0, text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.height(), text_bounds.height()); |
+ EXPECT_EQ(extra.width() / 2, params->bounds.x()); |
+ EXPECT_EQ(0, params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// ALIGN_LEFT label. |
label.SetHorizontalAlignment(gfx::ALIGN_LEFT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be right aligned horizontally and centered vertically. |
- EXPECT_EQ(extra.width(), text_bounds.x()); |
- EXPECT_EQ(0, text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.height(), text_bounds.height()); |
+ EXPECT_EQ(extra.width(), params->bounds.x()); |
+ EXPECT_EQ(0, params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// ALIGN_RIGHT label. |
label.SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be left aligned horizontally and centered vertically. |
- EXPECT_EQ(0, text_bounds.x()); |
- EXPECT_EQ(0, text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.height(), text_bounds.height()); |
+ EXPECT_EQ(0, params->bounds.x()); |
+ EXPECT_EQ(0, params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// Test single line drawing with a border. |
@@ -709,51 +683,48 @@ TEST_F(LabelTest, DrawSingleLineStringInRTL) { |
// Centered text with border. |
label.SetHorizontalAlignment(gfx::ALIGN_CENTER); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be centered horizontally and vertically within the border. |
- EXPECT_EQ(border.left() + extra.width() / 2, text_bounds.x()); |
- EXPECT_EQ(border.top(), text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.GetContentsBounds().height(), text_bounds.height()); |
+ EXPECT_EQ(border.left() + extra.width() / 2, params->bounds.x()); |
+ EXPECT_EQ(border.top(), params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.GetContentsBounds().height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// ALIGN_LEFT text with border. |
label.SetHorizontalAlignment(gfx::ALIGN_LEFT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be right aligned horizontally and centered vertically. |
- EXPECT_EQ(border.left() + extra.width(), text_bounds.x()); |
- EXPECT_EQ(border.top(), text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.GetContentsBounds().height(), text_bounds.height()); |
+ EXPECT_EQ(border.left() + extra.width(), params->bounds.x()); |
+ EXPECT_EQ(border.top(), params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.GetContentsBounds().height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// ALIGN_RIGHT text. |
label.SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
// The text should be left aligned horizontally and centered vertically. |
- EXPECT_EQ(border.left(), text_bounds.x()); |
- EXPECT_EQ(border.top(), text_bounds.y()); |
- EXPECT_EQ(required_size.width(), text_bounds.width()); |
- EXPECT_EQ(label.GetContentsBounds().height(), text_bounds.height()); |
+ EXPECT_EQ(border.left(), params->bounds.x()); |
+ EXPECT_EQ(border.top(), params->bounds.y()); |
+ EXPECT_EQ(required_size.width(), params->bounds.width()); |
+ EXPECT_EQ(label.GetContentsBounds().height(), params->bounds.height()); |
EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT, |
- flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
- gfx::Canvas::TEXT_ALIGN_CENTER | |
- gfx::Canvas::TEXT_ALIGN_RIGHT)); |
+ params->flags & (gfx::Canvas::TEXT_ALIGN_LEFT | |
+ gfx::Canvas::TEXT_ALIGN_CENTER | |
+ gfx::Canvas::TEXT_ALIGN_RIGHT)); |
// Reset locale. |
base::i18n::SetICUDefaultLocale(locale); |
@@ -779,50 +750,45 @@ TEST_F(LabelTest, DrawMultiLineStringInRTL) { |
label.height() + extra.height()); |
// Do some basic verifications for all three alignments. |
- base::string16 paint_text; |
- gfx::Rect text_bounds; |
- int flags = -1; |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(extra.width() / 2, text_bounds.x()); |
- EXPECT_EQ(extra.height() / 2, text_bounds.y()); |
- EXPECT_GT(text_bounds.width(), kMinTextDimension); |
- EXPECT_GT(text_bounds.height(), kMinTextDimension); |
- EXPECT_TRUE(gfx::Canvas::MULTI_LINE & flags); |
- EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_CENTER & flags); |
+ const Label::DrawStringParams* params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(extra.width() / 2, params->bounds.x()); |
+ EXPECT_EQ(extra.height() / 2, params->bounds.y()); |
+ EXPECT_GT(params->bounds.width(), kMinTextDimension); |
+ EXPECT_GT(params->bounds.height(), kMinTextDimension); |
+ EXPECT_TRUE(gfx::Canvas::MULTI_LINE & params->flags); |
+ EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_CENTER & params->flags); |
#if !defined(OS_WIN) |
- EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & flags); |
+ EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & params->flags); |
#endif |
- gfx::Rect center_bounds(text_bounds); |
+ gfx::Rect center_bounds(params->bounds); |
label.SetHorizontalAlignment(gfx::ALIGN_LEFT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(extra.width(), text_bounds.x()); |
- EXPECT_EQ(extra.height() / 2, text_bounds.y()); |
- EXPECT_GT(text_bounds.width(), kMinTextDimension); |
- EXPECT_GT(text_bounds.height(), kMinTextDimension); |
- EXPECT_TRUE(gfx::Canvas::MULTI_LINE & flags); |
- EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_RIGHT & flags); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(extra.width(), params->bounds.x()); |
+ EXPECT_EQ(extra.height() / 2, params->bounds.y()); |
+ EXPECT_GT(params->bounds.width(), kMinTextDimension); |
+ EXPECT_GT(params->bounds.height(), kMinTextDimension); |
+ EXPECT_TRUE(gfx::Canvas::MULTI_LINE & params->flags); |
+ EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_RIGHT & params->flags); |
#if !defined(OS_WIN) |
- EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & flags); |
+ EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & params->flags); |
#endif |
label.SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(0, text_bounds.x()); |
- EXPECT_EQ(extra.height() / 2, text_bounds.y()); |
- EXPECT_GT(text_bounds.width(), kMinTextDimension); |
- EXPECT_GT(text_bounds.height(), kMinTextDimension); |
- EXPECT_TRUE(gfx::Canvas::MULTI_LINE & flags); |
- EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_LEFT & flags); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(0, params->bounds.x()); |
+ EXPECT_EQ(extra.height() / 2, params->bounds.y()); |
+ EXPECT_GT(params->bounds.width(), kMinTextDimension); |
+ EXPECT_GT(params->bounds.height(), kMinTextDimension); |
+ EXPECT_TRUE(gfx::Canvas::MULTI_LINE & params->flags); |
+ EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_LEFT & params->flags); |
#if !defined(OS_WIN) |
- EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & flags); |
+ EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & params->flags); |
#endif |
// Test multiline drawing with a border. |
@@ -835,48 +801,45 @@ TEST_F(LabelTest, DrawMultiLineStringInRTL) { |
label.height() + extra.height()); |
label.SetHorizontalAlignment(gfx::ALIGN_CENTER); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(border.left() + extra.width() / 2, text_bounds.x()); |
- EXPECT_EQ(border.top() + extra.height() / 2, text_bounds.y()); |
- EXPECT_EQ(center_bounds.width(), text_bounds.width()); |
- EXPECT_EQ(center_bounds.height(), text_bounds.height()); |
- EXPECT_TRUE(gfx::Canvas::MULTI_LINE & flags); |
- EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_CENTER & flags); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(border.left() + extra.width() / 2, params->bounds.x()); |
+ EXPECT_EQ(border.top() + extra.height() / 2, params->bounds.y()); |
+ EXPECT_EQ(center_bounds.width(), params->bounds.width()); |
+ EXPECT_EQ(center_bounds.height(), params->bounds.height()); |
+ EXPECT_TRUE(gfx::Canvas::MULTI_LINE & params->flags); |
+ EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_CENTER & params->flags); |
#if !defined(OS_WIN) |
- EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & flags); |
+ EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & params->flags); |
#endif |
label.SetHorizontalAlignment(gfx::ALIGN_LEFT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(border.left() + extra.width(), text_bounds.x()); |
- EXPECT_EQ(border.top() + extra.height() / 2, text_bounds.y()); |
- EXPECT_EQ(center_bounds.width(), text_bounds.width()); |
- EXPECT_EQ(center_bounds.height(), text_bounds.height()); |
- EXPECT_TRUE(gfx::Canvas::MULTI_LINE & flags); |
- EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_RIGHT & flags); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(border.left() + extra.width(), params->bounds.x()); |
+ EXPECT_EQ(border.top() + extra.height() / 2, params->bounds.y()); |
+ EXPECT_EQ(center_bounds.width(), params->bounds.width()); |
+ EXPECT_EQ(center_bounds.height(), params->bounds.height()); |
+ EXPECT_TRUE(gfx::Canvas::MULTI_LINE & params->flags); |
+ EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_RIGHT & params->flags); |
#if !defined(OS_WIN) |
- EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & flags); |
+ EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & params->flags); |
#endif |
label.SetHorizontalAlignment(gfx::ALIGN_RIGHT); |
- paint_text.clear(); |
- text_bounds.SetRect(0, 0, 0, 0); |
- label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags); |
- EXPECT_EQ(label.text(), paint_text); |
- EXPECT_EQ(border.left(), text_bounds.x()); |
- EXPECT_EQ(border.top() + extra.height() / 2, text_bounds.y()); |
- EXPECT_EQ(center_bounds.width(), text_bounds.width()); |
- EXPECT_EQ(center_bounds.height(), text_bounds.height()); |
- EXPECT_TRUE(gfx::Canvas::MULTI_LINE & flags); |
- EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_LEFT & flags); |
+ label.ResetLayoutCache(); |
+ params = label.CalculateDrawStringParams(); |
+ EXPECT_EQ(label.text(), params->text); |
+ EXPECT_EQ(border.left(), params->bounds.x()); |
+ EXPECT_EQ(border.top() + extra.height() / 2, params->bounds.y()); |
+ EXPECT_EQ(center_bounds.width(), params->bounds.width()); |
+ EXPECT_EQ(center_bounds.height(), params->bounds.height()); |
+ EXPECT_TRUE(gfx::Canvas::MULTI_LINE & params->flags); |
+ EXPECT_TRUE(gfx::Canvas::TEXT_ALIGN_LEFT & params->flags); |
#if !defined(OS_WIN) |
- EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & flags); |
+ EXPECT_TRUE(gfx::Canvas::NO_ELLIPSIS & params->flags); |
#endif |
// Reset Locale |