一个功能强大的Flutter开源聊天列表插件

flutter_im_list是一款高性能、轻量级的Flutter聊天列表插件。可以帮助你快速创建出类微信的聊天列表的效果。

目录

预览图

整体长按输入中动图
flutter_im_listflutter_im_listflutter_im_listflutter_im_list

示例

视频教程

欢迎通过视频教程学习交流。

如何使用

第一步添加依赖

在项目根目录下运行:

flutter pub add flutter_im_list

第二步:初始化ChatController


void initState() {
super.initState();
chatController = ChatController(
    initialMessageList: _messageList,
    timePellet: 60,
    scrollController: ScrollController());
}

第三步:在布局中添加ChatList

  
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Text(widget.title),
        ),
        body: ChatList(
          chatController: chatController,
        ));
  }

第四步:设置初始化数据

final List<MessageModel> _messageList = [
MessageModel(
    id: 1,
    content: "介绍下《ChatGPT + Flutter快速开发多端聊天机器人App》",
    ownerType: OwnerType.sender,
    createdAt: 1696142392000,
    avatar: 'https://o.devio.org/images/o_as/avatar/tx18.jpeg',
    ownerName: "Jack"),
MessageModel(
    id: 2,
    content:
        "当前ChatGPT应用如雨后春笋般应运而生,给移动端开发者也带来了极大的机会。本课程将整合ChatGPT与Flutter高级技术,手把手带你从0到1开发一款可运行在多端的聊天机器人App,帮助你抓住机遇,快速具备AI运用能力,成为移动端领域的AI高手。@https://coding.imooc.com/class/672.html",
    ownerType: OwnerType.receiver,
    createdAt: 1696142393000,
    avatar: 'https://o.devio.org/images/o_as/avatar/tx2.jpeg',
    ownerName: "ChatGPT"),
];

如果没有,可以将_messageList赋值为[]。

了解更多请查看视频教程

API

IChatController

abstract class IChatController {
  /// 在列表中添加消息
  void addMessage(MessageModel message);
  /// 在列表中删除消息
  void deleteMessage(MessageModel message);
  /// 批量添加消息(适用于下来加载更多的场景)
  void loadMoreData(List<MessageModel> messageList);
}

ChatController

class ChatController implements IChatController {
  /// 列表的初始化数据可以为[]
  final List<MessageModel> initialMessageList;
  final ScrollController scrollController;

  ///支持提供一个MessageWidgetBuilder来自定义气泡样式
  final MessageWidgetBuilder? messageWidgetBuilder;

  ///设置显示的时间分组的间隔,单位秒
  final int timePellet;
  List<int> pelletShow = [];

  ChatController({required this.initialMessageList,
    required this.scrollController,
    required this.timePellet,
    this.messageWidgetBuilder}) {
    for (var message in initialMessageList.reversed) {
      inflateMessage(message);
    }
  }
...

ChatList

class ChatList extends StatefulWidget {
  /// ChatList的控制器
  final ChatController chatController;

  /// 插入子项的空间大小
  final EdgeInsetsGeometry? padding;

  /// 气泡点击事件
  final OnBubbleClick? onBubbleTap;

  /// 奇葩长按事件
  final OnBubbleClick? onBubbleLongPress;
  /// 文本选择回调
  final HiSelectionArea? hiSelectionArea;

  const ChatList(
      {super.key,
      required this.chatController,
      this.padding,
      this.onBubbleTap,
      this.onBubbleLongPress,
      this.hiSelectionArea});

  
  State<ChatList> createState() => _ChatListState();
}

了解更多请查看视频教程

Contribution

欢迎在issues上报告问题。请附上bug截图和代码片段。解决问题的最快方法是在示例中重现它。

欢迎提交拉取请求。如果您想更改API或执行重大操作,最好先创建一个问题并进行讨论。


MIT Licensed

Flutter一个开源的移动应用开发框架,由谷歌公司开发并维护。它允许开发者使用一套代码构建高性能、具有漂亮用户界面的应用程序,同时可以在iOS和Android等多个平台上运行。Flutter的特点之一是它使用了自己的渲染引擎,可以实现跨平台的高性能渲染,而且Flutter还支持响应式编程模式,使得开发者能够更方便地处理用户界面的交互和更新。 由于Flutter开源项目,任何开发者都可以查看和修改其源代码。这为开发者提供了更大的自由度和灵活性,可以根据自己的需求进行定制和优化。同时,Flutter开源性也促进了社区的发展和合作,开发者可以互相交流和分享经验,共同推动Flutter的进步。 在Flutter开源项目中,有许多优秀的第三方库和插件可供使用。这些库和插件丰富了Flutter的功能和扩展性,开发者可以根据自己的需求引入和使用。同时,开发者也可以贡献自己的代码或解决方案,为开源社区做出贡献。 Flutter开源项目还包括一些示例应用和教程资源,供开发者学习和参考。这些资源展示了Flutter的各种功能和用法,帮助开发者更好地理解和掌握Flutter的开发技巧。 总之,Flutter作为一个开源项目,不仅提供了一个强大的移动应用开发框架,还促进了开发者社区的合作和创新。通过开源Flutter能够更好地满足开发者的需求,并推动移动应用开发行业的不断发展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值