Flutter:使用贝塞尔曲线剪切图片
Opened this issue · 0 comments
greycode commented
代码如下
import 'package:flutter/material.dart';
class WavyHeaderImage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new ClipPath(
child: new Image.asset('images/coffee_header.jpg'),
clipper: new BottomWaveClipper(),
);
}
}
class BottomWaveClipper extends CustomClipper<Path> {
@override
Path getClip(Size size) {
Path path = new Path();
path.lineTo(0.0, size.height - 20);
var firstControlPoint = new Offset(size.width / 4, size.height);
var firstEndPoint = new Offset(size.width / 2.25, size.height - 30.0);
path.quadraticBezierTo(firstControlPoint.dx, firstControlPoint.dy,
firstEndPoint.dx, firstEndPoint.dy);
var secondControlPoint =
new Offset(size.width - (size.width / 3.25), size.height - 65);
var secondEndPoint = new Offset(size.width, size.height - 40);
path.quadraticBezierTo(secondControlPoint.dx, secondControlPoint.dy,
secondEndPoint.dx, secondEndPoint.dy);
path.lineTo(size.width, size.height - 40);
path.lineTo(size.width, 0.0);
return path;
}
@override
bool shouldReclip(CustomClipper<Path> oldClipper) => false;
}