[Flutter] 绘图--异形裁剪

由于时间关系,先上代码和效果。后续再补充上解释

代码

import 'package:flutter/material.dart';
//import 'dart:math';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      debugShowCheckedModeBanner: false,
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: ClipImagePage(),
    );
  }
}

class ClipImagePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
  return Scaffold(
      appBar: AppBar(
        title: Text('裁切'),
      ),
      body: Center(
        child: Column(
          mainAxisSize: MainAxisSize.min,
          children: <Widget>[
            ClipPath(
                clipper: MyClipper(),
                child: Container(height: 300, width: 300, color: Colors.amber))
          ],
        ),
      ),
    );
  }
}

class MyClipper extends CustomClipper<Path> {
  @override
  Path getClip(Size size) {
    Path path = Path();
    
    path.moveTo(0,0);// start point

    var radius = size.width / 3;
    
    path.arcToPoint(Offset(radius, radius),radius:Radius.circular(radius));

    var lineY = size.height - radius;
    var finalLineY = lineY > radius ? lineY : radius;
    
    path.lineTo(radius, finalLineY);
    
    path.arcToPoint(Offset(2*radius, size.height),radius:Radius.circular(radius),clockwise:false);

    path.lineTo(0, size.height);
    path.close();

    return path;
  }

  @override
  bool shouldReclip(CustomClipper<Path> oldClipper) => false;
}

效果如下:

最终效果
在上面的基础上,再完善,做出一个对称的效果

import 'package:flutter/material.dart';
//import 'dart:math';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      debugShowCheckedModeBanner: false,
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: ClipImagePage(),
    );
  }
}

class ClipImagePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
  return Scaffold(
      appBar: AppBar(
        title: Text('裁切'),
      ),
      body: Center(
        child: Column(
          mainAxisSize: MainAxisSize.min,
          children: <Widget>[
            ClipPath(
                clipper: MyClipper(),
                child: Container(height: 100, width: 200, color: Colors.amber))
          ],
        ),
      ),
    );
  }
}

class MyClipper extends CustomClipper<Path> {
  @override
  Path getClip(Size size) {
    Path path = Path();

    var baseRadius = size.width / 10;
    var edgeSpace = baseRadius * 2;

    path.moveTo(edgeSpace, 0);

    path.lineTo(size.width - edgeSpace, 0);

    path.arcToPoint(Offset(size.width - edgeSpace + baseRadius, baseRadius),
        radius: Radius.circular(baseRadius));

    path.lineTo(size.width - edgeSpace + baseRadius, size.height - baseRadius);

    path.arcToPoint(Offset(size.width, size.height),
        radius: Radius.circular(baseRadius), clockwise: false);

    path.lineTo(0, size.height);

    path.arcToPoint(Offset(baseRadius, size.height - baseRadius),
        radius: Radius.circular(baseRadius), clockwise: false);

    path.lineTo(baseRadius, baseRadius);

    path.arcToPoint(Offset(edgeSpace, 0),
        radius: Radius.circular(baseRadius));

    return path;
  }

  @override
  bool shouldReclip(CustomClipper<Path> oldClipper) => false;
}

效果如下:
更近一步

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值