fluffychat merge

This commit is contained in:
ggurdin 2026-02-02 16:55:35 -05:00
commit abdd5c2be1
No known key found for this signature in database
GPG key ID: A01CB41737CBB478
3 changed files with 51 additions and 7 deletions

View file

@ -1,6 +1,7 @@
import 'dart:math' show min;
import 'dart:typed_data';
import 'dart:ui';
import 'package:image/image.dart';
import 'package:matrix/matrix.dart';
extension ClientDownloadContentExtension on Client {
@ -49,10 +50,10 @@ extension ClientDownloadContentExtension on Client {
var imageData = response.bodyBytes;
if (rounded) {
final image = decodeImage(imageData);
if (image != null) {
imageData = encodePng(copyCropCircle(image));
}
imageData = await _convertToCircularImage(
imageData,
min(width ?? 64, height ?? 64).round(),
);
}
await database.storeFile(cacheKey, imageData, 0);
@ -60,3 +61,43 @@ extension ClientDownloadContentExtension on Client {
return imageData;
}
}
Future<Uint8List> _convertToCircularImage(
Uint8List imageBytes,
int size,
) async {
final codec = await instantiateImageCodec(imageBytes);
final frame = await codec.getNextFrame();
final originalImage = frame.image;
final recorder = PictureRecorder();
final canvas = Canvas(recorder);
final paint = Paint();
final rect = Rect.fromLTWH(0, 0, size.toDouble(), size.toDouble());
final clipPath = Path()
..addOval(
Rect.fromCircle(center: Offset(size / 2, size / 2), radius: size / 2),
);
canvas.clipPath(clipPath);
canvas.drawImageRect(
originalImage,
Rect.fromLTWH(
0,
0,
originalImage.width.toDouble(),
originalImage.height.toDouble(),
),
rect,
paint,
);
final picture = recorder.endRecording();
final circularImage = await picture.toImage(size, size);
final byteData = await circularImage.toByteData(format: ImageByteFormat.png);
return byteData!.buffer.asUint8List();
}

View file

@ -55,7 +55,7 @@ extension LocalNotificationsExtension on MatrixState {
Uri? thumbnailUri;
if (avatarUrl != null) {
const size = 64;
const size = 128;
const thumbnailMethod = ThumbnailMethod.crop;
// Pre-cache so that we can later just set the thumbnail uri as icon:
await client.downloadMxcCached(
@ -64,6 +64,7 @@ extension LocalNotificationsExtension on MatrixState {
height: size,
thumbnailMethod: thumbnailMethod,
isThumbnail: true,
rounded: true,
);
thumbnailUri =
@ -100,6 +101,7 @@ extension LocalNotificationsExtension on MatrixState {
height: size,
thumbnailMethod: thumbnailMethod,
isThumbnail: true,
rounded: true,
);
final image = decodeImage(data);

View file

@ -1,5 +1,6 @@
#!/bin/sh -ve
./scripts/add-firebase-messaging.sh
flutter pub add fcm_shared_isolate:0.1.0
sed -i '' 's,//<GOOGLE_SERVICES>,,g' lib/utils/background_push.dart
yq eval '.dependencies.fcm_shared_isolate = "0.1.0"' -i pubspec.yaml # Workaround: 0.2.0 does not work on iOS
flutter clean
flutter pub get