Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Web] Error: Couldn't create typeface for #2784

Open
tlow92 opened this issue Dec 3, 2024 · 4 comments
Open

[Web] Error: Couldn't create typeface for #2784

tlow92 opened this issue Dec 3, 2024 · 4 comments

Comments

@tlow92
Copy link

tlow92 commented Dec 3, 2024

Hi,

I am currently upgrading from expo 51 to 52 and noticed that after the upgrade no fonts are rendered in my skia canvas due to an error:

Font.js:67 Uncaught (in promise) Error: Couldn't create typeface for Inter-Regular
    at Font.js:67:17
    at async Promise.all (index 0)

I am adding inter fonts like this in all skia components and it used to work just fine

const fonts = useFonts({
  'Inter-Regular': [require('@tamagui/font-inter/otf/Inter-Regular.otf')],
});

After then I'm using them in the styles for paragraph

 Skia.ParagraphBuilder.Make({}, fonts).pushStyle({
  fontFamilies: ['Inter-Regular'],
}).addText(text).build()

It works fine in iOS (even after upgrade to expo 52) but not in Web anymore.

Tested with react-native-skia 1.5.0 and 1.6.0

@wcandillon
Copy link
Contributor

can you share a reproduction?

@tlow92
Copy link
Author

tlow92 commented Dec 4, 2024

@wcandillon Sure, I added a skia paragraph using inter font to a fresh expo 52 create-expo-app.
https://github.com/tlow92/react-native-skia-typeface-issue

Let me know if you need more

@tlow92
Copy link
Author

tlow92 commented Dec 5, 2024

I found something, but I am not sure about the root cause and the consequences (I'm sure resolveAsset is used for a purpose), maybe you can help understanding this.

For some reason
Platform.resolveAsset(typefaceToLoad) is undefined on web
when removing the resolveAsset call and just passing typefaceToLoad typefaces are created and displayed correctly.

return Skia.Data.fromURI(Platform.resolveAsset(typefaceToLoad)).then(

Patch used:

diff --git a/node_modules/@shopify/react-native-skia/lib/module/skia/core/Font.js b/node_modules/@shopify/react-native-skia/lib/module/skia/core/Font.js
index 25896be..58085c1 100644
--- a/node_modules/@shopify/react-native-skia/lib/module/skia/core/Font.js
+++ b/node_modules/@shopify/react-native-skia/lib/module/skia/core/Font.js
@@ -61,7 +61,7 @@ export const listFontFamilies = (fontMgr = Skia.FontMgr.System()) => new Array(f
 const loadTypefaces = typefacesToLoad => {
   const promises = Object.keys(typefacesToLoad).flatMap(familyName => {
     return typefacesToLoad[familyName].map(typefaceToLoad => {
-      return Skia.Data.fromURI(Platform.resolveAsset(typefaceToLoad)).then(data => {
+      return Skia.Data.fromURI(typefaceToLoad).then(data => {
         const tf = Skia.Typeface.MakeFreeTypeFaceFromData(data);
         if (tf === null) {
           throw new Error(`Couldn't create typeface for ${familyName}`);

@megabuz
Copy link

megabuz commented Dec 31, 2024

same for me (in expo web)

as a workaround for developing I am using
Noto: [{ default: require("../assets/fonts/NotoColorEmoji.ttf") }],
instead of
Noto: [require("../assets/fonts/NotoColorEmoji.ttf")],

typescript is complaining and it is definitely not a right solution, but I can proceed with my explorations

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants