Flutter多下拉刷新插件multi_pull的使用

Flutter多下拉刷新插件multi_pull的使用

version:1.1.0 license:BSD3

multi_pull #

“multi pull” 是 RefreshIndicator 的扩展!

如果您喜欢这个插件,请给它点个星!🌟

无需多言,先看看效果吧!#

一个自定义 multi_pull 示例#

什么是 MultiPull?#

RefreshIndicator 主要用于滚动和重新加载,而 MultiPull 是其扩展,允许用户在滚动时根据出现的 widget 选择操作。虽然我在 appBar 中放置了操作项,但希望用户能更方便地访问它们。如果您的 appBar 中已有操作项,但希望使其更易用,可以将其放入 MultiPull 中,用户只需滚动即可访问!

所以简单来说,让我们直接看效果!

如何安装#

dependencies:
  multi_pull: 1.1.0

开始使用#

MultiPull 的使用方式与 RefreshIndicator 类似。它通过将 Scrollable Widget(如 ListView)作为子组件来工作。然后将操作项放置在 actionWidgets 中,并包装在 ActionWidget 中以在拖动时显示为选项。别忘了设置 action 或 onRefresh 来定义当用户选择操作时会发生什么。

import 'package:multi_pull/multi_pull.dart';

// 示例代码省略其他部分...

Scaffold(
  appBar: AppBar(
    title: Text("Second Page"),
  ),
  body: MultiPull(
    circleMoveDuration: Duration(milliseconds: 400), // 设置圆形动画的持续时间
    circleMoveCurve: Curves.easeInOut, // 设置圆形动画的曲线
    circleIndicator: DefaultCircle( // 设置圆形指示器的样式
      circleColor: Colors.grey,
      circleOpacity: 0.2,
    ),
    pullIndicators: [ // 定义多个下拉选项
      DefaultPullIndicator(
        icon: Icon(Icons.arrow_back_ios_outlined), // 左箭头图标
        label: Text("back"), // 文本标签
        onPull: () => Navigator.pop(context), // 点击后返回上一页
      ),
      DefaultPullIndicator(
        icon: Icon(Icons.refresh_rounded), // 刷新图标
        onPull: () async => await Future.delayed(Duration(seconds: 2)), // 模拟异步操作
      ),
      DefaultPullIndicator(
        icon: Icon(Icons.backspace_outlined), // 清除图标
        label: Text("clear", style: TextStyle(color: Colors.redAccent)), // 文本标签
        onPull: () { // 清空文本框内容
          _firstTextController.clear();
          _secondTextController.clear();
          _thirdTextController.clear();
        },
      ),
    ],
    child: ListView( // 下拉刷新的内容
      physics: AlwaysScrollableScrollPhysics(),
      children: [
        TextField(
          controller: _firstTextController,
        ),
        TextField(
          controller: _secondTextController,
        ),
        TextField(
          controller: _thirdTextController,
        ),
      ],
    ),
  ),
);

action 和 onRefresh 的区别很简单:如果需要执行异步处理,只需使用 onRefresh。实际上,action 也可以进行异步处理,但 onRefresh 会显示一个 RefreshIndicator 来表明正在执行异步操作。

完整示例代码

以下是一个完整的示例代码,展示了如何使用 multi_pull 插件:

import 'dart:async';

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

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
        visualDensity: VisualDensity.adaptivePlatformDensity,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key? key, required this.title}) : super(key: key);
  final String title;

  [@override](/user/override)
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          crossAxisAlignment: CrossAxisAlignment.center,
          children: [
            ElevatedButton(
              child: Text('简单下拉刷新页面'),
              onPressed: () =>
                  Navigator.push(context, MaterialPageRoute(builder: (context) => SimplePage())),
            ),
            ElevatedButton(
              child: Text('带标签的下拉刷新页面'),
              onPressed: () =>
                  Navigator.push(context, MaterialPageRoute(builder: (context) => LabelPage())),
            ),
          ],
        ),
      ),
    );
  }
}

class SimplePage extends StatefulWidget {
  SimplePage({Key? key}) : super(key: key);

  [@override](/user/override)
  SimplePageState createState() => SimplePageState();
}

class SimplePageState extends State<SimplePage> {
  final _firstTextController = TextEditingController();
  final _secondTextController = TextEditingController();
  final _thirdTextController = TextEditingController();

