Skip to content
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

Multiple Improvements & v5 Release Preparation #1532

Merged
merged 22 commits into from
Jun 4, 2023
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
03b5a42
Multiple changes, see PR body
JaffaKetchup May 25, 2023
2d33a22
Updated CHANGELOG
JaffaKetchup May 25, 2023
2764747
Added `offset` option to `FlutterMapState.move` and related methods (…
JaffaKetchup May 29, 2023
579b420
Updated CHANGELOG
JaffaKetchup May 29, 2023
434ce32
Ensure `id` of `MapController.move` is passed through to the emitted …
JaffaKetchup May 30, 2023
c6afe5c
Fixed regression in commit 2764747 where internal `MapController` sta…
JaffaKetchup May 30, 2023
48853f2
Added `rotateAroundPoint` - resolves #1460
JaffaKetchup May 30, 2023
8b117a5
Updated CHANGELOG
JaffaKetchup May 30, 2023
e8a361e
Added `TileLayer.fallbackUrl` support to `FileTileProvider`
JaffaKetchup May 31, 2023
68e2a38
Updated CHANGELOG
JaffaKetchup May 31, 2023
63c7948
Updated pubspec.yaml
JaffaKetchup May 31, 2023
59d3cc1
Removed `saveLayers` property from `PolylineLayer`
JaffaKetchup Jun 1, 2023
2857207
Updated CHANGELOG
JaffaKetchup Jun 1, 2023
4a89a47
Updated MacOS configuration
JaffaKetchup Jun 1, 2023
84e5bbc
Added more position options to `AnchorAlign`
JaffaKetchup Jun 2, 2023
6b6a7ae
Simplified `Anchor`
JaffaKetchup Jun 2, 2023
d372d1c
Updated version numbers
JaffaKetchup Jun 2, 2023
4035494
Fixed bug in example application
JaffaKetchup Jun 2, 2023
3edaf92
Added automated publishing action for tags in format 'v_._._'
JaffaKetchup Jun 3, 2023
a3a0304
Merge branch 'master' into jaffa
JaffaKetchup Jun 4, 2023
622fac5
Updated CHANGELOG
JaffaKetchup Jun 4, 2023
4cd419f
Added credit to CHANGELOG
JaffaKetchup Jun 4, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 0 additions & 5 deletions .github/workflows/build-io.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,11 +39,6 @@ jobs:
steps:
- name: Checkout Repository
uses: actions/checkout@v3
- name: Setup Java 17 Environment
uses: actions/setup-java@v3
with:
distribution: "temurin"
java-version: "17"
- name: Setup Flutter Environment
uses: subosito/flutter-action@v2
with:
Expand Down
5 changes: 4 additions & 1 deletion .github/workflows/pr.yml
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
name: PR CI/CD
name: Branch Push & PR CI/CD
on:
push:
branches:
- '!master'
pull_request:
workflow_dispatch:

Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/push.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Push CI/CD
name: Master Push CI/CD
on:
push:
branches:
Expand Down
49 changes: 49 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,54 @@
# Changelog

## [5.0.0] - 2023/XX/XX

**"Dart The Third"**

Contains the following API changes:

- Migrated to Flutter 3.10 and Dart 3.0 minimums - [#1512](https://github.com/fleaflet/flutter_map/pull/1512) & [#1517](https://github.com/fleaflet/flutter_map/pull/1517)
- Added offset capability to `FlutterMapState.move`/`MapController.move` methods - [#1532](https://github.com/fleaflet/flutter_map/pull/1532) for [#952](https://github.com/fleaflet/flutter_map/issues/952)
- Added `MapController.rotateAroundPoint` method - [#1532](https://github.com/fleaflet/flutter_map/pull/1532) for [#1460](https://github.com/fleaflet/flutter_map/issues/1460)
- Added `TileLayer.fallbackUrl` support to `FileTileProvider` - [#1532](https://github.com/fleaflet/flutter_map/pull/1532)
- Improved/stricter typing of `CustomPoint` - [#1515](https://github.com/fleaflet/flutter_map/pull/1515)
- Deprecated `TileUpdateTransformers.alwaysLoadAndPrune` in favour of `ignoreTapEvents` - [#1517](https://github.com/fleaflet/flutter_map/pull/1517)
- Removed `NetworkNoRetryTileProvider` in favour of custom `NetworkTileProvider.httpClient` - [#1512](https://github.com/fleaflet/flutter_map/pull/1512)
- Removed `FileTileProvider` fallback to `NetworkTileProvider` on web - [#1512](https://github.com/fleaflet/flutter_map/pull/1512)
- Removed `saveLayers` property from `PolylineLayer` - [#1532](https://github.com/fleaflet/flutter_map/pull/1532) & [#1519](https://github.com/fleaflet/flutter_map/pull/1519)
- Updated dependencies - [#1530](https://github.com/fleaflet/flutter_map/pull/1530)
- Updated 'latlong2' to access `const` `LatLng` objects
- Updated 'http'
- Removed 'tuple' in favour of built-in `Record`s ([#1517](https://github.com/fleaflet/flutter_map/pull/1517))

Contains the following bug fixes:

- Polylines with translucent fills and borders now paint properly - [#1519](https://github.com/fleaflet/flutter_map/pull/1519) for [#1510](https://github.com/fleaflet/flutter_map/issues/1510) & [#1420](https://github.com/fleaflet/flutter_map/issues/1420)
- Removed potential for jitter/frame delay when painting `Polyline`s & `Polygon`s - [#1514](https://github.com/fleaflet/flutter_map/pull/1514)
- Removed potential for un-`mounted` `setState` call in `RichAttributionWidget` - [#1532](https://github.com/fleaflet/flutter_map/pull/1532) for [#1538](https://github.com/fleaflet/flutter_map/issues/1538)
- Ensure `id` of `MapController.move` is passed through to the emitted `MapEventMove` - [#1534](https://github.com/fleaflet/flutter_map/pull/1534) in [#1532](https://github.com/fleaflet/flutter_map/pull/1532)

Contains the following performance improvements:

- Reduced unnecessary rebuilding in environments where `MediaQuery` changes frequently - [#1523](https://github.com/fleaflet/flutter_map/pull/1523)
- Use Flutter's default `CachingAssetBundle` in `AssetTileProvider` when `TileLayer.fallbackUrl` is not specified - [#1532](https://github.com/fleaflet/flutter_map/pull/1532) for [#1436](https://github.com/fleaflet/flutter_map/issues/1436)
- Improved performance of `TileProvider`s and `FlutterMapNetworkImageProvider` - [#1512](https://github.com/fleaflet/flutter_map/pull/1512)

In other news:

- You may have noticed some minor rebranding around the repo recently! The maintainers have finally gained full member access from the previous owner (thanks John :)) to the 'fleaflet' organisation and now have total control.
- We've launched a Live Web Demo so you can experiment with flutter_map without having to build from source yourself! Visit [demo.fleaflet.dev](https://demo.fleaflet.dev).
- [#1532](https://github.com/fleaflet/flutter_map/pull/1532) made some big changes to the structure/organization of flutter_map internals, which we hope should make it easier for new contributors to add code due to the reduction of the scope of responsibility of each source file.

Many thanks to these contributors (in no particular order):

- @josxha
- @ignatz
- @rorystephenson
- @tlserver
- ... and all the maintainers

And an additional special thanks to @josxha & @ignatz for investing so much of their time into this project recently - we appreciate it!

## [4.0.0] - 2023/05/05

**"Out With The Old, In With The New"**
Expand Down
3 changes: 1 addition & 2 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
Copyright (c) 2018-2023, the 'flutter_map' authors and maintainers
Loosely based on the original works of 'leaflet.js' (c) by Vladimir Agafonkin & CloudMade
Copyright (c) 2018-2023, the 'flutter_map' authors and maintainers, loosely based on the original works of 'leaflet.js' by Vladimir Agafonkin & CloudMade

All rights reserved.

Expand Down
19 changes: 12 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,20 +1,25 @@
# flutter_map

A versatile mapping package for Flutter, based off of ['leaflet.js'](https://leafletjs.com/). Simple and easy to learn, yet completely customizable and configurable, it's the best choice for mapping in your Flutter app.
A versatile mapping package for Flutter. Simple and easy to learn, yet completely customizable and configurable, it's the best choice for mapping in your Flutter app.

[![Pub.dev](https://img.shields.io/pub/v/flutter_map.svg?label=Latest+Version)](https://pub.dev/packages/flutter_map) [![Checks & Tests](https://badgen.net/github/checks/fleaflet/flutter_map?label=Checks+%26+Tests&color=orange)](https://github.com/fleaflet/flutter_map/actions?query=branch%3Amaster) [![points](https://img.shields.io/pub/points/flutter_map?logo=flutter)](https://pub.dev/packages/flutter_map/score)
[![stars](https://badgen.net/github/stars/fleaflet/flutter_map?label=stars&color=green&icon=github)](https://github.com/fleaflet/flutter_map/stargazers) [![likes](https://img.shields.io/pub/likes/flutter_map?logo=flutter)](https://pub.dev/packages/flutter_map/score)      [![Open Issues](https://badgen.net/github/open-issues/fleaflet/flutter_map?label=Open+Issues&color=green)](https://github.com/fleaflet/flutter_map/issues) [![Open PRs](https://badgen.net/github/open-prs/fleaflet/flutter_map?label=Open+PRs&color=green)](https://github.com/fleaflet/flutter_map/pulls)

---

## [Discord Server](https://discord.gg/egEGeByf4q)
## [Documentation](https://docs.fleaflet.dev/)

Join the Discord server: <https://discord.gg/egEGeByf4q>!
Visit our [documentation website](https://docs.fleaflet.dev/), for all information about how to use this library.
Additional documentation can be found in-code/whilst you type and over at the [pub.dev package](https://pub.dev/documentation/flutter_map/latest/flutter_map/flutter_map-library.html).

Talk about 'flutter_map', get and give help, and receive notifications about new 'flutter_map' updates! More additions planned in the future.
## [Live Web Demo](https://demo.fleaflet.dev/)

## [Documentation](https://docs.fleaflet.dev/)
> Please don't abuse the web demo! It runs on limited bandwidth and won't hold up to thousands of loads.
If you're going to be straining the application, please see the [Examples page in the docs](https://docs.fleaflet.dev/getting-started/examples), for information about building/using the application locally.

Want to see how flutter_map looks and works quickly? Just visit our [demo site](https://demo.fleaflet.dev/) that gets updated automatically with every new commit to 'master'!

Visit the [documentation website here](https://docs.fleaflet.dev/), for all information about how to use this library, including setup and usage instructions.
## [Get Help](https://docs.fleaflet.dev/#get-help)

Some documentation is also provided within the code and can be view inside your favourite editor. These docs are also over at the [pub.dev package](https://pub.dev/documentation/flutter_map/latest/flutter_map/flutter_map-library.html), and can be viewed from within your favourite editor.
Not sure about how to do something, or just want to chat? Pop over to our [Discord server](https://discord.gg/BwpEsjqMAH) to get support quickly, and to get notified about new releases!
Think you've found a bug, or would like to see a new feature? We'd love to hear about it! Please see the [Get Help section of our docs](https://docs.fleaflet.dev/#get-help) for information about what to do.
10 changes: 5 additions & 5 deletions example/lib/main.dart
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ import 'package:flutter_map_example/pages/marker_anchor.dart';
import 'package:flutter_map_example/pages/marker_rotate.dart';
import 'package:flutter_map_example/pages/max_bounds.dart';
import 'package:flutter_map_example/pages/moving_markers.dart';
import 'package:flutter_map_example/pages/network_tile_provider.dart';
import 'package:flutter_map_example/pages/offline_map.dart';
import 'package:flutter_map_example/pages/on_tap.dart';
import 'package:flutter_map_example/pages/overlay_image.dart';
Expand All @@ -36,22 +35,23 @@ import 'package:flutter_map_example/pages/tile_builder_example.dart';
import 'package:flutter_map_example/pages/tile_loading_error_handle.dart';
import 'package:flutter_map_example/pages/widgets.dart';
import 'package:flutter_map_example/pages/wms_tile_layer.dart';
import 'package:url_strategy/url_strategy.dart';

void main() => runApp(const MyApp());
void main() {
setPathUrlStrategy();
TesteurManiak marked this conversation as resolved.
Show resolved Hide resolved
runApp(const MyApp());
}

class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);

// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'flutter_map Demo',
theme: ThemeData.light(useMaterial3: true),
home: const HomePage(),
routes: <String, WidgetBuilder>{
NetworkTileProviderPage.route: (context) =>
const NetworkTileProviderPage(),
WidgetsPage.route: (context) => const WidgetsPage(),
TapToAddPage.route: (context) => const TapToAddPage(),
PolylinePage.route: (context) => const PolylinePage(),
Expand Down
153 changes: 120 additions & 33 deletions example/lib/pages/home.dart
Original file line number Diff line number Diff line change
@@ -1,49 +1,106 @@
import 'package:flutter/foundation.dart' show kIsWeb;
import 'package:flutter/material.dart';
import 'package:flutter/scheduler.dart';
import 'package:flutter_map/flutter_map.dart';
import 'package:flutter_map_example/widgets/drawer.dart';
import 'package:latlong2/latlong.dart';
import 'package:shared_preferences/shared_preferences.dart';
import 'package:url_launcher/url_launcher.dart';

class HomePage extends StatelessWidget {
class HomePage extends StatefulWidget {
static const String route = '/';

const HomePage({Key? key}) : super(key: key);

@override
Widget build(BuildContext context) {
final markers = <Marker>[
Marker(
width: 80,
height: 80,
point: const LatLng(51.5, -0.09),
builder: (ctx) => const FlutterLogo(
textColor: Colors.blue,
key: ObjectKey(Colors.blue),
),
),
Marker(
width: 80,
height: 80,
point: const LatLng(53.3498, -6.2603),
builder: (ctx) => const FlutterLogo(
textColor: Colors.green,
key: ObjectKey(Colors.green),
),
),
Marker(
width: 80,
height: 80,
point: const LatLng(48.8566, 2.3522),
builder: (ctx) => const FlutterLogo(
textColor: Colors.purple,
key: ObjectKey(Colors.purple),
),
),
];
State<HomePage> createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> {
@override
void initState() {
super.initState();

const seenIntroBoxKey = 'seenIntroBox(a)';
if (kIsWeb && Uri.base.host.trim() == 'demo.fleaflet.dev') {
SchedulerBinding.instance.addPostFrameCallback(
(_) async {
final prefs = await SharedPreferences.getInstance();
if (prefs.getBool(seenIntroBoxKey) ?? false) return;

if (!mounted) return;

final width = MediaQuery.of(context).size.width;
await showDialog<void>(
context: context,
builder: (context) => AlertDialog(
icon: UnconstrainedBox(
child: SizedBox.square(
dimension: 64,
child:
Image.asset('assets/ProjectIcon.png', fit: BoxFit.fill),
),
),
title: const Text('flutter_map Live Web Demo'),
content: ConstrainedBox(
constraints: BoxConstraints(
maxWidth: width < 750
? double.infinity
: (width / (width < 1100 ? 1.5 : 2.5)),
),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
const Text(
"This is built automatically off of the latest commits to 'master', so may not reflect the latest release available on pub.dev.\nThis is hosted on Firebase Hosting, meaning there's limited bandwidth to share between all users, so please keep loads to a minimum.",
textAlign: TextAlign.center,
),
Padding(
padding:
const EdgeInsets.only(right: 8, top: 16, bottom: 4),
child: Align(
alignment: Alignment.centerRight,
child: Text(
"This won't be shown again",
style: TextStyle(
color: Theme.of(context)
.colorScheme
.inverseSurface
.withOpacity(0.5),
),
textAlign: TextAlign.right,
),
),
),
],
),
),
actions: [
TextButton.icon(
onPressed: () => Navigator.of(context).pop(),
label: const Text('OK'),
icon: const Icon(Icons.done),
),
],
contentPadding: const EdgeInsets.only(
left: 24,
top: 16,
bottom: 0,
right: 24,
),
),
);
await prefs.setBool(seenIntroBoxKey, true);
},
);
}
}

@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Home')),
drawer: buildDrawer(context, route),
drawer: buildDrawer(context, HomePage.route),
body: Padding(
padding: const EdgeInsets.all(8),
child: Column(
Expand Down Expand Up @@ -82,7 +139,37 @@ class HomePage extends StatelessWidget {
'https://tile.openstreetmap.org/{z}/{x}/{y}.png',
userAgentPackageName: 'dev.fleaflet.flutter_map.example',
),
MarkerLayer(markers: markers),
MarkerLayer(
markers: [
Marker(
width: 80,
height: 80,
point: const LatLng(51.5, -0.09),
builder: (ctx) => const FlutterLogo(
textColor: Colors.blue,
key: ObjectKey(Colors.blue),
),
),
Marker(
width: 80,
height: 80,
point: const LatLng(53.3498, -6.2603),
builder: (ctx) => const FlutterLogo(
textColor: Colors.green,
key: ObjectKey(Colors.green),
),
),
Marker(
width: 80,
height: 80,
point: const LatLng(48.8566, 2.3522),
builder: (ctx) => const FlutterLogo(
textColor: Colors.purple,
key: ObjectKey(Colors.purple),
),
),
],
),
],
),
),
Expand Down
2 changes: 1 addition & 1 deletion example/lib/pages/latlng_to_screen_point.dart
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ class _LatLngScreenPointTestPageState extends State<LatLngScreenPointTestPage> {
onMapEvent: onMapEvent,
onTap: (tapPos, latLng) {
final pt1 = _mapController.latLngToScreenPoint(latLng);
_textPos = CustomPoint(pt1!.x, pt1.y);
_textPos = CustomPoint(pt1.x, pt1.y);
setState(() {});
},
center: const LatLng(51.5, -0.09),
Expand Down
Loading