TimeTracker/lib/pages/MapPage.dart
2025-05-15 19:49:19 -07:00

97 lines
2.5 KiB
Dart

import 'package:flutter/material.dart';
import 'package:flutter/widgets.dart';
import 'package:flutter_map/flutter_map.dart';
import 'package:latlong2/latlong.dart';
import 'package:libacflutter/Constants.dart';
import 'package:timetrack/data.dart';
class MapPage extends StatefulWidget {
MapPage({super.key});
@override
State<StatefulWidget> createState() {
return _MapPage();
}
}
class _MapPage extends State<MapPage> {
MapController controller = MapController();
LatLng initialPosition = LatLng(0, 0);
List<LatLng> PointMap = [];
@override
void didChangeDependencies() {
PointMap = [];
var firstPos = SessionData.positions[0];
initialPosition = LatLng(firstPos.latitude, firstPos.longitude);
for (var position in SessionData.positions) {
PointMap.add(LatLng(position.latitude, position.longitude));
}
setState(() {});
super.didChangeDependencies();
}
@override
void dispose() {
print("Map page disposed");
controller.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text("Time Tracker - Map View"),
backgroundColor: LibACFlutterConstants.TITLEBAR_COLOR,
actions: [
IconButton(
onPressed: () async {
didChangeDependencies();
},
icon: Icon(Icons.refresh),
),
],
),
body: GestureDetector(
onTap: FocusScope.of(context).unfocus,
child: SafeArea(
child: FlutterMap(
mapController: controller,
options: MapOptions(
minZoom: 1,
maxZoom: 30,
initialZoom: 15,
initialCenter: initialPosition,
keepAlive: false,
),
children: [
TileLayer(
urlTemplate: "https://tile.openstreetmap.org/{z}/{x}/{y}.png",
userAgentPackageName: "dev.zontreck.timetrack",
),
PolylineLayer(
polylines: [
Polyline(
points: PointMap,
color: Colors.blue,
borderStrokeWidth: 3,
borderColor: Colors.blue,
),
],
),
RichAttributionWidget(
attributions: [
TextSourceAttribution('OpenStreetMap contributors'),
],
),
],
),
),
),
);
}
}