Tracking now works via timed interval
This commit is contained in:
@@ -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(),
|
||||
],
|
||||
),
|
||||
|
||||
@@ -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'),
|
||||
],
|
||||
),
|
||||
),
|
||||
|
||||
Reference in New Issue
Block a user