From 61f34d113c9f6941194a6ed3101f54158de722a3 Mon Sep 17 00:00:00 2001 From: Marcus Lum Date: Tue, 30 Aug 2016 13:37:07 -0400 Subject: Allow Custom Android MapRenderers to override the default MapView options (#285) * Allow Custom Android MapRenderers to override the default MapView options * Larger effort to use CreateNativeControl () everywhere instead of just in the Android AppCompat renderers. --- Xamarin.Forms.Maps.Android/MapRenderer.cs | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) (limited to 'Xamarin.Forms.Maps.Android/MapRenderer.cs') diff --git a/Xamarin.Forms.Maps.Android/MapRenderer.cs b/Xamarin.Forms.Maps.Android/MapRenderer.cs index a0a3bbc1..29270c0b 100644 --- a/Xamarin.Forms.Maps.Android/MapRenderer.cs +++ b/Xamarin.Forms.Maps.Android/MapRenderer.cs @@ -15,7 +15,7 @@ using System.Collections; namespace Xamarin.Forms.Maps.Android { - public class MapRenderer : ViewRenderer, + public class MapRenderer : ViewRenderer, GoogleMap.IOnCameraChangeListener { public MapRenderer () @@ -41,19 +41,24 @@ namespace Xamarin.Forms.Maps.Android return new SizeRequest (new Size (Context.ToPixels (40), Context.ToPixels (40))); } - protected override void OnElementChanged (ElementChangedEventArgs e) + protected override MapView CreateNativeControl() + { + return new MapView(Context); + } + + protected override void OnElementChanged (ElementChangedEventArgs e) { base.OnElementChanged (e); var oldMapView = (MapView)Control; - var mapView = new MapView (Context); + var mapView = CreateNativeControl(); mapView.OnCreate (s_bundle); mapView.OnResume (); SetNativeControl (mapView); if (e.OldElement != null) { - var oldMapModel = (Map) e.OldElement; + var oldMapModel = e.OldElement; ((ObservableCollection)oldMapModel.Pins).CollectionChanged -= OnCollectionChanged; MessagingCenter.Unsubscribe (this, MoveMessageName); -- cgit v1.2.3