-
-
Notifications
You must be signed in to change notification settings - Fork 868
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
How to convert screen position to LatLng and/or vise versa? #607
Comments
Check out gestures.dart's LatLng _offsetToCrs(Offset offset) {
// Get the widget's offset
var renderObject = context.findRenderObject() as RenderBox;
var width = renderObject.size.width;
var height = renderObject.size.height;
// convert the point to global coordinates
var localPoint = _offsetToPoint(offset);
var localPointCenterDistance =
CustomPoint((width / 2) - localPoint.x, (height / 2) - localPoint.y);
var mapCenter = map.project(map.center);
var point = mapCenter - localPointCenterDistance;
return map.unproject(point);
} |
@maRci002 thanks for pointing me towards that. How would I access the function? From what I can tell there's no way other than forking this repo and making it a public function. |
Even if you make it public method you cannot go that deep easily. Write something like this: import 'package:flutter/material.dart';
import 'package:flutter_map/flutter_map.dart';
import 'package:latlong/latlong.dart';
import '../widgets/drawer.dart';
class EsriPage extends StatefulWidget {
static const String route = 'esri';
@override
_EsriPageState createState() => _EsriPageState();
}
class _EsriPageState extends State<EsriPage> {
MapController mapController;
@override
void initState() {
super.initState();
mapController = MapController();
}
LatLng _offsetToCrs(Crs crs, Offset offset, BoxConstraints constraints,
[LatLng initCenter, double initZoom]) {
var center = mapController.ready ? mapController.center : initCenter;
var zoom = mapController.ready ? mapController.zoom : initZoom;
if (center == null || zoom == null) {
return null;
}
// Get the widget's offset
var width = constraints.maxWidth;
var height = constraints.maxHeight;
// convert the point to global coordinates
var localPoint = CustomPoint(offset.dx, offset.dy);
var localPointCenterDistance =
CustomPoint((width / 2) - localPoint.x, (height / 2) - localPoint.y);
var mapCenter = crs.latLngToPoint(center, zoom);
var point = mapCenter - localPointCenterDistance;
return crs.pointToLatLng(point, zoom);
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text('Esri')),
drawer: buildDrawer(context, EsriPage.route),
body: Padding(
padding: EdgeInsets.all(8.0),
child: Column(
children: [
Padding(
padding: EdgeInsets.only(top: 8.0, bottom: 8.0),
child: Text('Esri'),
),
Flexible(
child: LayoutBuilder(
builder: (BuildContext context, BoxConstraints constraints) {
print(
_offsetToCrs(
const Epsg3857(),
Offset(12.0, 12.0),
constraints,
// optional center should be same as MapOptions' center
// if not provided then _offsetToCrs will return null at very first build because mapController isn't ready
LatLng(45.5231, -122.6765),
// optional zoom should be same as MapOptions' zoom
// if not provided then _offsetToCrs will return null at very first build because mapController isn't ready
13.0,
),
);
return FlutterMap(
mapController: mapController,
options: MapOptions(
crs: const Epsg3857(),
center: LatLng(45.5231, -122.6765),
zoom: 13.0,
onTap: (l) {
print(l);
print(_offsetToCrs(
const Epsg3857(), Offset(12.0, 12.0), constraints));
},
),
layers: [
TileLayerOptions(
urlTemplate:
'https://server.arcgisonline.com/ArcGIS/rest/services/World_Street_Map/MapServer/tile/{z}/{y}/{x}',
),
],
);
},
),
),
],
),
),
);
}
}
|
@maRci002 that's great. Thanks for the help! |
@iwishiwasaneagle This was a while ago but can you try this? |
…nt (#1115) * Added MapController.pointToLatLng() to get LatLng of given screen point Ref #496, ref #607, ref #981, ref #1010 * Better pointToLatLng example * dartfmt * Fix zoom breaking pointToLatLng() * Updated example to help fix the rotation issue * Rebased on latest * Fix pointToLatLng with rotation * Fix trailing lines (3x attempts) Co-authored-by: Polo <gitpjp@pm.me> and ibrierley
I'm trying to move a widget relative to the map, and need to be able to either move the map relative to the widget's screen position or vise versa. Any suggestions?
The text was updated successfully, but these errors were encountered: