Skip to content

yinanwang1/FlutterSnippet

Repository files navigation

FlutterSnippet

声明: 如果有任何代码侵权,请联系我wyn18968158629@gmail.com

在项目使用到或者网上看到好的组件,整理一份方便以后开发的时候使用。

1. FlutterText 字体抖动

一个字体抖动的组件,继承自Text。用法和Text一样,可以设置Text的所有属性。 可以传入一个动画的配置项,实现动画。支持重复播放。 使用示例:

FlutterText(
              "我们都是孩子",
              style: const TextStyle(fontSize: 30, color: Colors.cyan),
              config: AnimationConfig(curveTween: CurveTween(curve: Curves.ease), repeat: true),
            ),

flutter

2. NormalCell 一行显示左边的图标,标题,和右边的尾部组件

提供了(1)标题图片(2)标题(3)内容(4)尾部内容(或箭头)(5)是否需要底部分割线(6)点击事件 使用示例:

const NormalCell(leading: Text("leading"), title: Text("title"), middle: Text("middle"), trailing: Text("trailing")),

cell

3. NStarView 多边形

绘制多边形,传入多边形的个数n,外半径R,内半径r,填充的颜色color 使用示例:

NStarView(15, 30, 20, color: Colors.red,)

多边形

4. AbilityWidget 蛛网显示能力图

蛛网的样式显示不同能力值,并伴有动画。 使用示例:

AbilityWidget(
          ability: Ability(100, 1500, AssetImage("images/namei.png"), {
            "攻击力": 70.0,
            "生命": 90.0,
            "闪避": 50.0,
            "暴击": 70.0,
            "破格": 80.0,
            "格挡": 100.0,
          }, Colors.black),
        ),

蛛网显示能力图

5. CircleProgressWidget 圆形进度条

通过Progress来设置属性. 使用时设置动画,可实现动态显示 使用示例:

CircleProgressWidget(Progress(value: value, backgroundColor: Colors.red))

圆形进度条

6. FlutterWebView 浏览器

传入url和title,打开新页面在浏览器展示内容。 iOS使用时,需要在ViewDidLoad中添加GeneratedPluginRegistrant.register(with: self)。 使用示例:

Navigator.of(context).push(
              MaterialPageRoute(builder: (BuildContext context) {
                return const FlutterWebView(
                    "http://www.baidu.com",
                    title: "我就是我");
              }));

需要在pubspec.yaml中依赖webview_flutter: ^2.1.1

7. MathRunner 按函数移动

封装了一个动画,传入x和y的函数,使组件按函数动起来。 使用示例:

Stack(
        alignment: Alignment.center,
        children: <Widget>[
          const CircleAvatar(
            backgroundImage: AssetImage("images/namei.png"),
          ),
          MathRunner(
            f: (t) => cos(t * pi),
            g: (t) => 0.6 * sin(t * pi),
            reverse: false,
            parts: 4,
            index: 0,
            child: const CircleAvatar(
              backgroundImage: AssetImage("images/namei.png"),
            ),
          ),
          MathRunner(
            f: (t) => cos(t * pi),
            g: (t) => 0.6 * sin(t * pi),
            reverse: false,
            parts: 4,
            index: 1,
            child: const CircleAvatar(
              backgroundImage: AssetImage("images/namei.png"),
            ),
          ),
          MathRunner(
            f: (t) => cos(t * pi),
            g: (t) => 0.6 * sin(t * pi),
            reverse: false,
            parts: 4,
            index: 2,
            child: const CircleAvatar(
              backgroundImage: AssetImage("images/namei.png"),
            ),
          ),
          MathRunner(
            f: (t) => cos(t * pi),
            g: (t) => 0.6 * sin(t * pi),
            reverse: false,
            parts: 4,
            index: 3,
            child: const CircleAvatar(
              backgroundImage: AssetImage("images/namei.png"),
            ),
          ),
        ],
      )

按函数移动

8. 评分

StarScore显示评分结果 CustomRating打分 使用示例:

Column(
  mainAxisSize: MainAxisSize.min,
  children: <Widget>[
    CustomRating(
      onRating: (double d) {
        debugPrint("score is $d");
      },
    ),
    StarScore(
      score: 3.0,
      tail: Column(
        children: const <Widget>[Text("综合评分"), Text("3.0")],
      ),
    ),
  ],
),

