| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- import 'package:clean/base/base_controller.dart';
- import 'package:clean/data/bean/photos_type.dart';
- import 'package:clean/module/image_picker/image_picker_util.dart';
- import 'package:clean/module/locations_photo/locations_photo_controller.dart';
- import 'package:clean/module/people_photo/photo_group.dart';
- import 'package:clean/module/photo_preview/photo_preview_view.dart';
- import 'package:get/get.dart';
- import 'package:wechat_assets_picker/wechat_assets_picker.dart';
- class LocationsSinglePhotoController extends BaseController {
- late final PhotoGroup photoGroup;
- final RxInt selectedFileCount = 0.obs;
- final RxList<PhotoGroup> photoGroups = <PhotoGroup>[].obs;
- final RxDouble selectedFilesSize = 0.0.obs;
- @override
- void onInit() {
- // TODO: implement onInit
- super.onInit();
- _getArgs();
- loadLocationsSinglePhoto();
- restoreSelections();
- }
- void clickImage(String location, int imageIndex) {
- final group = getGroupByLocation(location);
- final image = group.images[imageIndex];
- PhotoPreviewPage.start(PhotosType.locationPhotos, image.id);
- }
- void toggleImageSelection(String groupTitle, int imageIndex) {
- final group = getGroupByLocation(groupTitle);
- final image = group.images[imageIndex];
- final selected = !group.selectedImages[imageIndex];
- group.selectedImages[imageIndex] = selected;
- _updateSelectedScreenshotsPhotosIds(image.id, selected);
- group.isSelected.value = group.selectedImages.every((selected) => selected);
- updateSelectedFilesSize();
- selectedFileCount.value = ImagePickerUtil.selectedLocationPhotosIds.length;
- }
- Future<void> updateSelectedFilesSize() async {
- double totalSize = 0;
- for (var id in ImagePickerUtil.selectedLocationPhotosIds) {
- final entity = await AssetEntity.fromId(id);
- if (entity != null) {
- final file = await entity.file;
- if (file != null) {
- totalSize += await file.length();
- }
- }
- }
- selectedFilesSize.value = totalSize / 1024; // Convert to KB
- }
- void _updateSelectedScreenshotsPhotosIds(String photoId, bool isSelected) {
- if (isSelected) {
- ImagePickerUtil.selectedLocationPhotosIds.add(photoId);
- } else {
- ImagePickerUtil.selectedLocationPhotosIds.remove(photoId);
- }
- }
- // 获取参数
- void _getArgs() {
- photoGroup = parameters?['PhotoGroup'];
- }
- void loadLocationsSinglePhoto() {
- photoGroups.clear();
- photoGroups.add(photoGroup);
- }
- void restoreSelections() async {
- final selectedIds = ImagePickerUtil.selectedLocationPhotosIds.toSet();
- for (var group in photoGroups) {
- for (int i = 0; i < group.images.length; i++) {
- group.selectedImages[i] = selectedIds.contains(group.images[i].id);
- }
- group.isSelected.value = group.selectedImages.every((selected) => selected);
- }
- await updateSelectedFilesSize();
- selectedFileCount.value = selectedIds.length;
- }
- void toggleGroupSelection(String location) {
- final group = getGroupByLocation(location);
- final newValue = !group.isSelected.value;
- group.toggleSelectAll(newValue);
- for (var image in group.images) {
- _updateSelectedScreenshotsPhotosIds(image.id, newValue);
- }
- updateSelectedFilesSize();
- selectedFileCount.value = ImagePickerUtil.selectedLocationPhotosIds.length;
- }
- // 通过标题获取照片组
- PhotoGroup _getGroupByTitle(String groupTitle) {
- return photoGroups.firstWhere((g) => g.title == groupTitle);
- }
- // 通过位置获取照片组
- PhotoGroup getGroupByLocation(String? location) {
- return photoGroups.firstWhere((group) => group.location == location);
- }
- }
|