I am looking at implementing the following design.
How do I achieve the triangular bump on the line as in the image above? I am new to flutter and am clueless on how to get started on this.
I am looking at implementing the following design.
How do I achieve the triangular bump on the line as in the image above? I am new to flutter and am clueless on how to get started on this.
Its easy, just you need to understand how to use clippers.
Here is how :
u need to use ClipPath
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Colors.lightGreen,
appBar: AppBar(
title: Text("test"),
backgroundColor: Colors.deepOrange,
),
body: Center(
child: Column(
mainAxisSize: MainAxisSize.min,
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Container(
width: double.infinity,
height: 200,
color: Colors.red,
child: Center(
child: Text("Download"),
),
),
ClipPath(
clipper: TriangleClipper(),
child: Container(
color: Colors.red,
height: 10,
width: 20,
),
)
],
)),
);
}
And add your custom clipper :
class TriangleClipper extends CustomClipper<Path> {
@override
Path getClip(Size size) {
final path = Path();
path.lineTo(size.width, 0.0);
path.lineTo(size.width / 2, size.height);
path.close();
return path;
}
@override
bool shouldReclip(TriangleClipper oldClipper) => false;
}
Thats it you will get the same result.
That's it
ClipPath(
clipper: ClipperStack(),
child: Container(
height: 100,
color: Colors.pink,
child: Center(child: Text("DOWNLOAD")),
),
),
class ClipperStack extends CustomClipper<Path> {
@override
Path getClip(Size size) {
Path path = Path();
path.moveTo(0.0, 0.0);
path.lineTo(0.0, size.height-10);
path.lineTo((size.width / 2 )-5, size.height-10);
path.lineTo(size.width / 2, size.height);
path.lineTo((size.width / 2)+5, size.height-10);
path.lineTo(size.width, size.height-10);
path.lineTo(size.width, 0.0);
return path;
}
@override
bool shouldReclip(CustomClipper<Path> oldClipper) => true;
}