评分

9. ToggleRotate 点击旋转组件

点击一个组件的时候,可以将组件旋转到指定的角度,并可指定动画效果。 使用示例:

ToggleRotate(
  onTap: () {},
  child: const Icon(
    Icons.arrow_upward,
    size: 60,
    color: Colors.orangeAccent,
  ),
  durationMs: 500,
  curve: Curves.bounceInOut,
),

旋转

10. CouponShapeBorder 优惠券

用自定义shape绘制外边框的形状,实现优惠券的样式 使用示例:

Material(
color: Colors.red,
shape: const CouponShapeBorder(),
elevation: 2,
child: Container(
padding: const EdgeInsets.all(10),
height: 150,
child: Row(
  mainAxisSize: MainAxisSize.max,
  children: <Widget>[
    Flexible(
      flex: 718,
      child: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Row(
              mainAxisAlignment: MainAxisAlignment.center,
              mainAxisSize: MainAxisSize.min,
              children: <Widget>[
                const Text(
                  "¥",
                  style: TextStyle(
                      color: Colors.white, fontSize: 17),
                ),
                const Text(
                  "200",
                  style: TextStyle(
                      color: Colors.white,
                      fontSize: 60,
                      fontWeight: FontWeight.bold),
                ),
                Column(
                  mainAxisSize: MainAxisSize.min,
                  children: const <Widget>[
                    Text(
                      "优",
                      style: TextStyle(
                          color: Colors.white, fontSize: 12),
                    ),
                    Text(
                      "惠",
                      style: TextStyle(
                          color: Colors.white, fontSize: 12),
                    ),
                    Text(
                      "券",
                      style: TextStyle(
                          color: Colors.white, fontSize: 12),
                    ),
                  ],
                ),
              ],
            ),
            const Text(
              "订单满599元使用",
              style: TextStyle(
                  color: Colors.black45, fontSize: 20),
            )
          ],
        ),
      ),
    ),
    const Flexible(
      flex: 282,
      child: Center(
        child: SizedBox(
          width: 10,
          child: Text(
            "立即领取",
            style:
                TextStyle(color: Colors.yellow, fontSize: 20),
          ),
        ),
      ),
    ),
  ],
),
),
),

优惠券

11. FlutterWaveLoading 波浪加载

滚动的波浪,可以设置进度。 使用示例

const FlutterWaveLoading(
    width: 75,
    height: 75,
    isOval: false,
    progress: 0.5,
    waveHeight: 3,
    color: Colors.cyan,
    curve: Curves.bounceInOut,
),

波浪

12. PointsCurve 根据多点绘制直线和曲线

根据多个坐标,用直线和贝塞尔曲线连接。 可以设置直线的颜色和坐标点的颜色,圆的半径。 可以设置曲线的颜色和线的宽度。 使用示例:

const SizedBox(
    height: 500,
    child: PointsCurve([
      Offset(0, 20),
      Offset(40, 40),
      Offset(80, -20),
      Offset(120, -40),
      Offset(160, -80),
      Offset(200, -20),
      Offset(240, -40),
    ],),
),

直线和曲线

13. EfficientPage 联动滚动页面

通过局部更新的方式,来降低全局刷新 使用示例:

const EfficientPage()

联动滚动

14. Wave 类似水波的效果,可以设置一个中心圆,然后一个波动的圆。

波动波动。 使用示例:

Wave(),
Wave(
    waveSize: Size(100, 200),
    centerColor: Colors.black,
    waveColor: Colors.red,
    centerRadius: 20,
    durationMilliseconds: 3000,
    isWaveUp: false,
),

水波

15. Clock 钟表

表盘绘制一次,时分秒针每秒更新。 如果项目中要用到,需要将颜色提取出来,作为变量。 使用示例:

Clock()

钟表

16 Umbrella

使用绘制60度的一个小三角来组成一个伞面 可以填充彩虹色 Beta 还有很多小问题 使用示例:

Umbrella()

雨伞

17 Rainbow

使用一道彩虹。可以设置大小。 使用示例:

Rainbow()

彩虹

18 RedPacket

