这是它的简化结构:
project:
│
...
│
├── lib:
│ │
│ └── classes using AppIcons.ttf:
│
└── packages:
│
└── ui-kit:
│
├── lib:
│ │
│ └── classes using AppIcons.ttf:
│
└── assets:
│
└── icons:
│
└── AppIcons.ttf:
packages/ui-kit/pubspec.yaml
:
flutter:
fonts:
- family: AppIcons.ttf
fonts:
- asset: assets/icons/AppIcons.ttf
packages/ui-kit/app_icons.dart
:
abstract class AppIcons {
static const _kFontFam = 'AppIcons';
static const IconData ic_add = IconData(0xe800, fontFamily: _kFontFam);
...
}
AppIcons.ic_add
中使用
lib/
所以当我尝试放置图标(
Icon(AppIcons.ic_add)
)时,我总是得到占位符而不是我的图标
终于解决了这个问题。对于那些遇到同样问题的人,这是我的解决方案:
packages/ui-kit/app_icons.dart
:
...
flutter:
fonts:
- family: AppIcons.ttf
fonts:
- asset: packages/ui-kit/assets/icons/AppIcons.ttf
...
此解决方案适用于根应用程序包之外的所有类型的资产。