import 'dart:convert'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'package:flutter_screenutil/flutter_screenutil.dart'; import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; import 'package:huixiang/data/user_info.dart'; import 'package:huixiang/generated/l10n.dart'; import 'package:huixiang/qr/qr_share_image.dart'; import 'package:huixiang/utils/font_weight.dart'; import 'package:huixiang/utils/shared_preference.dart'; import 'package:huixiang/view_widget/my_appbar.dart'; import 'package:shared_preferences/shared_preferences.dart'; class QrSharePage extends StatefulWidget { @override State createState() { return _QrSharePage(); } } class _QrSharePage extends State { String? phone = ""; @override void initState() { super.initState(); String user = SharedInstance.instance.userJson; if (user.isNotEmpty) { phone = UserInfo.fromJson(jsonDecode(user)).inviteCode; } buildImageInfo(); } @override void dispose() { super.dispose(); } @override Widget build(BuildContext context) { if (height == 0) height = MediaQuery.of(context).size.height; return Scaffold( appBar: MyAppBar( title: "", titleColor: Colors.black, background: Color(0xFFF7F7F7), leadingColor: Colors.black, action: Container( alignment: Alignment.center, margin: EdgeInsets.only(right: 16.w), child: InkWell( onTap: () { if (phone?.isEmpty ?? true) return; SmartDialog.show( builder: (ctx) => QrShareImagePage(phone!), clickMaskDismiss: true, ); }, child: Icon( Icons.share, color: Colors.black, size: 24.w, ), ), ), ), body: SingleChildScrollView( child: Container( height: height, child: Stack( children: [ Positioned( child: Image.asset( "assets/image/qr_share_bg.webp", fit: BoxFit.fill, ), top: 0, left: 0, bottom: 0, right: 0, ), Positioned( child: Container( width: MediaQuery.of(context).size.width, height: height * 0.635, padding: EdgeInsets.symmetric( vertical: 28.h, horizontal: 19.w, ), child: Stack( children: [ Positioned( child: Image.asset( "assets/image/qr_share_info_bg.webp", fit: BoxFit.fill, ), top: 0, left: 0, bottom: 0, right: 0, ), Column( mainAxisAlignment: MainAxisAlignment.spaceEvenly, crossAxisAlignment: CrossAxisAlignment.center, children: [ shareTypeTitle(S.of(context).wodeyaoqingma), Container( margin: EdgeInsets.only(left: 16.w, right: 24.w), child: GestureDetector( child: SelectableText( // S.of(context).baocunsaoma, phone ?? "", textAlign: TextAlign.center, style: TextStyle( color: Color(0xFF2E3552), fontSize: 40.sp, fontWeight: MyFontWeight.semi_bold, ), ), onTap: this.copy(phone), )), // Container( // width: 152.w, // height: 152.w, // decoration: BoxDecoration( // border: Border.all( // color: Color(0xFF2E3552), // width: 1, // ), // ), // child: QrImage( // data: "http://mp.hx.lotus-wallet.com/pages/invite/index?mobile=${phone ?? ""}", // version: QrVersions.auto, // size: 200.w, // gapless: true, // ), // ), shareTypeTitle(S.of(context).haoyoujiangliguize), Container( margin: EdgeInsets.only(left: 16.w, right: 24.w), child: Text( // S.of(context).fenxiangyaoqing, S.of(context).fenxiangyaoqingma, textAlign: TextAlign.center, style: TextStyle( height: 1.5, color: Color(0xFF2E3552), fontSize: 16.sp, fontWeight: MyFontWeight.regular, ), ), ), // Container( // margin: EdgeInsets.only(left: 16.w, right: 24.w), // child: Text( // // S.of(context).fenxiangyaoqing, // S.of(context).beiyaoqingdejiangli, // textAlign: TextAlign.center, // style: TextStyle( // color: Color(0xFF2E3552), // fontSize: 16.sp, // fontWeight: MyFontWeight.regular, // ), // ), // ), SizedBox( height: 1.h, ), ], ), ], ), ), left: 0, bottom: 0, right: 0, ), ], ), ), ), ); } Widget shareTypeTitle(typeText) { return Container( width: 140.w, height: 30.h, child: Text( typeText, style: TextStyle( fontWeight: MyFontWeight.regular, fontSize: 16.sp, color: Color(0xFF2E3552), ), ), alignment: Alignment.center, decoration: BoxDecoration( color: Color(0xFFFFC93B), border: Border.all( color: Color(0xFF2E3552), width: 1, ), ), ); } double height = 0; buildImageInfo() async { Image image = Image.asset("assets/image/qr_share_bg_yq.webp"); image.image .resolve(ImageConfiguration()) .addListener(ImageStreamListener((ImageInfo info, bool _) { height = info.image.height.toDouble(); setState(() {}); })); } copy(String? phone) { if (phone?.isEmpty ?? true) { return; } Clipboard.setData(ClipboardData(text: phone!)); } }