  [@override](/user/override)
  void initState() {
    super.initState();
    _firstTextController.text = "Hello";
    _secondTextController.text = "multi pull actions";
    _thirdTextController.text = "airy-swift";
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("Second Page"),
      ),
      body: MultiPull(
        circleMoveDuration: Duration(milliseconds: 400),
        circleMoveCurve: Curves.easeInOut,
        circleIndicator: DefaultCircle(
          circleColor: Colors.grey,
          circleOpacity: 0.2,
        ),
        pullIndicators: [
          DefaultPullIndicator(
            icon: Icon(Icons.arrow_back_ios_outlined),
            label: Text("back"),
            onPull: () => Navigator.pop(context),
          ),
          DefaultPullIndicator(
            icon: Icon(Icons.refresh_rounded),
            onPull: () async => await Future.delayed(Duration(seconds: 2)),
          ),
          DefaultPullIndicator(
            icon: Icon(Icons.backspace_outlined),
            label: Text("clear", style: TextStyle(color: Colors.redAccent)),
            onPull: () {
              _firstTextController.clear();
              _secondTextController.clear();
              _thirdTextController.clear();
            },
          ),
        ],
        child: ListView(
          physics: AlwaysScrollableScrollPhysics(),
          children: [
            TextField(
              controller: _firstTextController,
            ),
            TextField(
              controller: _secondTextController,
            ),
            TextField(
              controller: _thirdTextController,
            ),
          ],
        ),
      ),
    );
  }
}

class LabelPage extends StatelessWidget {
  const LabelPage();

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      body: MultiPull(
        circleMoveDuration: Duration(milliseconds: 400),
        circleMoveCurve: Curves.easeInOut,
        circleIndicator: ArrowIndicator(),
        pullIndicators: [
          LabelPullIndicator(
            label: "Back",
            onPull: () => Navigator.pop(context),
          ),
          LabelPullIndicator(
            label: "Refresh",
            onPull: () async => await Future.delayed(Duration(seconds: 2)),
          ),
        ],
        child: ListView(
          physics: AlwaysScrollableScrollPhysics(),
          children: [
            Center(child: Text("")),
          ],
        ),
      ),
    );
  }
}

更多关于Flutter多下拉刷新插件multi_pull的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter多下拉刷新插件multi_pull的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


multi_pull 是一个 Flutter 插件,用于实现多下拉刷新功能。它允许你在同一个页面中同时管理多个下拉刷新组件,并且可以分别控制它们的刷新行为。以下是如何使用 multi_pull 插件的基本步骤:

1. 添加依赖

首先,你需要在 pubspec.yaml 文件中添加 multi_pull 插件的依赖:

dependencies:
  flutter:
    sdk: flutter
  multi_pull: ^0.0.1  # 请检查最新版本

然后运行 flutter pub get 来获取依赖。

2. 导入包

在你的 Dart 文件中导入 multi_pull 包:

import 'package:multi_pull/multi_pull.dart';

3. 使用 MultiPull 组件

MultiPull 组件是 multi_pull 插件的核心组件。你可以在你的页面中使用它来管理多个下拉刷新组件。

以下是一个简单的示例:

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

class MultiPullExample extends StatefulWidget {
  [@override](/user/override)
  _MultiPullExampleState createState() => _MultiPullExampleState();
}

class _MultiPullExampleState extends State<MultiPullExample> {
  final MultiPullController _controller = MultiPullController();

  Future<void> _onRefresh(int index) async {
    // 模拟网络请求
    await Future.delayed(Duration(seconds: 2));
    // 刷新完成后调用
    _controller.completeRefresh(index);
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('MultiPull Example'),
      ),
      body: MultiPull(
        controller: _controller,
        children: [
          MultiPullChild(
            onRefresh: () => _onRefresh(0),
            child: ListView.builder(
              itemCount: 10,
              itemBuilder: (context, index) {
                return ListTile(
                  title: Text('Item $index'),
                );
              },
            ),
          ),
          MultiPullChild(
            onRefresh: () => _onRefresh(1),
            child: ListView.builder(
              itemCount: 10,
              itemBuilder: (context, index) {
                return ListTile(
                  title: Text('Item $index'),
                );
              },
            ),
          ),
        ],
      ),
    );
  }
}
回到顶部