From 394dc271373793a13b406fbf43bf5c5d7d0d162d Mon Sep 17 00:00:00 2001 From: Sebastian Date: Sat, 28 Oct 2023 11:10:30 +0200 Subject: [PATCH] perf: avoid unnecessarily creating new list on every frame (#1708) --- lib/src/map/widget.dart | 56 ++++++++++++++++++++++------------------- 1 file changed, 30 insertions(+), 26 deletions(-) diff --git a/lib/src/map/widget.dart b/lib/src/map/widget.dart index 5f7dd9042..2fedf63a5 100644 --- a/lib/src/map/widget.dart +++ b/lib/src/map/widget.dart @@ -139,38 +139,42 @@ class _FlutterMapStateContainer extends State Widget build(BuildContext context) { super.build(context); + final widgets = ClipRect( + child: Stack( + children: [ + Positioned.fill( + child: ColoredBox(color: widget.options.backgroundColor), + ), + ...widget.children.map( + (child) => TranslucentPointer( + translucent: widget.options.applyPointerTranslucencyToLayers, + child: child, + ), + ), + ...widget.nonRotatedChildren.map( + (child) => TranslucentPointer( + translucent: widget.options.applyPointerTranslucencyToLayers, + child: child, + ), + ), + ], + ), + ); + return LayoutBuilder( builder: (context, constraints) { _updateAndEmitSizeIfConstraintsChanged(constraints); return FlutterMapInteractiveViewer( controller: _flutterMapInternalController, - builder: (context, options, camera) => FlutterMapInheritedModel( - controller: _mapController, - options: options, - camera: camera, - child: ClipRect( - child: Stack( - children: [ - Positioned.fill( - child: ColoredBox(color: options.backgroundColor), - ), - ...widget.children.map( - (child) => TranslucentPointer( - translucent: options.applyPointerTranslucencyToLayers, - child: child, - ), - ), - ...widget.nonRotatedChildren.map( - (child) => TranslucentPointer( - translucent: options.applyPointerTranslucencyToLayers, - child: child, - ), - ), - ], - ), - ), - ), + builder: (context, options, camera) { + return FlutterMapInheritedModel( + controller: _mapController, + options: options, + camera: camera, + child: widgets, + ); + }, ); }, );