Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/chromeos/ui/accessibility_focus_ring.h" | 5 #include "chrome/browser/chromeos/ui/accessibility_focus_ring.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | |
| 8 | |
| 7 namespace chromeos { | 9 namespace chromeos { |
| 8 | 10 |
| 9 // static | 11 // static |
| 10 AccessibilityFocusRing AccessibilityFocusRing::CreateWithRect( | 12 AccessibilityFocusRing AccessibilityFocusRing::CreateWithRect( |
| 11 const gfx::Rect& bounds, int margin) { | 13 const gfx::Rect& bounds, int margin) { |
| 14 // Compute the height of the top and bottom cap. | |
| 15 int cap_height = std::min(bounds.height() / 2, margin * 2); | |
| 16 | |
| 12 gfx::Rect top(bounds.x(), bounds.y(), | 17 gfx::Rect top(bounds.x(), bounds.y(), |
| 13 bounds.width(), bounds.height() / 4); | 18 bounds.width(), cap_height); |
| 19 gfx::Rect bottom(bounds.x(), bounds.bottom() - cap_height, | |
| 20 bounds.width(), cap_height); | |
| 14 gfx::Rect body(bounds.x(), top.bottom(), | 21 gfx::Rect body(bounds.x(), top.bottom(), |
| 15 bounds.width(), bounds.height() / 2); | 22 bounds.width(), bottom.y() - top.bottom()); |
| 16 gfx::Rect bottom(bounds.x(), body.bottom(), | 23 |
| 17 bounds.width(), bounds.bottom() - body.bottom()); | |
| 18 return CreateWithParagraphShape(top, body, bottom, margin); | 24 return CreateWithParagraphShape(top, body, bottom, margin); |
| 19 } | 25 } |
| 20 | 26 |
| 21 // static | 27 // static |
| 28 AccessibilityFocusRing AccessibilityFocusRing::Interpolate( | |
| 29 const AccessibilityFocusRing& r1, | |
| 30 const AccessibilityFocusRing& r2, | |
| 31 double fraction) { | |
| 32 AccessibilityFocusRing dst; | |
| 33 for (int i = 0; i < 36; i++) { | |
|
xiyuan
2014/09/24 19:40:35
nit: ++i
dmazzoni
2014/09/24 21:40:56
Done.
| |
| 34 dst.points[i] = gfx::Point( | |
| 35 r1.points[i].x() * (1 - fraction) + r2.points[i].x() * fraction, | |
| 36 r1.points[i].y() * (1 - fraction) + r2.points[i].y() * fraction); | |
| 37 } | |
| 38 return dst; | |
| 39 } | |
| 40 | |
| 41 // static | |
| 22 AccessibilityFocusRing AccessibilityFocusRing::CreateWithParagraphShape( | 42 AccessibilityFocusRing AccessibilityFocusRing::CreateWithParagraphShape( |
| 23 const gfx::Rect& orig_top_line, | 43 const gfx::Rect& orig_top_line, |
| 24 const gfx::Rect& orig_body, | 44 const gfx::Rect& orig_body, |
| 25 const gfx::Rect& orig_bottom_line, | 45 const gfx::Rect& orig_bottom_line, |
| 26 int margin) { | 46 int margin) { |
| 27 gfx::Rect top = orig_top_line; | 47 gfx::Rect top = orig_top_line; |
| 28 gfx::Rect middle = orig_body; | 48 gfx::Rect middle = orig_body; |
| 29 gfx::Rect bottom = orig_bottom_line; | 49 gfx::Rect bottom = orig_bottom_line; |
| 30 | 50 |
| 51 int min_height = std::min(top.height(), bottom.height()); | |
| 52 margin = std::min(margin, min_height / 2); | |
| 53 | |
| 31 if (top.x() <= middle.x() + 2 * margin) { | 54 if (top.x() <= middle.x() + 2 * margin) { |
| 32 top.set_width(top.width() + top.x() - middle.x()); | 55 top.set_width(top.width() + top.x() - middle.x()); |
| 33 top.set_x(middle.x()); | 56 top.set_x(middle.x()); |
| 34 } | 57 } |
| 35 if (top.right() >= middle.right() - 2 * margin) { | 58 if (top.right() >= middle.right() - 2 * margin) { |
| 36 top.set_width(middle.right() - top.x()); | 59 top.set_width(middle.right() - top.x()); |
| 37 } | 60 } |
| 38 | 61 |
| 39 if (bottom.x() <= middle.x() + 2 * margin) { | 62 if (bottom.x() <= middle.x() + 2 * margin) { |
| 40 bottom.set_width(bottom.width() + bottom.x() - middle.x()); | 63 bottom.set_width(bottom.width() + bottom.x() - middle.x()); |
| 41 bottom.set_x(middle.x()); | 64 bottom.set_x(middle.x()); |
| 42 } | 65 } |
| 43 if (bottom.right() >= middle.right() - 2 * margin) { | 66 if (bottom.right() >= middle.right() - 2 * margin) { |
| 44 bottom.set_width(middle.right() - bottom.x()); | 67 bottom.set_width(middle.right() - bottom.x()); |
| 45 } | 68 } |
| 46 | 69 |
| 70 LogRect("Top2", top); | |
| 71 LogRect("Body2", middle); | |
| 72 LogRect("Bottom2", bottom); | |
|
xiyuan
2014/09/24 19:40:35
Where is LogRect defined?
dmazzoni
2014/09/24 21:40:56
Sorry, left that in while debugging. Gone.
| |
| 73 | |
| 47 AccessibilityFocusRing ring; | 74 AccessibilityFocusRing ring; |
| 48 ring.points[0] = gfx::Point(top.x(), top.bottom() - margin); | 75 ring.points[0] = gfx::Point(top.x(), top.bottom() - margin); |
| 49 ring.points[1] = gfx::Point(top.x(), top.y() + margin); | 76 ring.points[1] = gfx::Point(top.x(), top.y() + margin); |
| 50 ring.points[2] = gfx::Point(top.x(), top.y()); | 77 ring.points[2] = gfx::Point(top.x(), top.y()); |
| 51 ring.points[3] = gfx::Point(top.x() + margin, top.y()); | 78 ring.points[3] = gfx::Point(top.x() + margin, top.y()); |
| 52 ring.points[4] = gfx::Point(top.right() - margin, top.y()); | 79 ring.points[4] = gfx::Point(top.right() - margin, top.y()); |
| 53 ring.points[5] = gfx::Point(top.right(), top.y()); | 80 ring.points[5] = gfx::Point(top.right(), top.y()); |
| 54 ring.points[6] = gfx::Point(top.right(), top.y() + margin); | 81 ring.points[6] = gfx::Point(top.right(), top.y() + margin); |
| 55 ring.points[7] = gfx::Point(top.right(), top.bottom() - margin); | 82 ring.points[7] = gfx::Point(top.right(), top.bottom() - margin); |
| 56 ring.points[8] = gfx::Point(top.right(), top.bottom()); | 83 ring.points[8] = gfx::Point(top.right(), top.bottom()); |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 101 ring.points[34] = gfx::Point(top.x(), top.bottom()); | 128 ring.points[34] = gfx::Point(top.x(), top.bottom()); |
| 102 } | 129 } |
| 103 ring.points[35] = gfx::Point(top.x(), top.bottom()); | 130 ring.points[35] = gfx::Point(top.x(), top.bottom()); |
| 104 | 131 |
| 105 return ring; | 132 return ring; |
| 106 } | 133 } |
| 107 | 134 |
| 108 gfx::Rect AccessibilityFocusRing::GetBounds() const { | 135 gfx::Rect AccessibilityFocusRing::GetBounds() const { |
| 109 gfx::Point top_left = points[0]; | 136 gfx::Point top_left = points[0]; |
| 110 gfx::Point bottom_right = points[0]; | 137 gfx::Point bottom_right = points[0]; |
| 111 for (size_t i = 1; i < 36; i++) { | 138 for (size_t i = 1; i < 36; i++) { |
|
xiyuan
2014/09/24 19:40:35
nit: ++i
dmazzoni
2014/09/24 21:40:56
Done.
| |
| 112 top_left.SetToMin(points[i]); | 139 top_left.SetToMin(points[i]); |
| 113 bottom_right.SetToMax(points[i]); | 140 bottom_right.SetToMax(points[i]); |
| 114 } | 141 } |
| 115 return gfx::Rect(top_left, gfx::Size(bottom_right.x() - top_left.x(), | 142 return gfx::Rect(top_left, gfx::Size(bottom_right.x() - top_left.x(), |
| 116 bottom_right.y() - top_left.y())); | 143 bottom_right.y() - top_left.y())); |
| 117 } | 144 } |
| 118 | 145 |
| 119 } // namespace chromeos | 146 } // namespace chromeos |
| OLD | NEW |