1. Project introduction
Flutter is a popular cross-platform development technology. Due to its excellent performance, Flutter has attracted the attention of many front-end technology enthusiasts. Some big companies, such as Alibaba Xianyu, Meituan and Tencent, have been involved in the production and use of Flutter. The Flutter_chatroom project is a cross-platform wechat app chat interface application developed based on Flutter+Dart+ Chewie +photo_view+ Image_picker, etc. Realized message/expression sending, picture preview, long press menu, red envelope/small video/circle of friends and other functions.
2. Technical framework
- Techniques used: Flutter 1.12.13/Dart 2.7.0
- Video component: Chewie: ^0.9.7
- Image/Photo: image_picker: ^0.6.6+1
- Image preview component: photo_view: ^0.9.2
- Pop-up components: showModalBottomSheet/AlertDialog/SnackBar
- Local storage: shareD_preferences: ^0.5.7+1
- Font icon: Ali Iconfont font icon library
Since Flutter is based on dart, you need to install the DART Sdk/FLUTTER Sdk
flutter.cn/
flutterchina.club/
pub.flutter-io.cn/
www.dartcn.com/
With the vscode editor, Dart, Flutter, and Flutter widget snippets can be installed first
3, Flutter immersive status bar/bottom tabbar
How to implement an immersive transparent status bar with the top full background in Flutter (remove the black translucent background of the status bar) and remove the banner in the upper right corner can be found in this article segmentfault.com/a/11…
4, Flutter icon component /IconData custom encapsulation component
1, Use the system Icon component: Icon(Icons. Search) 2, use IconData mode: Icon(IconData(0xe60E, fontFamily:’ Iconfont ‘), size:24.0) Using the second method requires first downloading the Ali Icon Library font file and then importing the font in Pubspec.yaml
Static iconfont(int codePoint, {double size = 16.0, Color color}) { return Icon( IconData(codePoint, fontFamily: ‘iconfont’, matchTextDirection: true), size: size, color: color, ); }} call is very simple, can be customized color, font size; Gstyle.iconfont (0xe635, color: Colors. Orange, size: 17.0)
5, flutter to achieve badge red/dot prompt
There are no dot-tip components in FLUTTER and they need to be wrapped and implemented themselves.
Class GStyle {// message red badge(int count, {Color Color = Colors. Red, bool isdot = false, double height = 18.0, Double width = 18.0}) {final _num = count > 99? ‘… ‘: count; return Container( alignment: Alignment.center, height: ! isdot ? height : height/2, width: ! isdot ? Width: width/2, decoration: BoxDecoration(color: color, borderRadius: borderRadius. Circular (100.0)), child:! isdot ? Text(‘$_num’, style: TextStyle(color: color.white, fontSize: 12.0)) : null); }} Support custom red dot size, color, default number over 99… Display; GStyle. Badge (4, color: Colors. Orange, height: 15.0, width: 15.0) GStyle. Badge (5, color: Colors.
6. Long flutter according to custom pop-ups
How to implement long press in Flutter and pop up the menu in long press position, similar to the pop-up effect of wechat message long press;
Through the onTapDown event provided by the InkWell component to obtain the coordinate point implementation
InkWell( splashColor: Colors.grey[200], child: Container(…) , onTapDown: (TapDownDetails details) { _globalPositionX = details.globalPosition.dx; _globalPositionY = details.globalPosition.dy; }, onLongPress: () { _showPopupMenu(context); },), // Long press the popover double _globalPositionX = 0.0; // Double _globalPositionY = 0.0; Void _showPopupMenu(BuildContext context) {bool isLeft = _globalPositionX > MediaQuery.of(context).size.width/2 ? false : true; Bool isTop = _globalPositionY > mediaQuery.of (context).size. Height /2? false : true;
showDialog( context: context, builder: (context) { return Stack( children: <Widget>[ Positioned( top: IsTop? _globalPositionY: _globalpositionY-200.0, left: isLeft? _globalPositionX: _globalpositionx-120.0, width: 120.0, child: Material(...),)],); });Copy the code
} how does a flutter remove the AlertDialog popover size limit? This can be implemented through the SizedBox and UnconstrainedBox components
void _showCardPopup(BuildContext context) { showDialog( context: context, builder: (context) { return UnconstrainedBox( constrainedAxis: Axis.vertical, child: SizedBox( width: 260, child: AlertDialog( content: Container( … ) , elevation: 0, contentPadding: EdgeInsets. Symmetric (Horizontal: 10.0, vertical: 20.0),),); }); }
7, flutter login/registration form | local storage
Flutter provides two TextField components: TextField and TextFormField. This article uses TextField to implement flutter, and adds the clear TextField/password view icon after the TextField
TextField( keyboardType: TextInputType.phone, controller: TextEditingController.fromValue(TextEditingValue( text: formObj[‘tel’], selection: new TextSelection.fromPosition(TextPosition(affinity: TextAffinity.downstream, offset: FormObj [‘tel’].length)))), decoration: InputDecoration(hintText: “isDense: true “, hintStyle: TextStyle(fontSize: 14.0), suffixIcon: Visibility(visible: formObj[‘tel’]. IsNotEmpty, child: InkWell(child: Gstyle.iconfont (0xe69f, color: color.grey, size: 14.0), onTap: () {setState(() {formObj[‘tel’] = “; }); } ), ), border: OutlineInputBorder(borderSide: BorderSide.none) ), onChanged: (val) { setState(() { formObj[‘tel’] = val; }); },)
TextField(decoration: InputDecoration(hintText: “Please enter your password “, isDense: true, hintStyle: TextStyle(fontSize: SuffixIcon: InkWell(Child: Icon(formObj[‘isObscureText’]? Icons. Visibility_off: Icons. Visibility, color: Colors. Grey, size: 14.0), onTap: () { setState(() { formObj[‘isObscureText’] = ! formObj[‘isObscureText’]; }); }, ), border: OutlineInputBorder(borderSide: BorderSide.none) ), obscureText: formObj[‘isObscureText’], onChanged: (val) { setState(() { formObj[‘pwd’] = val; }); },) the validation message prompt is implemented using the SnackBar provided by Flutter
// SnackBar says final _scaffoldKey = new GlobalKey(); void _snackbar(String title, {Color color}) { _scaffoldkey.currentState.showSnackBar(SnackBar( backgroundColor: color ?? Colors.redAccent, content: Text(title), duration: Duration(seconds: 1), )); Local storage uses shared_preferences. See pub.flutter-io.cn/packages/sh…
Void handleSubmit() async {if(formObj[‘tel’] == ”) {_snackbar(‘ phone number cannot be empty ‘); }else if(! Util. CheckTel (formObj[‘tel’])) {_snackbar(‘ phone number format error ‘); } else if (formObj [‘ PWD ‘] = = ‘ ‘) {_snackbar (‘ password cannot be empty); }else { // … The interface data
/ / set the storage information final prefs = await SharedPreferences. GetInstance (); prefs.setBool('hasLogin', true); prefs.setInt('user', int.parse(formObj['tel'])); prefs.setString('token', Util.setToken()); _snackbar(' congratulations! ', color: Colors. GreenAccent [400]); Timer(Duration(seconds: 2), (){ Navigator.pushNamedAndRemoveUntil(context, '/tabbarpage', (route) => route == null); }); }Copy the code
} ##8, flutter chat page function
How to implement an editor like the one shown above in Flutter? This is done through the multi-line text box property maxLines provided by TextField. Container(margin: gstyle.margin (10.0), decoration: BoxDecoration(color: Colors. White, borderRadius: BorderRadius. Circular (3.0)), Constraints: BoxConstraints(minHeight: 30.0, maxHeight: 150.0), child: TextField( maxLines: null, keyboardType: TextInputType.multiline, decoration: InputDecoration( hintStyle: TextStyle(fontSize: 14.0), isDense: true, contentPadding: EdgeInsets. All (5.0), Border: OutlineInputBorder(borderSide: BorderSide.none) ), controller: _textEditingController, focusNode: _focusNode, onChanged: (val) { setState(() { editorLastCursor = _textEditingController.selection.baseOffset; }); }, onTap: () {handleEditorTaped(); },),), flutter scroll at the bottom of the chat messages to the most by the controller in the ListView attributes provide methods and _msgController jumpTo. Position. MaxScrollExtent
ScrollController _msgController = new ScrollController(); . ListView(Controller: _msgController, padding: EdgeInsets. All (10.0), children: renderMsgTpl(),)
Void scrollMsgBottom() {timer = timer (Duration(milliseconds: 100), () => _msgController.jumpTo(_msgController.position.maxScrollExtent)); } here are some chat room examples based on Flutter /dart development ~~💪💪