FlutterのImageFiltered
ウィジェットの用途と使い方のまとめ記事です。
本記事ではImageFiltered
のサンプルコードを使いながら基本的な使い方、知っておきたい基本プロパティを解説していきます。
目次
ImageFilteredとは?
ImageFiltered
は指定したウィジェットをぼかして表示(ブラーエフェクト)したり、回転や傾きなどを調整したりできるウィジェットです。
data:image/s3,"s3://crabby-images/7cff2/7cff2bd415119c041be8ef4e648710534bb5fede" alt=""
data:image/s3,"s3://crabby-images/159a2/159a27b5c0958925a423a8c4f2f7d1fc21743fb2" alt=""
ImageFilteredの基本的な使い方
まずはImageFiltered
を使用するためにdart:ui
をインポートします。
import 'dart:ui';
ImageFiltered
はimageFilter
の引数にImageFilter.blur()
を渡すことでぼかしの調整、ImageFilter.matrix()
を渡すことで回転や傾きの調整ができます。
ImageFilter.blur()でぼかしを調整
ImageFiltered
の子ウィジェットで背景画像をぼかしたいウィジェットを指定します。imageFilter
にImageFilter.blur()
を渡し、ImageFilter.blur()
のsigmaX
とsigmaY
にdouble値を渡してぼかしを調整します。
ImageFiltered(
imageFilter: ImageFilter.blur(sigmaX: 15, sigmaY: 15),
child: Image.network(
'https://images.unsplash.com/photo-1627376617965-b8c29ca91aca',
),
)
sigmaX
とsigmaY
の値が0の場合はぼかしのないデフォルトの画像となり、値が高ければ高いほど画像がぼけて表示されます。
data:image/s3,"s3://crabby-images/99291/99291194105d9b2b52cbb100caf2ca0aab2af9d3" alt=""
data:image/s3,"s3://crabby-images/7cff2/7cff2bd415119c041be8ef4e648710534bb5fede" alt=""
data:image/s3,"s3://crabby-images/55c73/55c7358531b47cc2fb2ee3efc054bc97ba5009dd" alt=""
ImageFilter.matrix()で回転・傾きを調整
ImageFiltered
の子ウィジェットで回転・傾きを調整したいウィジェットを指定します。imageFilter
にImageFilter.matrix()
を渡し、ImageFilter.matrix()
にMatrix4()
を渡して回転や傾きを調整します。
ImageFiltered(
imageFilter: ImageFilter.matrix(Matrix4.skewY(0.3).storage),
child: Image.network(
'https://images.unsplash.com/photo-1627376617965-b8c29ca91aca',
),
)
data:image/s3,"s3://crabby-images/99291/99291194105d9b2b52cbb100caf2ca0aab2af9d3" alt=""
data:image/s3,"s3://crabby-images/159a2/159a27b5c0958925a423a8c4f2f7d1fc21743fb2" alt=""
data:image/s3,"s3://crabby-images/81247/81247a25cb5512863c2726f1cd8cca6bac5aea4c" alt=""
サンプルコード
import 'dart:ui';
import 'package:flutter/material.dart';
void main() => runApp(const MyApp());
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
home: Scaffold(
appBar: AppBar(title: const Text('Flutter')),
body: ImageFilteredExample(),
),
);
}
}
class ImageFilteredExample extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Center(
child: Padding(
padding: const EdgeInsets.all(30),
child: ImageFiltered(
imageFilter: ImageFilter.blur(sigmaX: 5, sigmaY: 5),
child: Image.network(
'https://images.unsplash.com/photo-1627376617965-b8c29ca91aca',
),
),
),
);
}
}
合わせて読みたい
あわせて読みたい
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/698c9/698c989dc85852b66730773b37bae404c82bbeec" alt=""
【Flutter】AppBarの戻るボタンを非表示にする
こんにちは、フラメルです。 今回は画面遷移する際にAppBarに自動生成される戻るボタンを非表示にする方法を紹介します。 【AppBarの戻るボタンを非表示にする方法】 戻…
あわせて読みたい
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/e31cd/e31cd9d11a3c8538b3b04e90366d495f3d6cc2bf" alt=""
【Flutter】Padding|余白を外側に作る
こんにちは、フラメルです。 今回はPaddingを使用して余白を作る方法を紹介します。 【余白を外側に作る方法】 Paddingあり Paddingなし ウィジェットの外側に余白を作…
あわせて読みたい
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/ef59b/ef59b5a815bf13e4cce77d561e44ed84a5d6e364" alt=""
【Flutter】Radioの使い方|ラジオボタン(オプションボタン)を実装
FlutterのRadioウィジェットの用途と使い方のまとめ記事です。本記事ではRadioのサンプルコードを使いながら基本的な使い方、知っておきたい基本プロパティを解説してい…