[Flutter/dart] google_fontsからnotoSansJpが消えた?
- M.R 
- 2021年10月16日
- 読了時間: 2分
現象
自分はflutterでアプリを作る際、日本語のフォントにはgoogle_fontsのnotoSansJpを使用しています。
先日、google_fontsをバージョン1系から2系にアップデートしたところ、notoSansJpを指定しているところが急にコンパイルエラーになりました。エラーメッセージは「google_fontsにnotoSansJpなんていうフォントはない」というようなことを言っています。
原因
理由は不明ですが、バージョン2以降からnotoSansJpは消えてしまったみたいです。ソースコードを見てもドキュメントを見ても載っていません。
対応案
1 google_fontsのをダウングレード
これができるならば一番手っ取り早いです。
ただ、自分の場合は、他のライブラリとの依存性の都合でバージョン2以上が必要でしたので、次の対応案2の方を採用しました。
2 カスタムフォントとしてインストール
flutterではカスタムフォントを導入することができます。notoSansJpをカスタムフォントとして導入しましょう。
1 notoSansJpのotfを入手
例えば以下のサイトなどでダウンロードできます。
2 プロジェクト内にfontsフォルダを作成し、入手したotfファイルをコピー

3 pubsec.yamlに下記を追記
flutter:
  fonts:   
    - family: NotoSansJP
      fonts:
        - asset: fonts/NotoSansJP-Regular.otf
        - asset: fonts/NotoSansJP-Medium.otf
        - asset: fonts/NotoSansJP-Bold.otf4 TestStyleで指定
Text(
  'test',
  TextStyle(
    fontFamily: 'NotoSansJP'
  )
)はまりどころ
自分は以下の点でハマってしまったので注意してください。
・pubsec.yamlのスペースの数はちゃんと正確に
・中華フォントにしないように
flutterで日本語フォントを使おうとすると、中華フォントになってしまいます。このページ の対応を行なって中華フォントにならないようにしてください。この対応がしてないとnotoSansJpにしても中華フォントになってしまいます。
・MediumやBoldもちゃんと入れる
複数のFontWeightを使う場合は対応するotfを全て入れましょう。僕の場合はMediumとBoldを使用しているので、上記のように3つのotfファイルがfontsフォルダ内にあります。






コメント