Tracking now works via timed interval

This commit is contained in:
Nico
2025-06-04 22:03:15 +02:00
parent 940995f2dc
commit 4b88071700
3 changed files with 121 additions and 49 deletions

View File

@@ -22,7 +22,7 @@ class Tracking extends StatefulWidget {
class _TrackingState extends State<Tracking> {
final TrackingService _trackingService = TrackingService();
LocationMarkerPosition? locationMarkerPosition;
Position? currentPosition;
MapController mapController = MapController();
StreamSubscription? _positionSubscription;
StreamSubscription? _statsSubscription;
@@ -48,11 +48,7 @@ class _TrackingState extends State<Tracking> {
}
}
locationMarkerPosition = LocationMarkerPosition(
latitude: widget.startPosition.latitude,
longitude: widget.startPosition.longitude,
accuracy: widget.startPosition.accuracy,
);
currentPosition = widget.startPosition;
// Initialisiere die Statistiken sofort
setState(() {
@@ -62,11 +58,7 @@ class _TrackingState extends State<Tracking> {
_positionSubscription = _trackingService.positionStream$.listen((position) {
setState(() {
locationMarkerPosition = LocationMarkerPosition(
latitude: position.latitude,
longitude: position.longitude,
accuracy: position.accuracy,
);
currentPosition = position;
});
});
@@ -163,11 +155,7 @@ class _TrackingState extends State<Tracking> {
if (_trackingService.isTracking) {
_trackingService.pauseTracking();
} else {
if (_trackingService.positionStream == null) {
_trackingService.startTracking(context);
} else {
_trackingService.resumeTracking();
}
_trackingService.startTracking(context);
}
});
},
@@ -181,8 +169,8 @@ class _TrackingState extends State<Tracking> {
onPressed: () {
mapController.move(
LatLng(
locationMarkerPosition!.latitude,
locationMarkerPosition!.longitude,
currentPosition!.latitude,
currentPosition!.longitude,
),
16,
);
@@ -218,6 +206,31 @@ class _TrackingState extends State<Tracking> {
),
],
),
if (currentPosition != null)
CircleLayer(
circles: [
CircleMarker(
point: LatLng(
currentPosition!.latitude,
currentPosition!.longitude,
),
radius: currentPosition!.accuracy,
color: Colors.blue.withOpacity(0.2),
borderColor: Colors.blue,
borderStrokeWidth: 2,
),
CircleMarker(
point: LatLng(
currentPosition!.latitude,
currentPosition!.longitude,
),
radius: 5,
color: Colors.blue,
borderColor: Colors.white,
borderStrokeWidth: 2,
),
],
),
CurrentLocationLayer(),
],
),

View File

@@ -10,36 +10,75 @@ class Settings extends StatefulWidget {
}
class _SettingsState extends State<Settings> {
int _trackingInterval = 60;
@override
void initState() {
super.initState();
_loadSettings();
}
Future<void> _loadSettings() async {
SharedPreferences prefs = await SharedPreferences.getInstance();
setState(() {
_trackingInterval = prefs.getInt('trackingInterval') ?? 60;
});
}
Future<void> _saveTrackingInterval(int value) async {
SharedPreferences prefs = await SharedPreferences.getInstance();
await prefs.setInt('trackingInterval', value);
setState(() {
_trackingInterval = value;
});
}
Future<String> _getSaveDir() async {
SharedPreferences prefs = await SharedPreferences.getInstance();
final String saveDir = prefs.getString('saveDir') ?? "";
return saveDir;
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text(AppLocalizations.of(context)!.settings),),
body: Center(
body: Padding(
padding: const EdgeInsets.all(16.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(AppLocalizations.of(context)!.filelocation, style: const TextStyle(fontSize: 20),),
FutureBuilder(future: _getSaveDir(), builder: (context, snapshot) {
if (snapshot.connectionState == ConnectionState.done) {
return Text(snapshot.data ?? "");
} else {
return const CircularProgressIndicator();
FutureBuilder(
future: _getSaveDir(),
builder: (context, snapshot) {
if (snapshot.connectionState == ConnectionState.done) {
return Text(snapshot.data ?? "");
} else {
return const CircularProgressIndicator();
}
}
}),
ElevatedButton(onPressed: () {
}, child: Text(AppLocalizations.of(context)!.open))
),
ElevatedButton(
onPressed: () {},
child: Text(AppLocalizations.of(context)!.open)
),
const SizedBox(height: 24),
const Text(
'Tracking Interval (Sekunden)',
style: TextStyle(fontSize: 20),
),
Slider(
value: _trackingInterval.toDouble(),
min: 10,
max: 300,
divisions: 29,
label: _trackingInterval.toString(),
onChanged: (double value) {
_saveTrackingInterval(value.round());
},
),
Text('Aktuelles Intervall: $_trackingInterval Sekunden'),
],
),
),