模仿微信的红包,弹出红包,点击"开"按钮后,旋转金币,然后跳转到结果页面。 使用示例:

@override
  Widget build(BuildContext context) {
    super.build(context);

    return Column(
      crossAxisAlignment: CrossAxisAlignment.start,
      children: <Widget>[
        const Padding(padding: EdgeInsets.only(top: 50)),
        ElevatedButton(
          onPressed: () {
            showRedPacket(context, onOpen);
          },
          child: const Text("点我领红包"),
        ),
      ],
    );
  }

  void onOpen() {
    Navigator.push(
        context,
        PageRouteBuilder(
            pageBuilder: (context, animation, secondaryAnimation) =>
                FadeTransition(
                  opacity: animation,
                  child: const ResultPage(),
                ),
            transitionDuration: const Duration(seconds: 1)));

ResultPage是结果页面,任意页面都可以。 红包

19. 兔子

使用CustomPainter绘制兔子,并采用animation控制绘制的进度。 使用示例:

Rabbit();

兔子

20. 变色气泡

聊天气泡,滚动的时候根据位置展示渐变的背景色。 渐变色的展示,根据气泡所在的位置而变。 使用示例:

BubbleBackgroundChat();

渐变

21. 流动渐变

渐变色在流动。 使用示例:

GradientBoundDemo();

渐变 渐变

22. 模糊图片

高斯模糊,设置模糊图片。 使用示例:

const BlurImageDemo()

模糊图片

23. 闪电

模拟一条闪电,随机路线,从屏幕上方向下方闪过。 使用示例:

const Lightning()

闪电

24. 加载动画

单个转圈,双个转圈和钟摆的加载动画。 主要还是使用到了computeMetrics来获取到每一时刻的位置,然后进行绘制圆点。 使用示例:

BallLoading(),
DoubleBallLoading(),
ClockPendulum(),

加载动画

25. 加载动画(转圈)

圆形、椭圆(可修改路径支持任何形状) 使用示例

LoadingAnimations(
  bgColor: Colors.white,
  foregroundColor: Colors.red,
  size: 300,
  loadingText: "我就是我,不一样的烟火",
)

加载动画2

26. 秒表

秒表的外观,及时。 使用示例

StopWatchWidget()

加载动画2

27. 图片展示进度条

上传或下载图片时,成功的进度清晰展示,未成功的模糊展示。 是用示例:

ProgressImage(0.15);

进度图片

28. 风车

一直转动的四页风车。使用CustomPainter的repaint传入一个动画来实现。 可以将风车设置成其他页数。

Windmill()

疯车

29. 霓虹灯文本

霓虹灯文本的「故障」效果的实现。

Container(
  color: Colors.black,
  child: const TearingText("美丽蝴蝶"),
)

霓虹灯文本

30. 运动汽车

控制骑车的运动,包括转弯和前进。

const RunCar(),

运动汽车

31. 计算器 (简单工厂模式)

简单的实现了加减乘除的计算,算法采用"工厂方法"设计模式。

const Calculator()

计算器

32. 收银系统 (策略模式)

收银系统,根据单价和数量,按计算方式得到金额。采用策略模式实现算法。

const CashierSystem()

计算器

33. 穿衣打扮(装饰模式)

穿衣时,进行不同服饰的打扮,方便重用和调整。采用装饰模式。 相当于链式调用。

Person xc = Person(name: "小菜");
Sneakers pqx = Sneakers();
BigTrouser kk = BigTrouser();
TShirts dtx = TShirts();

pqx.decorate(xc);
kk.decorate(pqx);
dtx.decorate(kk);
dtx.show();

打印内容为 穿衣打扮

34. 代送花(代理模式)

Pursuit请别人Proxy帮忙去送花追求SchoolGirl。此时SchoolGirl不认识Pursuit,由Proxy来代理Pursuit。 使用:使用第三方库时,做一个封装。比较项目直接依赖第三方库。当需要更换第三方库时,可以不修改项目代码。

SchoolGirl jiaoJiao = SchoolGirl("李娇娇");
Proxy daiLi = Proxy(jiaoJiao);
daiLi.giveDolls();
daiLi.giveFlowers();
daiLi.giveChocolate();

打印内容为 代送花

35. 雷锋(工厂方法模式)

为每一个产品创建一个工厂方法。在使用的时候,调用工厂方法创建实例,使用实例。

IFactory factory = UndergraduateFactory();
LeiFeng studentA = factory.createLeiFeng();
studentA.buyRice();
LeiFeng studentB = factory.createLeiFeng();
studentB.sweep();
LeiFeng studentC = factory.createLeiFeng();
studentC.wash();

打印内容为 雷锋

36. 分页列表

列表页面,(1)开始时的加载。(2)下拉刷新(3)上拉加载。将通用的功能提取成一个虚类。 使用时,只要实例化虚类并实现虚方法。一个分页列表就完成了。


class MyList extends PagingListWidget {
  const MyList({super.key});

  @override
  PagingListWidgetState<PagingListWidget, dynamic> createState() => _MyListState();
}

class _MyListState extends PagingListWidgetState<MyList, String> {
  var random = Random();

  @override
  Future<void> fetchData() async {
    return Future.delayed(const Duration(seconds: 3), () {
      super.total = 100000;
      super.dataList.addAll(List.generate(super.pageSize, (index) => "测试下 ${random.nextInt(10000000)}"));

      setState(() {
        super.showLoadingMore = false;
        super.hasInitialed = true;
      });
    });
  }

  @override
  Widget listItem(int index) {
    return Container(
      color: MyColors.randomColor(),
      height: 44,
      padding: const EdgeInsets.only(top: 8, left: 8),
      child: Text(super.dataList[index], style: TextStyle(color: MyColors.randomColor(), fontSize: 16),),
    );
  }

  @override
  String? navigationTitle() {
    return "测试分页列表";
  }
}

打印内容为 分页列表

37. 建造者(建造者模式)

创建一个PersonBuilder抽象了所有的操作,新创建类时继承PersonBuilder则完成了所有内容编写。 建造者PersonDirector则只需要添加一个PersonBuilder的子类,并规范好操作。

const BuilderWidget();

绘制瘦子 瘦子 绘制胖子 胖子

38. 老板回来了(观察者模式)

创建一个observer抽象对象,实例化同事1和同事2。创建一个Subject抽象对象,实例化boss。 boss可以绑定同事1和同事2.那么老板回来了,触发通知。

TextButton(onPressed: (){
    var boss = Boss();
    var colleague1 = StockObserver("围观眼", boss);
    var colleague2 = NBAObserver("以观察", boss);
    
    boss.attach(colleague1);
    boss.attach(colleague2);
    
    boss.subjectState = "老板回来了";
    boss.notify();

}, child: const Text("测试下"));

观察者 观察者

39. 不同数据表多张表(抽象工厂模式)

创建一个工厂方法,提供所有的表和操作方法。每一张表兼容不同的平台。

IUser user = DataAccess.createUser();
user.insert(User("test", 2));
user.getUser(2);

IProject project = DataAccess.createProject();
project.insertProject(Project("Woo", "1"));
project.getProject("123");

观察者 观察者

40. 渐变色边框

展示渐变色边框。

class GradientBorder extends StatelessWidget {
  final Widget? child;

  const GradientBorder({Key? key, this.child}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return SizedBox(
      width: 200,
      height: 48,
      child: LayoutBuilder(
        builder: (BuildContext context, BoxConstraints constraints) {
          return CustomPaint(
            painter: GradientBoundPainter(
                colors: [MyColors.mainColor, const Color(0xffff8D1A)],
                width: constraints.maxWidth,
                height: constraints.maxHeight),
            child: Center(
              child: child,
            ),
          );
        },
      ),
    );
  }
}

渐变色边框 渐变色边框

41. 下雪

绘制雪人和雪花,用显示动画展示。

Snowing()

下雪 渐变色边框

42.拍照指定裁剪大小

(1)自定义拍照界面。(2)拍好照片后直接裁剪指定范围。

CropCamera()

裁剪 渐变色边框

43. 水印

在页面中添加一个水印。

WaterMarkInstance().addWatermark(context, "稍微长一点把");

水印 水印

44. 自定义图标

在高德地图上展示一个自定义的Marker

const DemoAMapMarkers()

自定义图标 自定义图标

45.

About

收集常用的flutter组件。

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published