Hotfix loop audioplayer and scannerpage
parent
ed5b392cf6
commit
5a3eac1be2
|
@ -18,10 +18,7 @@ Die App lässt sich als Android- und iOS App ausführen und zu Debugzwecken eben
|
||||||
|
|
||||||
## App bedienen
|
## App bedienen
|
||||||
|
|
||||||
Um die App nutzen zu können, müssen Settings eingelesen werden. Dazu kann entweder ein in die App integrierter QR-Code Scanner (mit dem beigefügten [QR-Code](./gruppe1_QR.png)) benutzt werden, oder zu Debugzwecken mit dem dafür vorgesehenen Button auf der Scannerseite über eine lokale JSON-Datei.
|
Um die App nutzen zu können, müssen Settings eingelesen werden. Dazu kann entweder ein in die App integrierter QR-Code Scanner (mit dem beigefügten [QR-Code](./gruppe1_QR.png)) benutzt werden, oder zu Debugzwecken über eine lokale JSON-Datei. Es ist zu beachten, dass das verwendete QR-Code Scanner Package für Mobilgeräte optimiert ist. Deshalb kann es zu Abstürzen beim Verwenden des Scanners mit der Web-Version kommen. Beim Verwenden der Web-Version sollten die Settings mit der lokalen JSON-Datei eingelesen werden. Um beim Klick auf den Scan-Button die lokale JSON-Datei einzulesen, muss in der Datei [globals.dart](./lib/globals.dart) die Variable <code>bool useLocalConfig = true;</code> gesetzt werden.
|
||||||
Es ist zu beachten, dass das verwendete QR-Code Scanner Package für Mobilgeräte optimiert ist. Deshalb kann es zu Abstürzen beim Verwenden des Scanners mit der Web-Version kommen.
|
|
||||||
Beim Verwenden der Web-Version sollten die Settings mit der lokalen JSON-Datei eingelesen werden.
|
|
||||||
Der Button zum Einlesen der lokalen JSON-Datei kann über die Variable <code>bool useLocalConfig</code> in der Datei [globals.dart](./lib/globals.dart) ein- und ausgeblendet werden.
|
|
||||||
|
|
||||||
## Authoren
|
## Authoren
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,9 @@
|
||||||
import 'package:awesome_dialog/awesome_dialog.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:provider/provider.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:smoke_cess_app/services/export_service.dart';
|
import 'package:smoke_cess_app/services/export_service.dart';
|
||||||
import 'package:smoke_cess_app/services/settings_service.dart';
|
|
||||||
import 'package:smoke_cess_app/services/notification_service.dart';
|
|
||||||
import 'package:smoke_cess_app/widgets/buttons/text_icon_button.dart';
|
import 'package:smoke_cess_app/widgets/buttons/text_icon_button.dart';
|
||||||
import 'package:smoke_cess_app/widgets/scanner.dart';
|
import 'package:smoke_cess_app/widgets/scanner.dart';
|
||||||
import '../providers/settings_provider.dart';
|
import '../providers/settings_provider.dart';
|
||||||
import '../globals.dart' as globals;
|
|
||||||
|
|
||||||
class ScannerPage extends StatelessWidget {
|
class ScannerPage extends StatelessWidget {
|
||||||
const ScannerPage({super.key});
|
const ScannerPage({super.key});
|
||||||
|
@ -17,21 +13,6 @@ class ScannerPage extends StatelessWidget {
|
||||||
exportService.exportData();
|
exportService.exportData();
|
||||||
}
|
}
|
||||||
|
|
||||||
void loadJSON(BuildContext context) async {
|
|
||||||
SettingsProvider settingsModel = context.read<SettingsProvider>();
|
|
||||||
await loadSettingsFromLocalJSON();
|
|
||||||
settingsModel.initSettings();
|
|
||||||
NotificationService().setAllNotifications();
|
|
||||||
if (context.mounted) {
|
|
||||||
AwesomeDialog(
|
|
||||||
context: context,
|
|
||||||
dialogType: DialogType.success,
|
|
||||||
title: 'Geschafft',
|
|
||||||
desc: 'Die Einstellung wurden erfolgreich gespeichert',
|
|
||||||
).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
SettingsProvider settingsProvider = context.watch<SettingsProvider>();
|
SettingsProvider settingsProvider = context.watch<SettingsProvider>();
|
||||||
|
@ -47,13 +28,6 @@ class ScannerPage extends StatelessWidget {
|
||||||
text: 'Export',
|
text: 'Export',
|
||||||
onPressed: ExportService().exportData,
|
onPressed: ExportService().exportData,
|
||||||
iconData: Icons.upload),
|
iconData: Icons.upload),
|
||||||
if (globals.useLocalConfig && !settingsProvider.scanning)
|
|
||||||
ElevatedButton(
|
|
||||||
style: ElevatedButton.styleFrom(
|
|
||||||
textStyle: const TextStyle(fontSize: 20)),
|
|
||||||
onPressed: () => loadJSON(context),
|
|
||||||
child: const Text('Read JSON'),
|
|
||||||
),
|
|
||||||
],
|
],
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,6 +42,7 @@ class AudioProvider extends ChangeNotifier {
|
||||||
_audioPlayer.play(_beepSoundSource);
|
_audioPlayer.play(_beepSoundSource);
|
||||||
_onCompleteSubscription = _audioPlayer.onPlayerComplete.listen((event) {
|
_onCompleteSubscription = _audioPlayer.onPlayerComplete.listen((event) {
|
||||||
_audioPlayer.play(source);
|
_audioPlayer.play(source);
|
||||||
|
_audioPlayer.setReleaseMode(ReleaseMode.loop);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,7 @@ import 'package:smoke_cess_app/services/settings_service.dart';
|
||||||
import 'package:smoke_cess_app/widgets/buttons/text_icon_button.dart';
|
import 'package:smoke_cess_app/widgets/buttons/text_icon_button.dart';
|
||||||
import '../providers/settings_provider.dart';
|
import '../providers/settings_provider.dart';
|
||||||
import '../services/notification_service.dart';
|
import '../services/notification_service.dart';
|
||||||
|
import '../globals.dart' as globals;
|
||||||
|
|
||||||
class MyScanner extends StatelessWidget {
|
class MyScanner extends StatelessWidget {
|
||||||
const MyScanner({super.key});
|
const MyScanner({super.key});
|
||||||
|
@ -57,6 +58,21 @@ class MyScanner extends StatelessWidget {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void loadJSON(BuildContext context) async {
|
||||||
|
SettingsProvider settingsModel = context.read<SettingsProvider>();
|
||||||
|
await loadSettingsFromLocalJSON();
|
||||||
|
settingsModel.initSettings();
|
||||||
|
NotificationService().setAllNotifications();
|
||||||
|
if (context.mounted) {
|
||||||
|
AwesomeDialog(
|
||||||
|
context: context,
|
||||||
|
dialogType: DialogType.success,
|
||||||
|
title: 'Geschafft',
|
||||||
|
desc: 'Die Einstellung wurden erfolgreich gespeichert',
|
||||||
|
).show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return settingsProvider.scanning
|
return settingsProvider.scanning
|
||||||
? Expanded(
|
? Expanded(
|
||||||
child: Stack(
|
child: Stack(
|
||||||
|
@ -79,7 +95,9 @@ class MyScanner extends StatelessWidget {
|
||||||
))
|
))
|
||||||
: TextIconButton(
|
: TextIconButton(
|
||||||
text: "Scan",
|
text: "Scan",
|
||||||
onPressed: () => settingsProvider.scanning = true,
|
onPressed: globals.useLocalConfig
|
||||||
|
? () => loadJSON(context)
|
||||||
|
: () => settingsProvider.scanning = true,
|
||||||
iconData: Icons.qr_code_scanner_outlined);
|
iconData: Icons.qr_code_scanner_outlined);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue