【发布时间】:2020-10-30 15:57:38
【问题描述】:
我试图在我的应用程序中实现一个 AnimatedSwitcher 来为使用 firebase 作为后端的聊天设置动画,我已经看到了各种示例,但是当我尝试在聊天中发送新消息时,动画不起作用,这是我的代码:
return StreamBuilder(
stream: _chats,
builder: (context, snapshot) {
if (snapshot.hasData &&
!snapshot.hasError &&
snapshot.data.snapshot.value != null) {
item = [];
Map data = snapshot.data.snapshot.value;
data.forEach((index, data) => item.add({
"key": index,
"message": data['message'],
"sendBy": data['sendBy'],
"time": data['time']
}));
item.sort((b, a) => a["time"].compareTo(b["time"]));
return AnimatedSwitcher(
duration: Duration(milliseconds: 500),
child: ListView.builder(
reverse: true,
controller: _scrollController,
itemCount: item.length,
itemBuilder: (context, index) {
return MessageTile(
message: item[index]['message'],
sendByMe: widget.user.uid == item[index]['sendBy'],
time: item[index]['time']);
}),
);
} else {
return Container();
}
},
);
【问题讨论】:
标签: firebase flutter animation stream chat