Flutterで複雑な形をしたWidgetを描画するには様々な方法があります。
その中で、ClipPathとCustomClipperを使用して既存のWidgetを切り抜く方法についてコードを用いてわかりやすく解説します。
既存のWidgetを切り抜くにはClipPathとCustomClipperを使用します。
ClipPathは、CustomClipperで指定したPathを使用してWidgetを切り抜くWidgetです。
1辺の長さが300の正方形を切り抜いてみます。
class MyCustomClipper extends CustomClipper<Path> {
Path getClip(Size size) {
// 正方形の左上が(0, 0)、右下が(300, 300)
final path = Path();
// 左上に移動(開始地点)
path.moveTo(0, 0);
// 右の真ん中まで直線で切り抜く
path.lineTo(size.width, size.height / 2);
// 左下まで直線で切り抜く
path.lineTo(0, size.height);
return path;
}
bool shouldReclip(covariant CustomClipper<Path> oldClipper) => false;
}
ClipPath(
clipper: MyCustomClipper(),
// 1辺の長さが300の正方形
child: Container(
color: Colors.amber,
width: 300,
height: 300,
),
)
三角形になりました。
既存のWidgetを元にすることですべてを1から描画する必要がなく、とても楽に描画することができました。
Flutterで複雑な形をしたWidgetを描画するには様々な方法があるので、そちらもぜひ調べてみてください。
可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。
Read More可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。
Read More