|
|
|
@ -868,7 +868,7 @@ class _ChatDetailsPage extends State<ChatDetailsPage>
|
|
|
|
|
}, |
|
|
|
|
onTap:(){}, |
|
|
|
|
child: FutureBuilder( |
|
|
|
|
future: fetchImageSize(messages[position].attach), |
|
|
|
|
future: fetchImageSize(messages[position]), |
|
|
|
|
builder: (BuildContext context, AsyncSnapshot snapshot) { |
|
|
|
|
if (snapshot.connectionState == ConnectionState.waiting || snapshot.hasError) { |
|
|
|
|
return Image.file( |
|
|
|
@ -906,7 +906,7 @@ class _ChatDetailsPage extends State<ChatDetailsPage>
|
|
|
|
|
}, |
|
|
|
|
onTap:(){}, |
|
|
|
|
child: FutureBuilder( |
|
|
|
|
future: fetchImageSize(messages[position].attach), |
|
|
|
|
future: fetchImageSize(messages[position]), |
|
|
|
|
builder: (BuildContext context, AsyncSnapshot snapshot) { |
|
|
|
|
if (snapshot.connectionState == ConnectionState.waiting || snapshot.hasError) { |
|
|
|
|
return Image.file( |
|
|
|
@ -961,13 +961,18 @@ class _ChatDetailsPage extends State<ChatDetailsPage>
|
|
|
|
|
); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
Future<Size> fetchImageSize(String imagePath) async { |
|
|
|
|
debugPrint("$imagePath"); |
|
|
|
|
Future<Size> fetchImageSize(Message message) async { |
|
|
|
|
String imageLocalPath = message.attach; |
|
|
|
|
debugPrint("$imageLocalPath"); |
|
|
|
|
|
|
|
|
|
File file = File(imageLocalPath); |
|
|
|
|
if (!(await file.exists())) { |
|
|
|
|
await qiniu.downloadFile(message.content, savePath: imageLocalPath); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
Size size = Size.zero; |
|
|
|
|
Completer<Size> completer = Completer(); |
|
|
|
|
Image.file( |
|
|
|
|
File(imagePath), |
|
|
|
|
).image.resolve(ImageConfiguration()) |
|
|
|
|
Image.file(file).image.resolve(ImageConfiguration()) |
|
|
|
|
.addListener(ImageStreamListener((image, synchronousCall) { |
|
|
|
|
size = Size((image.image.width ?? 0).toDouble(), (image.image.height ?? 0).toDouble()); |
|
|
|
|
size = resizeImage(size); |
|
|
|
|