mirror of
https://gitlab.com/famedly/fluffychat.git
synced 2024-12-18 10:52:34 +01:00
123a9b000c
Prior the pointer in the map bubble wasn't offsetted upwards, so the center of the icon marked the point, rather than the point of the icon as one would expect. Additionally, attribution to the OpenStreetMap project has been added.
88 lines
2.8 KiB
Dart
88 lines
2.8 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_map/flutter_map.dart';
|
|
import 'package:latlong2/latlong.dart';
|
|
|
|
class MapBubble extends StatelessWidget {
|
|
final double latitude;
|
|
final double longitude;
|
|
final double zoom;
|
|
final double width;
|
|
final double height;
|
|
final double radius;
|
|
const MapBubble({
|
|
this.latitude,
|
|
this.longitude,
|
|
this.zoom = 14.0,
|
|
this.width = 400,
|
|
this.height = 400,
|
|
this.radius = 10.0,
|
|
Key key,
|
|
}) : super(key: key);
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return ClipRRect(
|
|
borderRadius: BorderRadius.circular(radius),
|
|
child: Container(
|
|
constraints: BoxConstraints.loose(Size(width, height)),
|
|
child: AspectRatio(
|
|
aspectRatio: width / height,
|
|
child: Stack(
|
|
children: <Widget>[
|
|
FlutterMap(
|
|
options: MapOptions(
|
|
center: LatLng(latitude, longitude),
|
|
zoom: zoom,
|
|
),
|
|
layers: [
|
|
TileLayerOptions(
|
|
urlTemplate:
|
|
'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',
|
|
subdomains: ['a', 'b', 'c'],
|
|
),
|
|
MarkerLayerOptions(
|
|
rotate: true,
|
|
markers: [
|
|
Marker(
|
|
point: LatLng(latitude, longitude),
|
|
width: 30,
|
|
height: 30,
|
|
builder: (_) => Transform.translate(
|
|
// No idea why the offset has to be like this, instead of -15
|
|
// It has been determined by trying out, though, that this yields
|
|
// the tip of the location pin to be static when zooming.
|
|
// Might have to do with psychological perception of where the tip exactly is
|
|
offset: const Offset(0, -12.5),
|
|
child: const Icon(
|
|
Icons.location_pin,
|
|
color: Colors.red,
|
|
size: 30,
|
|
),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
],
|
|
),
|
|
Container(
|
|
alignment: Alignment.bottomRight,
|
|
child: Text(
|
|
' © OpenStreetMap contributors ',
|
|
style: TextStyle(
|
|
color: Theme.of(context).brightness == Brightness.dark
|
|
? Colors.white
|
|
: Colors.black,
|
|
backgroundColor:
|
|
Theme.of(context).appBarTheme.backgroundColor,
|
|
),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|