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

Side by Side Diff: ui/views/view_text_utils.cc

Issue 9232055: Clean up some code in view_text_utils.cc. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 8 years, 10 months 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 "ui/views/view_text_utils.h" 5 #include "ui/views/view_text_utils.h"
6 6
7 #include "base/i18n/bidi_line_iterator.h" 7 #include "base/i18n/bidi_line_iterator.h"
8 #include "base/i18n/break_iterator.h" 8 #include "base/i18n/break_iterator.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/utf_string_conversions.h" 10 #include "base/utf_string_conversions.h"
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
84 void DrawTextStartingFrom(gfx::Canvas* canvas, 84 void DrawTextStartingFrom(gfx::Canvas* canvas,
85 views::Label* label, 85 views::Label* label,
86 const string16& text, 86 const string16& text,
87 gfx::Size* position, 87 gfx::Size* position,
88 const gfx::Rect& bounds, 88 const gfx::Rect& bounds,
89 const gfx::Font& font, 89 const gfx::Font& font,
90 bool text_direction_is_rtl, 90 bool text_direction_is_rtl,
91 bool ltr_within_rtl) { 91 bool ltr_within_rtl) {
92 // Iterate through line breaking opportunities (which in English would be 92 // Iterate through line breaking opportunities (which in English would be
93 // spaces and such). This tells us where to wrap. 93 // spaces and such). This tells us where to wrap.
94 string16 text16(text); 94 base::i18n::BreakIterator iter(text,
95 base::i18n::BreakIterator iter(text16,
96 base::i18n::BreakIterator::BREAK_SPACE); 95 base::i18n::BreakIterator::BREAK_SPACE);
97 if (!iter.Init()) 96 if (!iter.Init())
98 return; 97 return;
99 98
100 int flags = (text_direction_is_rtl ? gfx::Canvas::TEXT_ALIGN_RIGHT : 99 int flags = (text_direction_is_rtl ? gfx::Canvas::TEXT_ALIGN_RIGHT :
101 gfx::Canvas::TEXT_ALIGN_LEFT); 100 gfx::Canvas::TEXT_ALIGN_LEFT);
102 flags |= gfx::Canvas::MULTI_LINE | gfx::Canvas::HIDE_PREFIX; 101 flags |= gfx::Canvas::MULTI_LINE | gfx::Canvas::HIDE_PREFIX |
102 gfx::Canvas::NO_ELLIPSIS;
103 103
104 // Iterate over each word in the text, or put in a more locale-neutral way: 104 // Iterate over each word in the text, or put in a more locale-neutral way:
105 // iterate to the next line breaking opportunity. 105 // iterate to the next line breaking opportunity.
106 while (iter.Advance()) { 106 while (iter.Advance()) {
107 // Get the word and figure out the dimensions. 107 // Get the word and figure out the dimensions.
108 string16 word; 108 string16 word;
109 if (!ltr_within_rtl) 109 if (!ltr_within_rtl)
110 word = iter.GetString(); // Get the next word. 110 word = iter.GetString(); // Get the next word.
111 else 111 else
112 word = text16; // Draw the whole text at once. 112 word = text; // Draw the whole text at once.
113 113
114 int w = font.GetStringWidth(word), h = font.GetHeight(); 114 int w = 0, h = 0;
115 gfx::CanvasSkia::SizeStringInt(word, font, &w, &h, flags); 115 gfx::CanvasSkia::SizeStringInt(word, font, &w, &h, flags);
116 116
117 // If we exceed the boundaries, we need to wrap. 117 // If we exceed the boundaries, we need to wrap.
118 WrapIfWordDoesntFit(w, font.GetHeight(), position, bounds); 118 WrapIfWordDoesntFit(w, font.GetHeight(), position, bounds);
119 119
120 int x = label->GetMirroredXInView(position->width()) + bounds.x(); 120 int x = label->GetMirroredXInView(position->width()) + bounds.x();
121 if (text_direction_is_rtl) { 121 if (text_direction_is_rtl) {
122 x -= w; 122 x -= w;
123 // When drawing LTR strings inside RTL text we need to make sure we 123 // When drawing LTR strings inside RTL text we need to make sure we
124 // draw the trailing space (if one exists after the LTR text) to the 124 // draw the trailing space (if one exists after the LTR text) to the
125 // left of the LTR string. 125 // left of the LTR string.
126 if (ltr_within_rtl && word[word.size() - 1] == ' ') { 126 if (ltr_within_rtl && word[word.size() - 1] == ' ')
127 int space_w = font.GetStringWidth(ASCIIToUTF16(" ")); 127 x += gfx::CanvasSkia::GetStringWidth(ASCIIToUTF16(" "), font);
128 int space_h = font.GetHeight();
129 gfx::CanvasSkia::SizeStringInt(ASCIIToUTF16(" "), font, &space_w,
130 &space_h, flags);
131 x += space_w;
132 }
133 } 128 }
134 int y = position->height() + bounds.y(); 129 int y = position->height() + bounds.y();
135 130
136 // Draw the text on the screen (mirrored, if RTL run). 131 // Draw the text on the screen (mirrored, if RTL run).
137 canvas->DrawStringInt(word, font, label->enabled_color(), x, y, w, 132 canvas->DrawStringInt(word, font, label->enabled_color(), x, y, w,
138 font.GetHeight(), flags); 133 font.GetHeight(), flags);
139 134
140 if (!word.empty() && word[word.size() - 1] == '\x0a') { 135 if (!word.empty() && word[word.size() - 1] == '\x0a') {
141 // When we come across '\n', we move to the beginning of the next line. 136 // When we come across '\n', we move to the beginning of the next line.
142 position->set_width(0); 137 position->set_width(0);
(...skipping 12 matching lines...) Expand all
155 int font_height, 150 int font_height,
156 gfx::Size* position, 151 gfx::Size* position,
157 const gfx::Rect& bounds) { 152 const gfx::Rect& bounds) {
158 if (position->width() + word_width > bounds.right()) { 153 if (position->width() + word_width > bounds.right()) {
159 position->set_width(0); 154 position->set_width(0);
160 position->Enlarge(0, font_height); 155 position->Enlarge(0, font_height);
161 } 156 }
162 } 157 }
163 158
164 } // namespace view_text_utils 159 } // namespace view_text_utils
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698