Skip to content

Commit

Permalink
Set strut font to Roboto if the given font hasn't been registered (#2…
Browse files Browse the repository at this point in the history
  • Loading branch information
Harry Terkelsen committed Oct 29, 2020
1 parent 9ccf9f1 commit 38f6665
Showing 1 changed file with 10 additions and 16 deletions.
26 changes: 10 additions & 16 deletions lib/web_ui/lib/src/engine/canvaskit/text.dart
Expand Up @@ -75,7 +75,11 @@ class CkParagraphStyle implements ui.ParagraphStyle {
EngineStrutStyle style = value as EngineStrutStyle;
final SkStrutStyleProperties skStrutStyle = SkStrutStyleProperties();
if (style._fontFamily != null) {
final List<String> fontFamilies = <String>[style._fontFamily!];
String fontFamily = style._fontFamily!;
if (!skiaFontCollection.registeredFamilies.contains(fontFamily)) {
fontFamily = 'Roboto';
}
final List<String> fontFamilies = <String>[fontFamily];
if (style._fontFamilyFallback != null) {
fontFamilies.addAll(style._fontFamilyFallback!);
}
Expand Down Expand Up @@ -531,10 +535,10 @@ class CkParagraph extends ManagedSkiaObject<SkParagraph>
for (int i = 0; i < skRects.length; i++) {
final List<double> rect = skRects[i];
result.add(ui.TextBox.fromLTRBD(
rect[0],
rect[1],
rect[2],
rect[3],
rect[0],
rect[1],
rect[2],
rect[3],
_paragraphStyle._textDirection!,
));
}
Expand Down Expand Up @@ -563,20 +567,10 @@ class CkParagraph extends ManagedSkiaObject<SkParagraph>
assert(constraints.width != null); // ignore: unnecessary_null_comparison
_lastLayoutConstraints = constraints;

// Infinite width breaks layout, just use a very large number instead.
// TODO(het): Remove this once https://bugs.chromium.org/p/skia/issues/detail?id=9874
// is fixed.
double width;
const double largeFiniteWidth = 1000000;
if (constraints.width.isInfinite) {
width = largeFiniteWidth;
} else {
width = constraints.width;
}
// TODO(het): CanvasKit throws an exception when laid out with
// a font that wasn't registered.
try {
skiaObject.layout(width);
skiaObject.layout(constraints.width);
} catch (e) {
html.window.console.warn('CanvasKit threw an exception while laying '
'out the paragraph. The font was "${_paragraphStyle._fontFamily}". '
Expand Down

0 comments on commit 38f6665

Please sign in to comment.