OLD | NEW |
---|---|
1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 "chrome/browser/android/vr_shell/textures/url_bar_texture.h" | 5 #include "chrome/browser/android/vr_shell/textures/url_bar_texture.h" |
6 | 6 |
7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
8 #include "cc/paint/skia_paint_canvas.h" | 8 #include "cc/paint/skia_paint_canvas.h" |
9 #include "chrome/browser/android/vr_shell/color_scheme.h" | 9 #include "chrome/browser/android/vr_shell/color_scheme.h" |
10 #include "chrome/browser/android/vr_shell/textures/render_text_wrapper.h" | 10 #include "chrome/browser/android/vr_shell/textures/render_text_wrapper.h" |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
50 case SecurityLevel::SECURE_WITH_POLICY_INSTALLED_CERT: // ChromeOS only. | 50 case SecurityLevel::SECURE_WITH_POLICY_INSTALLED_CERT: // ChromeOS only. |
51 return color_scheme.insecure; | 51 return color_scheme.insecure; |
52 case SecurityLevel::DANGEROUS: | 52 case SecurityLevel::DANGEROUS: |
53 return color_scheme.insecure; | 53 return color_scheme.insecure; |
54 default: | 54 default: |
55 NOTREACHED(); | 55 NOTREACHED(); |
56 return color_scheme.insecure; | 56 return color_scheme.insecure; |
57 } | 57 } |
58 } | 58 } |
59 | 59 |
60 SkColor GetSecurityChipColor(SecurityLevel level, | |
61 bool offline_page, | |
62 const ColorScheme& color_scheme) { | |
63 if (offline_page) | |
64 return color_scheme.url_emphasized; | |
fgorski
2017/07/06 20:01:33
per our discussion I am concerned about putting th
cjgrant
2017/07/06 20:13:00
Noted. I'll follow up with Josh Carpenter (our UX
| |
65 return GetSchemeColor(level, color_scheme); | |
66 } | |
67 | |
60 void setEmphasis(vr_shell::RenderTextWrapper* render_text, | 68 void setEmphasis(vr_shell::RenderTextWrapper* render_text, |
61 bool emphasis, | 69 bool emphasis, |
62 const gfx::Range& range, | 70 const gfx::Range& range, |
63 const ColorScheme& color_scheme) { | 71 const ColorScheme& color_scheme) { |
64 SkColor color = | 72 SkColor color = |
65 emphasis ? color_scheme.url_emphasized : color_scheme.url_deemphasized; | 73 emphasis ? color_scheme.url_emphasized : color_scheme.url_deemphasized; |
66 if (range.IsValid()) { | 74 if (range.IsValid()) { |
67 render_text->ApplyColor(color, range); | 75 render_text->ApplyColor(color, range); |
68 } else { | 76 } else { |
69 render_text->SetColor(color); | 77 render_text->SetColor(color); |
70 } | 78 } |
71 } | 79 } |
72 | 80 |
73 gfx::PointF percentToMeters(const gfx::PointF& percent) { | 81 gfx::PointF percentToMeters(const gfx::PointF& percent) { |
74 return gfx::PointF(percent.x() * kWidth, percent.y() * kHeight); | 82 return gfx::PointF(percent.x() * kWidth, percent.y() * kHeight); |
75 } | 83 } |
76 | 84 |
77 } // namespace | 85 } // namespace |
78 | 86 |
79 UrlBarTexture::UrlBarTexture( | 87 UrlBarTexture::UrlBarTexture( |
80 bool web_vr, | 88 bool web_vr, |
81 const base::Callback<void(UiUnsupportedMode)>& failure_callback) | 89 const base::Callback<void(UiUnsupportedMode)>& failure_callback) |
82 : has_back_button_(!web_vr), | 90 : has_back_button_(!web_vr), |
83 has_security_chip_(false), | |
84 failure_callback_(failure_callback) {} | 91 failure_callback_(failure_callback) {} |
85 | 92 |
86 UrlBarTexture::~UrlBarTexture() = default; | 93 UrlBarTexture::~UrlBarTexture() = default; |
87 | 94 |
88 void UrlBarTexture::SetToolbarState(const ToolbarState& state) { | 95 void UrlBarTexture::SetToolbarState(const ToolbarState& state) { |
89 if (state_ == state) | 96 if (state_ == state) |
90 return; | 97 return; |
91 state_ = state; | 98 state_ = state; |
92 set_dirty(); | 99 set_dirty(); |
93 } | 100 } |
(...skipping 118 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
212 : color_scheme().disabled); | 219 : color_scheme().disabled); |
213 canvas->restore(); | 220 canvas->restore(); |
214 | 221 |
215 back_button_hit_region_.SetRect(left_edge, 0, left_edge + kBackButtonWidth, | 222 back_button_hit_region_.SetRect(left_edge, 0, left_edge + kBackButtonWidth, |
216 kHeight); | 223 kHeight); |
217 left_edge += kBackButtonWidth + kSeparatorWidth; | 224 left_edge += kBackButtonWidth + kSeparatorWidth; |
218 } | 225 } |
219 | 226 |
220 // Site security state icon. | 227 // Site security state icon. |
221 left_edge += kFieldSpacing; | 228 left_edge += kFieldSpacing; |
222 if (state_.security_level != security_state::NONE && | 229 if ((state_.security_level != security_state::NONE || state_.offline_page) && |
223 state_.vector_icon != nullptr) { | 230 state_.vector_icon != nullptr && state_.should_display_url) { |
224 gfx::RectF icon_region(left_edge, kHeight / 2 - kSecurityIconSize / 2, | 231 gfx::RectF icon_region(left_edge, kHeight / 2 - kSecurityIconSize / 2, |
225 kSecurityIconSize, kSecurityIconSize); | 232 kSecurityIconSize, kSecurityIconSize); |
226 canvas->save(); | 233 canvas->save(); |
227 canvas->translate(icon_region.x(), icon_region.y()); | 234 canvas->translate(icon_region.x(), icon_region.y()); |
228 const gfx::VectorIcon& icon = *state_.vector_icon; | 235 const gfx::VectorIcon& icon = *state_.vector_icon; |
229 float icon_scale = kSecurityIconSize / GetDefaultSizeOfVectorIcon(icon); | 236 float icon_scale = kSecurityIconSize / GetDefaultSizeOfVectorIcon(icon); |
230 canvas->scale(icon_scale, icon_scale); | 237 canvas->scale(icon_scale, icon_scale); |
231 PaintVectorIcon(&gfx_canvas, icon, | 238 PaintVectorIcon(&gfx_canvas, icon, |
232 GetSchemeColor(state_.security_level, color_scheme())); | 239 GetSecurityChipColor(state_.security_level, |
240 state_.offline_page, color_scheme())); | |
233 canvas->restore(); | 241 canvas->restore(); |
234 | 242 |
235 security_hit_region_ = icon_region; | 243 security_hit_region_ = icon_region; |
236 left_edge += kSecurityIconSize + kFieldSpacing; | 244 left_edge += kSecurityIconSize + kFieldSpacing; |
237 } | 245 } |
238 | 246 |
239 canvas->restore(); | 247 canvas->restore(); |
240 | 248 |
241 // Draw security chip text (eg. "Not secure") next to the security icon. | 249 // Draw security chip text (eg. "Not secure") next to the security icon. |
242 if (has_security_chip_ && state_.should_display_url) { | 250 if (state_.offline_page && state_.should_display_url) { |
fgorski
2017/07/06 20:01:34
this will only kick in for offline pages if you &&
cjgrant
2017/07/06 20:13:00
Yes. We added chip support for "Secure" and "Not
| |
243 float chip_max_width = kWidth - left_edge - kUrlRightMargin; | 251 float chip_max_width = kWidth - left_edge - kUrlRightMargin; |
244 gfx::Rect text_bounds(ToPixels(left_edge), 0, ToPixels(chip_max_width), | 252 gfx::Rect text_bounds(ToPixels(left_edge), 0, ToPixels(chip_max_width), |
245 ToPixels(kHeight)); | 253 ToPixels(kHeight)); |
246 | 254 |
247 int pixel_font_height = texture_size.height() * kFontHeight / kHeight; | 255 int pixel_font_height = texture_size.height() * kFontHeight / kHeight; |
248 SkColor chip_color = GetSchemeColor(state_.security_level, color_scheme()); | 256 SkColor chip_color = GetSecurityChipColor( |
257 state_.security_level, state_.offline_page, color_scheme()); | |
249 const base::string16& chip_text = state_.secure_verbose_text; | 258 const base::string16& chip_text = state_.secure_verbose_text; |
250 DCHECK(!chip_text.empty()); | 259 DCHECK(!chip_text.empty()); |
251 | 260 |
252 gfx::FontList font_list; | 261 gfx::FontList font_list; |
253 if (!GetFontList(pixel_font_height, chip_text, &font_list)) | 262 if (!GetFontList(pixel_font_height, chip_text, &font_list)) |
254 failure_callback_.Run(UiUnsupportedMode::kUnhandledCodePoint); | 263 failure_callback_.Run(UiUnsupportedMode::kUnhandledCodePoint); |
255 | 264 |
256 std::unique_ptr<gfx::RenderText> render_text( | 265 std::unique_ptr<gfx::RenderText> render_text( |
257 gfx::RenderText::CreateInstance()); | 266 gfx::RenderText::CreateInstance()); |
258 render_text->SetFontList(font_list); | 267 render_text->SetFontList(font_list); |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
292 last_drawn_gurl_ = state_.gurl; | 301 last_drawn_gurl_ = state_.gurl; |
293 last_drawn_security_level_ = state_.security_level; | 302 last_drawn_security_level_ = state_.security_level; |
294 } | 303 } |
295 url_render_text_->Draw(&gfx_canvas); | 304 url_render_text_->Draw(&gfx_canvas); |
296 } | 305 } |
297 } | 306 } |
298 | 307 |
299 void UrlBarTexture::RenderUrl(const gfx::Size& texture_size, | 308 void UrlBarTexture::RenderUrl(const gfx::Size& texture_size, |
300 const gfx::Rect& bounds) { | 309 const gfx::Rect& bounds) { |
301 url::Parsed parsed; | 310 url::Parsed parsed; |
311 | |
312 url_formatter::FormatUrlTypes format_types = url_formatter::kFormatUrlOmitAll; | |
313 if (state_.offline_page) | |
314 format_types |= url_formatter::kFormatUrlExperimentalOmitHTTPS; | |
315 | |
302 const base::string16 text = url_formatter::FormatUrl( | 316 const base::string16 text = url_formatter::FormatUrl( |
303 state_.gurl, url_formatter::kFormatUrlOmitAll, net::UnescapeRule::NORMAL, | 317 state_.gurl, format_types, net::UnescapeRule::NORMAL, &parsed, nullptr, |
304 &parsed, nullptr, nullptr); | 318 nullptr); |
305 | 319 |
306 int pixel_font_height = texture_size.height() * kFontHeight / kHeight; | 320 int pixel_font_height = texture_size.height() * kFontHeight / kHeight; |
307 | 321 |
308 gfx::FontList font_list; | 322 gfx::FontList font_list; |
309 if (!GetFontList(pixel_font_height, text, &font_list)) | 323 if (!GetFontList(pixel_font_height, text, &font_list)) |
310 failure_callback_.Run(UiUnsupportedMode::kUnhandledCodePoint); | 324 failure_callback_.Run(UiUnsupportedMode::kUnhandledCodePoint); |
311 | 325 |
312 std::unique_ptr<gfx::RenderText> render_text( | 326 std::unique_ptr<gfx::RenderText> render_text( |
313 gfx::RenderText::CreateInstance()); | 327 gfx::RenderText::CreateInstance()); |
314 render_text->SetFontList(font_list); | 328 render_text->SetFontList(font_list); |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
410 | 424 |
411 gfx::Size UrlBarTexture::GetPreferredTextureSize(int maximum_width) const { | 425 gfx::Size UrlBarTexture::GetPreferredTextureSize(int maximum_width) const { |
412 return gfx::Size(maximum_width, maximum_width * kHeight / kWidth); | 426 return gfx::Size(maximum_width, maximum_width * kHeight / kWidth); |
413 } | 427 } |
414 | 428 |
415 gfx::SizeF UrlBarTexture::GetDrawnSize() const { | 429 gfx::SizeF UrlBarTexture::GetDrawnSize() const { |
416 return size_; | 430 return size_; |
417 } | 431 } |
418 | 432 |
419 } // namespace vr_shell | 433 } // namespace vr_shell |
OLD | NEW |