OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2015 Google Inc. All rights reserved. | 2 * Copyright (C) 2015 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 25 matching lines...) Expand all Loading... |
36 | 36 |
37 float CachingWordShaper::width(const Font* font, const TextRun& run, | 37 float CachingWordShaper::width(const Font* font, const TextRun& run, |
38 HashSet<const SimpleFontData*>* fallbackFonts, | 38 HashSet<const SimpleFontData*>* fallbackFonts, |
39 FloatRect* glyphBounds) | 39 FloatRect* glyphBounds) |
40 { | 40 { |
41 float width = 0; | 41 float width = 0; |
42 RefPtr<ShapeResult> wordResult; | 42 RefPtr<ShapeResult> wordResult; |
43 CachingWordShapeIterator iterator(m_shapeCache, run, font); | 43 CachingWordShapeIterator iterator(m_shapeCache, run, font); |
44 while (iterator.next(&wordResult)) { | 44 while (iterator.next(&wordResult)) { |
45 if (wordResult) { | 45 if (wordResult) { |
| 46 if (glyphBounds) { |
| 47 FloatRect adjustedBounds = wordResult->bounds(); |
| 48 // Translate glyph bounds to the current glyph position which |
| 49 // is the total width before this glyph. |
| 50 adjustedBounds.setX(adjustedBounds.x() + width); |
| 51 glyphBounds->unite(adjustedBounds); |
| 52 } |
46 width += wordResult->width(); | 53 width += wordResult->width(); |
47 if (glyphBounds) | |
48 glyphBounds->unite(wordResult->bounds()); | |
49 if (fallbackFonts) | 54 if (fallbackFonts) |
50 wordResult->fallbackFonts(fallbackFonts); | 55 wordResult->fallbackFonts(fallbackFonts); |
51 } | 56 } |
52 } | 57 } |
53 | 58 |
54 return width; | 59 return width; |
55 } | 60 } |
56 | 61 |
57 static inline float shapeResultsForRun(ShapeCache* shapeCache, const Font* font, | 62 static inline float shapeResultsForRun(ShapeCache* shapeCache, const Font* font, |
58 const TextRun& run, HashSet<const SimpleFontData*>* fallbackFonts, | 63 const TextRun& run, HashSet<const SimpleFontData*>* fallbackFonts, |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
106 { | 111 { |
107 Vector<RefPtr<ShapeResult>> results; | 112 Vector<RefPtr<ShapeResult>> results; |
108 float totalWidth = shapeResultsForRun(m_shapeCache, font, run, nullptr, | 113 float totalWidth = shapeResultsForRun(m_shapeCache, font, run, nullptr, |
109 &results); | 114 &results); |
110 | 115 |
111 return ShapeResult::selectionRect(results, run.direction(), totalWidth, | 116 return ShapeResult::selectionRect(results, run.direction(), totalWidth, |
112 point, height, from, to); | 117 point, height, from, to); |
113 } | 118 } |
114 | 119 |
115 }; // namespace blink | 120 }; // namespace blink |
OLD | NEW |