aria2c 按需加载

This commit is contained in:
2024-02-24 17:41:44 +08:00
parent 27b5d9259f
commit ca2f584f20
6 changed files with 77 additions and 43 deletions

View File

@ -37,18 +37,22 @@ class DownloadsUIModel extends BaseUIModel {
onTapButton(String key) async {
switch (key) {
case "pause_all":
await Aria2cManager.aria2c.pauseAll();
if (!Aria2cManager.isAvailable) return;
await Aria2cManager.getClient().pauseAll();
return;
case "resume_all":
await Aria2cManager.aria2c.unpauseAll();
if (!Aria2cManager.isAvailable) return;
await Aria2cManager.getClient().unpauseAll();
return;
case "cancel_all":
final userOK = await showConfirmDialogs(
context!, "确认取消全部任务?", const Text("如果文件不再需要,你可能需要手动删除下载文件。"));
if (userOK == true) {
if (!Aria2cManager.isAvailable) return;
try {
for (var value in [...tasks, ...waitingTasks]) {
await Aria2cManager.aria2c.remove(value.gid!);
await Aria2cManager.getClient().remove(value.gid!);
}
} catch (e) {
dPrint("DownloadsUIModel cancel_all Error: $e");
@ -65,12 +69,15 @@ class DownloadsUIModel extends BaseUIModel {
try {
while (true) {
if (!mounted) return;
tasks.clear();
tasks = await Aria2cManager.aria2c.tellActive();
waitingTasks = await Aria2cManager.aria2c.tellWaiting(0, 1000000);
stoppedTasks = await Aria2cManager.aria2c.tellStopped(0, 1000000);
globalStat = await Aria2cManager.aria2c.getGlobalStat();
notifyListeners();
if (Aria2cManager.isAvailable) {
final aria2c = Aria2cManager.getClient();
tasks.clear();
tasks = await aria2c.tellActive();
waitingTasks = await aria2c.tellWaiting(0, 1000000);
stoppedTasks = await aria2c.tellStopped(0, 1000000);
globalStat = await aria2c.getGlobalStat();
notifyListeners();
}
await Future.delayed(const Duration(seconds: 1));
}
} catch (e) {
@ -136,14 +143,17 @@ class DownloadsUIModel extends BaseUIModel {
}
Future<void> resumeTask(String? gid) async {
final aria2c = Aria2cManager.getClient();
if (gid != null) {
await Aria2cManager.aria2c.unpause(gid);
await aria2c.unpause(gid);
}
}
Future<void> pauseTask(String? gid) async {
final aria2c = Aria2cManager.getClient();
if (gid != null) {
await Aria2cManager.aria2c.pause(gid);
await aria2c.pause(gid);
}
}
@ -153,7 +163,8 @@ class DownloadsUIModel extends BaseUIModel {
final ok = await showConfirmDialogs(
context!, "确认取消下载?", const Text("如果文件不再需要,你可能需要手动删除下载文件。"));
if (ok == true) {
await Aria2cManager.aria2c.remove(gid);
final aria2c = Aria2cManager.getClient();
await aria2c.remove(gid);
}
}
}
@ -220,12 +231,13 @@ class DownloadsUIModel extends BaseUIModel {
],
));
if (ok == true) {
await handleError(() => Aria2cManager.launchDaemon());
final aria2c = Aria2cManager.getClient();
final upByte = Aria2cManager.textToByte(upCtrl.text.trim());
final downByte = Aria2cManager.textToByte(downCtrl.text.trim());
final r = await handleError(
() => Aria2cManager.aria2c.changeGlobalOption(Aria2Option()
..maxOverallUploadLimit = upByte
..maxOverallDownloadLimit = downByte));
final r = await handleError(() => aria2c.changeGlobalOption(Aria2Option()
..maxOverallUploadLimit = upByte
..maxOverallDownloadLimit = downByte));
if (r != null) {
await box.put('downloader_up_limit', upCtrl.text.trim());
await box.put('downloader_down_limit', downCtrl.text.trim());

View File

@ -108,13 +108,17 @@ class IndexUIModel extends BaseUIModel {
void _listenAria2c() async {
while (true) {
if (!mounted) return;
try {
aria2globalStat = await Aria2cManager.aria2c.getGlobalStat();
notifyListeners();
if (Aria2cManager.isAvailable) {
final aria2c = Aria2cManager.getClient();
aria2globalStat = await aria2c.getGlobalStat();
notifyListeners();
}
} catch (e) {
dPrint("aria2globalStat update error:$e");
}
await Future.delayed(const Duration(seconds: 10));
await Future.delayed(const Duration(seconds: 5));
}
}
}

View File

@ -1,6 +1,5 @@
import 'package:starcitizen_doctor/api/analytics.dart';
import 'package:starcitizen_doctor/base/ui_model.dart';
import 'package:starcitizen_doctor/common/conf/binary_conf.dart';
import 'package:starcitizen_doctor/common/conf/url_conf.dart';
import 'package:starcitizen_doctor/common/io/aria2c.dart';
import 'package:starcitizen_doctor/ui/index_ui.dart';
@ -29,8 +28,7 @@ class SplashUIModel extends BaseUIModel {
await AppConf.checkUpdate();
step = 2;
notifyListeners();
await handleError(() => BinaryModuleConf.extractModel());
await handleError(() => Aria2cManager.launchDaemon());
await Aria2cManager.checkLazyLoad();
Navigator.pushAndRemoveUntil(
context!,
BaseUIContainer(

View File

@ -381,13 +381,17 @@ class ToolsUIModel extends BaseUIModel {
return;
}
/// 启动模块
await handleError(() => Aria2cManager.launchDaemon());
final aria2c = Aria2cManager.getClient();
try {
final b64Str = base64Encode(btData.data!);
final gid = await Aria2cManager.aria2c
.addTorrent(b64Str, extraParams: {"dir": savePath});
final gid =
await aria2c.addTorrent(b64Str, extraParams: {"dir": savePath});
_working = false;
dPrint("Aria2cManager.aria2c.addUri resp === $gid");
await Aria2cManager.aria2c.saveSession();
await aria2c.saveSession();
BaseUIContainer(
uiCreate: () => DownloadsUI(),
modelCreate: () => DownloadsUIModel()).push(context!);