| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472 |
- import 'dart:convert';
- import 'dart:io';
- import 'package:airbridge_flutter_sdk/airbridge_flutter_sdk.dart';
- import 'package:classify_photo/classify_photo.dart';
- import 'package:clean/base/base_controller.dart';
- import 'package:clean/data/consts/constants.dart';
- import 'package:clean/data/repositories/event_repository.dart';
- import 'package:clean/data/repositories/user_repository.dart';
- import 'package:clean/module/image_picker/image_picker_util.dart';
- import 'package:clean/module/locations_photo/locations_photo_view.dart';
- import 'package:clean/module/people_photo/people_photo_view.dart';
- import 'package:clean/module/screenshots_blurry/screenshots_view.dart';
- import 'package:clean/module/similar_photo/similar_photo_view.dart';
- import 'package:clean/router/app_pages.dart';
- import 'package:clean/utils/toast_util.dart';
- import 'package:flutter/Material.dart';
- import 'package:get/get.dart';
- import 'package:permission_handler/permission_handler.dart';
- import 'package:wechat_assets_picker/wechat_assets_picker.dart';
- import '../../data/api/response/user_info_response.dart';
- import '../../data/consts/event_report_id.dart';
- import '../../data/repositories/config_repository.dart';
- import '../../handler/event_handler.dart';
- import '../../widget/multi_segment_circle_indicator.dart';
- class HomeController extends BaseController {
- Rx<double> totalSpace = 0.0.obs;
- Rx<double> usedSpace = 0.0.obs;
- Rx<double> photoSpace = 0.0.obs;
- Rx<double> freeSpace = 0.0.obs;
- Rx<String> totalSpaceStr = "".obs;
- Rx<String> usedSpaceStr = "".obs;
- Rx<String> photoSpaceStr = "".obs;
- Rx<String> freeSpaceStr = "".obs;
- // 计算已用存储百分比
- double get usedSpacePercentage => (usedSpace.value / totalSpace.value) * 100;
- // 计算照片占用存储百分比
- double get photoSpacePercentage =>
- (photoSpace.value / totalSpace.value) * 100;
- // 计算可用存储百分比
- double get freeSpacePercentage => (freeSpace.value / totalSpace.value) * 100;
- RxList<String> similarImages =
- List.generate(4, (index) => 'iconHomeNoPhoto').obs;
- RxInt imageCount = 0.obs;
- // 相似图片
- RxList<AssetEntity> similarPhotos = <AssetEntity>[].obs;
- // 人物图片
- RxList<AssetEntity> peoplePhotos = <AssetEntity>[].obs;
- // 地点图片
- Rx<AssetEntity?> locationPhoto = Rx<AssetEntity?>(null);
- // 截图照片
- Rx<AssetEntity?> screenshotPhoto = Rx<AssetEntity?>(null);
- // 模糊照片
- Rx<AssetEntity?> blurryPhoto = Rx<AssetEntity?>(null);
- // 是否扫描完成
- RxBool isSimilarScanned = false.obs;
- // 是否扫描完成
- RxBool isPeopleScanned = false.obs;
- // 是否扫描完成
- RxBool isScreenShotScanned = false.obs;
- // 是否扫描完成
- RxBool isBlurryScanned = false.obs;
- // 存储是否扫描完成
- RxBool isStorageScanned = false.obs;
- UserInfoResponse? get userInfo => userRepository.userInfo.value;
- List<PieData> get pieDataList => [
- PieData("PhotoSpace", photoSpacePercentage, Colors.blue),
- PieData("OtherUsed", usedSpacePercentage - photoSpacePercentage, Colors.red),
- PieData("totalSpace", totalSpace.value, Colors.grey.withOpacity(0.1)),
- ];
- @override
- Future<void> onInit() async {
- // TODO: implement onInit
- super.onInit();
- if (Platform.isAndroid) {
- await loadPhotosFromDirectory();
- // 延迟3秒
- Future.delayed(const Duration(seconds: 3), () {
- isStorageScanned.value = true;
- totalSpace.value = 200.0;
- usedSpace.value = 50.0;
- photoSpace.value = 30.0;
- freeSpace.value = 0.0;
- });
- }
- if (await Permission.photos.request().isGranted) {
- PhotoManager.clearFileCache();
- getStorageInfo();
- handlePhotos();
- } else {
- ToastUtil.show("Please enable the album permission");
- }
- configRepository.refreshConfig();
- await userRepository.getUserInfo();
- if (userRepository.userInfo.value != null) {
- Airbridge.setUserID(userRepository.userInfo.value!.ssid);
- // 接收归因结果
- Airbridge.setOnAttributionReceived((result) {
- print(result);
- Map<String, String> attr = <String, String>{};
- attr["attributedChannel"] = "Appstore";
- Airbridge.fetchDeviceUUID(onSuccess: (uuid) {
- eventRepository.attrPush(uuid, "airbridge", jsonEncode(result));
- });
- });
- }
- EventHandler.pushInstall();
- if (!isFirstIntoApp() && !userRepository.isVip()) {
- Get.toNamed(RoutePath.discount);
- }
- setFirstIntoApp(false);
- if (Platform.isAndroid) {
- loadPhotosFromDirectory();
- }
- if (await Permission.photos.request().isGranted) {
- PhotoManager.clearFileCache();
- getStorageInfo();
- // handlePhotos();
- await handleScreenPhotos();
- await handleBlurryPhotos();
- await handlePeoplePhotos();
- await handleSimilarPhotos();
- } else {
- ToastUtil.show("Please enable the album permission");
- }
- }
- @override
- void onReady() {
- super.onReady();
- // EventHandler.report(EventId.event_03000);
- }
- Future<void> loadPhotosFromDirectory() async {
- if (ImagePickerUtil.peoplePhotos.isEmpty ||
- ImagePickerUtil.similarPhotos.isEmpty ||
- ImagePickerUtil.locationPhotos.isEmpty ||
- ImagePickerUtil.screenshotPhotos.isEmpty) {
- try {
- final List<AssetEntity> result = await ImagePickerUtil.loadAssets();
- ImagePickerUtil.peoplePhotos.value = result ?? [];
- if (ImagePickerUtil.peoplePhotos.isNotEmpty) {
- for (var personPhotos in ImagePickerUtil.peoplePhotos) {
- peoplePhotos.add(personPhotos);
- if (peoplePhotos.length == 2) {
- break;
- }
- }
- }
- ImagePickerUtil.locationPhotos['location'] = result ?? [];
- if (ImagePickerUtil.locationPhotos.isNotEmpty) {
- // 获取第一个地点的第一张照片
- final firstLocationPhotos =
- ImagePickerUtil.locationPhotos.values.first;
- if (firstLocationPhotos.isNotEmpty) {
- var asset = firstLocationPhotos.first;
- locationPhoto.value = asset;
- }
- }
- ImagePickerUtil.screenshotPhotos.value = result ?? [];
- if (ImagePickerUtil.screenshotPhotos.isNotEmpty) {
- var asset = ImagePickerUtil.screenshotPhotos.first;
- screenshotPhoto.value = asset;
- }
- ImagePickerUtil.similarPhotos.add(result ?? []);
- if (ImagePickerUtil.similarPhotos.isNotEmpty) {
- for (var group in ImagePickerUtil.similarPhotos) {
- for (var asset in group) {
- similarPhotos.add(asset);
- if (similarPhotos.length == 4) {
- break;
- }
- }
- }
- }
- ImagePickerUtil.blurryPhotos.value = result ?? [];
- if (ImagePickerUtil.blurryPhotos.isNotEmpty) {
- var asset = ImagePickerUtil.blurryPhotos.first;
- blurryPhoto.value = asset;
- }
- } catch (e) {
- print('Error loading photos: $e');
- }
- }
- }
- Future<void> getStorageInfo() async {
- final classifyPhoto = ClassifyPhoto();
- try {
- final storageInfo = await classifyPhoto.getStorageInfo();
- // 转换为 GB
- final totalSpaceGB = storageInfo['totalSpace']! / (1000 * 1000 * 1000);
- final freeSpaceGB = storageInfo['freeSpace']! / (1024 * 1024 * 1024);
- final usedSpaceGB = storageInfo['usedSpace']! / (1024 * 1024 * 1024);
- final photoSpaceGB = storageInfo['photoSpace']! / (1024 * 1024 * 1024);
- totalSpaceStr.value = ImagePickerUtil.formatFileSize(
- storageInfo['totalSpace']!,
- decimals: 1);
- freeSpaceStr.value = ImagePickerUtil.formatFileSize(
- storageInfo['freeSpace']!,
- decimals: 1);
- usedSpaceStr.value = ImagePickerUtil.formatFileSize(
- storageInfo['usedSpace']!,
- decimals: 1);
- photoSpaceStr.value = ImagePickerUtil.formatFileSize(
- storageInfo['photoSpace']!,
- decimals: 1);
- totalSpace.value = totalSpaceGB.round().toDouble();
- freeSpace.value = freeSpaceGB;
- usedSpace.value = usedSpaceGB;
- photoSpace.value = photoSpaceGB;
- print('总容量: $totalSpaceStr');
- print('可用空间: $freeSpaceStr');
- print('已用空间: $usedSpaceStr');
- print('照片占用: $photoSpaceStr');
- isStorageScanned.value = true;
- } catch (e) {
- print('获取存储信息失败: $e');
- }
- }
- Future<void> handleScreenPhotos() async {
- final photoClassify = ClassifyPhoto();
- try {
- print('开始获取截图照片');
- final photos = await photoClassify.getScreenshots();
- print('获取截图照片完成: ${photos?.length ?? 0} 组照片');
- isScreenShotScanned.value = true;
- if (photos != null) {
- await ImagePickerUtil.updatePhotos(photos);
- if (ImagePickerUtil.screenshotPhotos.isNotEmpty) {
- var asset = ImagePickerUtil.screenshotPhotos.first;
- screenshotPhoto.value = asset;
- }
- }
- } catch (e, stackTrace) {
- print('获取照片失败: $e');
- print('Stack trace: $stackTrace');
- }
- }
- Future<void> handleBlurryPhotos() async {
- final photoClassify = ClassifyPhoto();
- try {
- print('开始获取模糊照片');
- final photos = await photoClassify.getBlurryPhotos();
- print('获取模糊照片完成: ${photos?.length ?? 0} 组照片');
- isBlurryScanned.value = true;
- if (photos != null) {
- await ImagePickerUtil.updatePhotos(photos);
- if (ImagePickerUtil.blurryPhotos.isNotEmpty) {
- var asset = ImagePickerUtil.blurryPhotos.first;
- blurryPhoto.value = asset;
- }
- }
- } catch (e, stackTrace) {
- print('获取照片失败: $e');
- print('Stack trace: $stackTrace');
- }
- }
- Future<void> handlePeoplePhotos() async {
- final photoClassify = ClassifyPhoto();
- try {
- print('开始获取人物照片');
- final photos = await photoClassify.getPeoplePhotos();
- print('获取人物照片完成: ${photos?.length ?? 0} 组照片');
- isPeopleScanned.value = true;
- if (photos != null) {
- await ImagePickerUtil.updatePhotos(photos);
- // 处理人物照片
- peoplePhotos.clear();
- if (ImagePickerUtil.peoplePhotos.isNotEmpty) {
- for (var personPhotos in ImagePickerUtil.peoplePhotos) {
- peoplePhotos.add(personPhotos);
- if (peoplePhotos.length == 2) {
- break;
- }
- }
- }
- }
- } catch (e, stackTrace) {
- print('获取照片失败: $e');
- print('Stack trace: $stackTrace');
- }
- }
- Future<void> handleSimilarPhotos() async {
- final photoClassify = ClassifyPhoto();
- try {
- print('开始获取相似照片');
- final photos = await photoClassify.getSimilarPhotos();
- print('获取相似照片完成: ${photos?.length ?? 0} 组照片');
- isSimilarScanned.value = true;
- if (photos != null) {
- await ImagePickerUtil.updatePhotos(photos);
- similarPhotos.clear();
- if (ImagePickerUtil.similarPhotos.isNotEmpty) {
- for (var group in ImagePickerUtil.similarPhotos) {
- for (var asset in group) {
- similarPhotos.add(asset);
- if (similarPhotos.length == 4) {
- break;
- }
- }
- }
- }
- }
- } catch (e, stackTrace) {
- print('获取照片失败: $e');
- print('Stack trace: $stackTrace');
- }
- }
- Future<void> handlePhotos() async {
- final photoClassify = ClassifyPhoto();
- try {
- print('开始获取照片');
- final photos = await photoClassify.getPhoto();
- print('获取照片完成: ${photos?.length ?? 0} 组照片');
- // 已完成扫描
- // isScanned.value = true;
- if (photos != null) {
- await ImagePickerUtil.updatePhotos(photos);
- similarPhotos.clear();
- if (ImagePickerUtil.similarPhotos.isNotEmpty) {
- for (var group in ImagePickerUtil.similarPhotos) {
- for (var asset in group) {
- similarPhotos.add(asset);
- if (similarPhotos.length == 4) {
- break;
- }
- }
- }
- }
- // 处理地点照片
- locationPhoto.value = null;
- if (ImagePickerUtil.locationPhotos.isNotEmpty) {
- // 获取第一个地点的第一张照片
- final firstLocationPhotos =
- ImagePickerUtil.locationPhotos.values.first;
- if (firstLocationPhotos.isNotEmpty) {
- var asset = firstLocationPhotos.first;
- locationPhoto.value = asset;
- }
- }
- // 处理人物照片
- peoplePhotos.clear();
- if (ImagePickerUtil.peoplePhotos.isNotEmpty) {
- for (var personPhotos in ImagePickerUtil.peoplePhotos) {
- peoplePhotos.add(personPhotos);
- if (peoplePhotos.length == 2) {
- break;
- }
- }
- }
- if (ImagePickerUtil.screenshotPhotos.isNotEmpty) {
- var asset = ImagePickerUtil.screenshotPhotos.first;
- screenshotPhoto.value = asset;
- }
- if (ImagePickerUtil.blurryPhotos.isNotEmpty) {
- var asset = ImagePickerUtil.blurryPhotos.first;
- blurryPhoto.value = asset;
- }
- }
- } catch (e, stackTrace) {
- print('获取照片失败: $e');
- print('Stack trace: $stackTrace');
- }
- }
- void _navigateAndStartPage(Function pageStartFunction) {
- // if (isFirstClickHomeClean()) {
- // setFirstClickHomeClean(false);
- // Get.toNamed(RoutePath.discount)?.then((value) {
- // pageStartFunction();
- // });
- // } else {
- pageStartFunction();
- // }
- }
- similarCleanClick() {
- print('similarCleanClick');
- EventHandler.report(EventId.event_03001);
- _navigateAndStartPage(SimilarPhotoPage.start);
- }
- peopleCleanClick() {
- print('peopleCleanClick');
- EventHandler.report(EventId.event_03002);
- _navigateAndStartPage(PeoplePhotoPage.start);
- }
- locationCleanClick() {
- print('locationCleanClick');
- EventHandler.report(EventId.event_03003);
- _navigateAndStartPage(LocationsPhotoPage.start);
- }
- screenshotCleanClick() {
- print('screenshotCleanClick');
- EventHandler.report(EventId.event_03004);
- _navigateAndStartPage(() => ScreenshotsPage.start("Screenshots"));
- }
- blurryCleanClick() {
- print('blurCleanClick');
- EventHandler.report(EventId.event_03005);
- _navigateAndStartPage(() => ScreenshotsPage.start("Blurry"));
- }
- titleVipClick() {
- EventHandler.report(EventId.event_02000);
- Get.toNamed(RoutePath.store);
- }
- }
|