[Flutter/dart] google_fontsからnotoSansJpが消えた?
現象
自分は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.otf
4 TestStyleで指定
Text(
'test',
TextStyle(
fontFamily: 'NotoSansJP'
)
)
はまりどころ
自分は以下の点でハマってしまったので注意してください。
・pubsec.yamlのスペースの数はちゃんと正確に
・中華フォントにしないように
flutterで日本語フォントを使おうとすると、中華フォントになってしまいます。このページ の対応を行なって中華フォントにならないようにしてください。この対応がしてないとnotoSansJpにしても中華フォントになってしまいます。
・MediumやBoldもちゃんと入れる
複数のFontWeightを使う場合は対応するotfを全て入れましょう。僕の場合はMediumとBoldを使用しているので、上記のように3つのotfファイルがfontsフォルダ内にあります。
最新記事
すべて表示やりたいこと TextFieldで入力フォームを作りたい。 例えば入力内容が金額の場合、3桁区切りで頭に¥を付けた表記にしたい。 ただしユーザにこれらを入力させるのではなく、ユーザはあくまで数字を入力するだけで、アプリ側で自動でフォーマットしたい。 方法...
現象 やってること iosシミュレータで画像をデバイスのローカルに保存 保存したパスをデータベースに保存 アプリ立ち上げ時にデータベースから画像パスを取得し、そのパスの画像を画面上に表示 起きている現象 iosシミュレータを再起動した場合、上記3で「ファイルパスが見つからな...
やりたいこと 初期値さえ決まればあとは不変な変数がある ただし、コンストラクタ起動時にはまだ決定できない このような変数について late finalで変数を定義 (何らかのタイミングで)初期化されたかどうかをチェックし、されていなければ値を入れる(チェックしないとfina...
Comments