[Flutter/dart] 表示領域に合わせた画像の表示方法
概要
アプリで画像を表示させたい場合に、表示する領域に合わせて画像を表示する方法を解説します。
方法
1 縦横比はそのままに画面いっぱいに表示
width無限大のSizedBoxにimageを入れます。
Widget _myImg(){
return SizedBox(
width: double.infinity,
child: Image.asset('image/person.png',),
);
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(),
body: SingleChildScrollView(
child:_myImg()
),
);
}

2 サイズの決まった領域に、その中いっぱいに表示
ImageをFittedBoxに入れ、fitプロパティをBoxFit.containにします。
Widget _myImg(){
return FittedBox(
fit: BoxFit.contain,
child:
Image.asset('image/person.png',),
);
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(),
body: SingleChildScrollView(
child: Container(
padding: const EdgeInsets.all(32),
child: _myImg(),
width: 200,
height: 200,
)
),
);
}

最新記事
すべて表示現象 アプリ内にAdmobを追加して、アプリを起動すると、下記のエラーが発生 java.lang.RuntimeException: Unable to get provider com.google.android.gms.ads.MobileAdsInitProvider 原因 AndroidManifestの書き方が誤っていた。 <meta-data>はactivityと同じ階層にある必要が
概要 Uriを持っていて、Urlに変換したい場合の方法で少し手惑ったので共有します 方法 String url = uri.toString(); これだけです。 最後に ページを開くだけだとUriでもUrlでもいいんですが、WebViewはUrlを要求してくるんですよね。
問題 以前、日本語を含むURLを開くためには、エンコーディングしてやる必要がある、という記事を書きました。 しかし、すでにエンコーディングされているURLを再度エンコーディングしてしまうと、別のURLになってしまいます。 つまり、URLを開く処理の前に、 ・エンコーディングが必要なURLか ・すでにエンコーディングがされているか を判定しないといけないことになります。これは中々煩雑な処理です。 発