| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- import 'dart:io';
- 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/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 SimilarPhotoController extends BaseController {
- final RxList<PhotoGroup> photoGroups = <PhotoGroup>[].obs;
- final RxDouble selectedFilesSize = 0.0.obs;
- RxInt selectedFileCount = 0.obs;
- Future<void> getSelectedFilesSize() async {
- double totalSize = 0;
- for (var group in photoGroups) {
- for (int i = 0; i < group.images.length; i++) {
- if (group.selectedImages[i]) {
- final file = await group.images[i].file;
- if (file != null) {
- totalSize += file.lengthSync();
- }
- }
- }
- }
- selectedFilesSize.value = totalSize / 1024; // Convert to KB
- }
- void toggleImageSelection(List<AssetEntity> groupTitle, int imageIndex) {
- final group = _getGroupByImages(groupTitle);
- final image = group.images[imageIndex];
- final selected = !group.selectedImages[imageIndex];
- group.selectedImages[imageIndex] = selected;
- _updateSelectedSimilarPhotosIds(image.id, selected);
- group.isSelected.value = group.selectedImages.every((selected) => selected);
- selectedFileCount.value = ImagePickerUtil.selectedSimilarPhotosIds.length;
- getSelectedFilesSize();
- }
- void clickImage(List<AssetEntity> images , int imageIndex) {
- final group = _getGroupByImages(images);
- final image = group.images[imageIndex];
- PhotoPreviewPage.start(PhotosType.similarPhotos,image.id);
- }
- void toggleGroupSelection(List<AssetEntity> imagesList) {
- final group = _getGroupByImages(imagesList);
- final newValue = !group.isSelected.value;
- group.toggleSelectAll(newValue);
- for (var image in group.images) {
- _updateSelectedSimilarPhotosIds(image.id, newValue);
- }
- selectedFileCount.value = ImagePickerUtil.selectedSimilarPhotosIds.length;
- getSelectedFilesSize();
- }
- PhotoGroup _getGroupByImages(List<AssetEntity> images) {
- return photoGroups.firstWhere((g) => g.images == images);
- }
- void _updateSelectedSimilarPhotosIds(String photoId, bool isSelected) {
- if (isSelected) {
- ImagePickerUtil.selectedSimilarPhotosIds.add(photoId);
- } else {
- ImagePickerUtil.selectedSimilarPhotosIds.remove(photoId);
- }
- }
- void restoreSelections() async {
- final selectedIds = ImagePickerUtil.selectedSimilarPhotosIds.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 getSelectedFilesSize();
- selectedFileCount.value = selectedIds.length;
- }
- @override
- void onInit() {
- super.onInit();
- loadSimilarPhotos();
- restoreSelections();
- }
- void loadSimilarPhotos() {
- // 清空现有数据
- photoGroups.clear();
- // 加载相似图片
- for (var group in ImagePickerUtil.similarPhotos) {
- print('group.length ${group.length}, group[0].id ${group[0].id}');
- if (group.isNotEmpty) {
- photoGroups.add(PhotoGroup(
- title: 'photo : ${group.length}',
- imageCount: group.length,
- isSelected: false,
- images: group,
- ));
- }
- }
- }
- // 修改视图构建方法,使用 AssetEntity 而不是文件路径
- AssetEntity? getAssetById(String id) {
- for (var group in ImagePickerUtil.similarPhotos) {
- for (var asset in group) {
- if (asset.id == id) {
- return asset;
- }
- }
- }
- return null;
- }
- }
|