我试图通过复制WhatsApp来学习Flutter。我在WhatsApp中以讲话气泡格式显示消息时遇到了问题。
我试图查看Google的教程,但他们的信使教程只使用直线行。
有人能指出我正确的方向吗?
谢谢!
答案 0 :(得分:14)
import 'package:flutter/material.dart';
class Bubble extends StatelessWidget {
Bubble({this.message, this.time, this.delivered, this.isMe});
final String message, time;
final delivered, isMe;
@override
Widget build(BuildContext context) {
final bg = isMe ? Colors.white : Colors.greenAccent.shade100;
final align = isMe ? CrossAxisAlignment.start : CrossAxisAlignment.end;
final icon = delivered ? Icons.done_all : Icons.done;
final radius = isMe
? BorderRadius.only(
topRight: Radius.circular(5.0),
bottomLeft: Radius.circular(10.0),
bottomRight: Radius.circular(5.0),
)
: BorderRadius.only(
topLeft: Radius.circular(5.0),
bottomLeft: Radius.circular(5.0),
bottomRight: Radius.circular(10.0),
);
return Column(
crossAxisAlignment: align,
children: <Widget>[
Container(
margin: const EdgeInsets.all(3.0),
padding: const EdgeInsets.all(8.0),
decoration: BoxDecoration(
boxShadow: [
BoxShadow(
blurRadius: .5,
spreadRadius: 1.0,
color: Colors.black.withOpacity(.12))
],
color: bg,
borderRadius: radius,
),
child: Stack(
children: <Widget>[
Padding(
padding: EdgeInsets.only(right: 48.0),
child: Text(message),
),
Positioned(
bottom: 0.0,
right: 0.0,
child: Row(
children: <Widget>[
Text(time,
style: TextStyle(
color: Colors.black38,
fontSize: 10.0,
)),
SizedBox(width: 3.0),
Icon(
icon,
size: 12.0,
color: Colors.black38,
)
],
),
)
],
),
)
],
);
}
}
class BubbleScreen extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: Colors.blueGrey.shade50,
appBar: AppBar(
backgroundColor: Colors.white,
elevation: .9,
title: Text(
'Putra',
style: TextStyle(color: Colors.green),
),
leading: IconButton(
icon: Icon(
Icons.arrow_back_ios,
color: Colors.green,
),
onPressed: () {},
),
actions: <Widget>[
IconButton(
icon: Icon(
Icons.videocam,
color: Colors.green,
),
onPressed: () {},
),
IconButton(
icon: Icon(
Icons.call,
color: Colors.green,
),
onPressed: () {},
),
IconButton(
icon: Icon(
Icons.more_vert,
color: Colors.green,
),
onPressed: () {},
)
],
),
body: Padding(
padding: EdgeInsets.all(16.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: <Widget>[
Bubble(
message: 'Hi there, this is a message',
time: '12:00',
delivered: true,
isMe: false,
),
Bubble(
message: 'Whatsapp like bubble talk',
time: '12:01',
delivered: true,
isMe: false,
),
Bubble(
message: 'Nice one, Flutter is awesome',
time: '12:00',
delivered: true,
isMe: true,
),
Bubble(
message: 'I\'ve told you so dude!',
time: '12:00',
delivered: true,
isMe: false,
),
],
),
),
);
}
}
答案 1 :(得分:2)
您应该使用以下现成的小部件: https://pub.dev/packages/bubble 易于实施 将此粘贴到依赖项部分pubspec.yaml中:
bubble: ^1.1.9+1
然后像这样使用它:
Bubble(
color: Color.fromRGBO(212, 234, 244, 1.0),
child: Text('TODAY', textAlign: TextAlign.center, style: TextStyle(fontSize: 11.0)),
),
答案 2 :(得分:0)
如果您想在此处添加带有可点击链接的自动换行代码,请修改我的代码。
child: Container(
constraints: BoxConstraints(
maxWidth: 250,
minWidth: 20
),
child: Linkify(
onOpen: (url) => ReusableWidget.launchUrl(url.url),
text: message,
style: TextStyle(fontSize: 16)
),
),