Xamarin.Forms.Maps 1.4.0.6336-pre1

This is a prerelease version of Xamarin.Forms.Maps.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Xamarin.Forms.Maps --version 1.4.0.6336-pre1
                    
NuGet\Install-Package Xamarin.Forms.Maps -Version 1.4.0.6336-pre1
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Xamarin.Forms.Maps" Version="1.4.0.6336-pre1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Xamarin.Forms.Maps" Version="1.4.0.6336-pre1" />
                    
Directory.Packages.props
<PackageReference Include="Xamarin.Forms.Maps" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Xamarin.Forms.Maps --version 1.4.0.6336-pre1
                    
#r "nuget: Xamarin.Forms.Maps, 1.4.0.6336-pre1"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#addin nuget:?package=Xamarin.Forms.Maps&version=1.4.0.6336-pre1&prerelease
                    
Install Xamarin.Forms.Maps as a Cake Addin
#tool nuget:?package=Xamarin.Forms.Maps&version=1.4.0.6336-pre1&prerelease
                    
Install Xamarin.Forms.Maps as a Cake Tool

Maps models and renderers for Xamarin.Forms

Product Compatible and additional computed target framework versions.
MonoAndroid monoandroid10 is compatible. 
MonoTouch monotouch10 is compatible. 
Windows Phone wp8 is compatible.  wp81 was computed. 
Xamarin.iOS xamarinios10 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (20)

Showing the top 20 popular GitHub repositories that depend on Xamarin.Forms.Maps:

Repository Stars
xamarin/Xamarin.Forms
Xamarin.Forms is no longer supported. Migrate your apps to .NET MAUI.
xamarin/xamarin-forms-samples
Sample apps built using the Xamarin.Forms framework
xamarin/xamarin-forms-book-samples
Code samples for "Creating Mobile Apps with Xamarin.Forms"
xamarinhq/app-conference
Pre-build conference application built with Xamarin
microsoft/SmartHotel360-Mobile
SmartHotel360 Mobile
conceptdev/xamarin-forms-samples
Samples that use Xamarin.Forms (http://xamarin.com/forms)
xamarin/app-crm
davidortinau/Xappy
A mobile app to track Xamarin news and explore all the goodness that is .NET for Mobile developers
xamarinhq/app-myshoppe
Cross-platform Xamarin.Forms sample for managing stores.
paulpatarinski/Xamarin.Forms.Plugins
Xamarin Forms Plugins
chrfalch/NControl
Simple Xamarin.Forms wrapper control around the NGraphics library
Samsung/Tizen-CSharp-Samples
Tizen C# Samples for Mobile, Wearable, and TV profiles.
UdaraAlwis/Xamarin-Playground
Random cool stuff I play around using Xamarin.. :3 Some of these cool projects I feature them on my blog, with step by step explanation. :) Don't forget to check it out. Go to: theconfuzedsourcecode.wordpress.com
microsoft/app-innovation-workshop
Hands-on workshop designed to help you learn Azure, Mobile & AI
awolf/Xamarin-Forms-InAnger
Xamarin.Forms in Anger code from www.SyntaxismyUI.com my old blog where I wrote about mobile development with Xamarin, iOS and Android.
egvijayanand/dotnet-maui-templates
.NET MAUI Project and Item Templates for VS2022 and CLI.
rdelrosario/xamarin-plugins
Cross platform Xamarin & Windows plugins for PCLs
TorbenK/TK.CustomMap
Extended Map Control
jamesmontemagno/app-monkeychat
Monkey Chat application feature Twilio IP Messaging
sthewissen/KickassUI.Runkeeper
A Xamarin.Forms version of the Runkeeper app to prove you can create goodlooking UI with Xamarin.Forms
Version Downloads Last updated
2.0.1.6492-pre1 166 12/3/2015
2.0.0.6490 2,327 12/1/2015
2.0.0.6484 1,079 11/21/2015
2.0.0.6482 1,750 11/17/2015
1.5.2.6478-pre3 68 11/17/2015
1.5.2.6477-pre2 128 11/10/2015
1.5.2.6469-pre1 207 10/20/2015
1.5.1.6471 3,966 10/20/2015
1.5.1.6468 354 10/20/2015
1.5.1.6460-pre2 148 10/13/2015
1.5.1.6455-pre1 243 10/2/2015
1.5.0.6447 4,869 9/25/2015
1.5.0.6446 1,597 9/16/2015
1.5.0.6404-pre3 349 8/25/2015
1.5.0.6401-pre2 142 8/21/2015
1.5.0.6396-pre1 176 8/5/2015
1.4.4.6449 196 9/25/2015
1.4.4.6443 194 9/16/2015
1.4.4.6392 5,080 7/29/2015
1.4.4.6391 244 7/28/2015
1.4.4.6387 392 7/27/2015
1.4.4.6379-pre3 182 7/20/2015
1.4.4.6378-pre2 128 7/16/2015
1.4.4.6377-pre1 128 7/14/2015
1.4.3.6376 2,723 7/9/2015
1.4.3.6374 2,374 7/1/2015
1.4.3.6372 227 6/30/2015
1.4.3.6364-pre3 177 6/16/2015
1.4.3.6358-pre2 328 4/24/2015
1.4.3.6356-pre1 152 4/21/2015
1.4.2.6359 4,634 4/30/2015
1.4.2.6355 1,122 4/21/2015
1.4.2.6353-pre2 201 3/31/2015
1.4.2.6350-pre1 108 3/30/2015
1.4.1.6349 6,467 3/30/2015
1.4.1.6347-pre2 362 3/19/2015
1.4.1.6342-pre1 215 3/10/2015
1.4.0.6341 2,390 3/9/2015
1.4.0.6340-pre2 136 3/6/2015
1.4.0.6336-pre1 153 3/3/2015
1.3.5.6337 587 3/5/2015
1.3.5.6335 508 3/2/2015
1.3.5.6333-pre1 197 2/17/2015
1.3.4.6332 1,098 2/17/2015
1.3.4.6331-pre4 155 2/13/2015
1.3.4.6329-pre3 123 2/12/2015
1.3.4.6328-pre2 119 2/11/2015
1.3.4.6325-pre1 140 2/9/2015
1.3.3.6323 916 2/9/2015
1.3.3.6322-pre3 118 2/6/2015
1.3.3.6321-pre2 132 2/4/2015
1.3.3.6318-pre1 140 2/2/2015
1.3.2.6316 765 2/3/2015
1.3.2.6313-pre3 163 1/30/2015
1.3.2.6309-pre2 156 1/28/2015
1.3.2.6299-pre1 224 1/20/2015
1.3.1.6296 3,907 1/4/2015
1.3.1.6294-pre1 255 12/24/2014
1.3.0.6292 992 12/24/2014
1.3.0.6286-pre4 177 12/19/2014
1.3.0.6284-pre3 199 12/12/2014
1.3.0.6280-pre2 155 12/9/2014
1.3.0.6275-pre1 1,785 11/12/2014
1.2.3.6257 5,601 10/2/2014
1.2.3.6256-pre4 164 9/26/2014
1.2.3.6255-pre3 423 9/20/2014
1.2.3.6249-pre2 223 9/9/2014
1.2.3.6246-pre1 192 8/15/2014
1.2.2.6243 2,620 7/30/2014
1.2.2.6241-pre3 105 7/28/2014
1.2.2.6240-pre2 468 7/22/2014
1.2.2.6238-pre1 109 7/17/2014
1.2.1.6229 1,922 7/14/2014
1.1.1.6206 5,320 6/19/2014
1.1.0.6201 1,021 6/12/2014
1.0.6197 469 6/4/2014
1.0.6188 2,517 5/28/2014

## Important Notes ##

This is a feature release. As such unlike a patch version bump, the minor version bump indicates the inclusion of new APIs. There should be no breaking changes; however with all feature work, there is the potential for the inclusion of instability. Please help us beta test this release and let us know of any issues you run across.

## New API ##

### ScrollView ###

It is now possible to detect the current scroll offset of the ScrollView. These are readonly bindable properties.
```csharp
public double ScrollX { get; }
public double ScrollY { get; }
```

There are also methods which can be used to perform scrolling in the ScrollView.
```csharp
public Task ScrollToAsync (double x, double y, bool animated);
public Task ScrollToAsync (Element element, bool animated);
```
The `Element` passed to `ScrollToAsync` must be a descendant of the `ScrollView` but does not have to be a direct child.

Finally for those who do not wish to use bindings to observe scrolling, there is a `Scrolled` event that fires when `ScrollX` or `ScrollY` are updated.
```csharp
public event EventHandler<ScrolledEventArgs> Scrolled;

public class ScrolledEventArgs : EventArgs
{
   public double ScrollX { get; } = 0;
   public double ScrollY { get; } = 0;
}
```
Lastly ScrollView no longer uses any internal API to communicate between the frontend and the renderer. `IScrollViewController`, which is implemented explicitly on ScrollView can be used to trigger these and other events.

### ListView ###

**Separator Enhancements**
It is now possible to enable/disable separators for the ListView. This can be configured via the `SeparatorVisibility` property, which is bindable.
```csharp
public SeparatorVisibility SeparatorVisibility { get; set; } = SeparatorVisibility.Default;

public enum SeparatorVisibility {
   Default = 0,
   None = 1,
}
```
Currently there is no option for `Always` as not all platforms have separators as part of their UX. We are considering adding this in the future, however it would be an invented paradigm for Windows platforms.

It is now possible to apply a `Color` to the separator in ListView.
```csharp
public Color SeparatorColor { get; set; } = Color.Default;
```
The default value is `Color.Default` and will function unchanged from the 1.3.0 implementation if left untouched. RGBA values are supported. This function does nothing in `SeparatorVisibility` is set to `None`. Please note that setting either of these properties on Android after loading the `ListView` incurs a large performance penalty.

**Header/Footer**
`ListView` has also grown both a Header and a Footer. These are managed through a series of properties which enable everything from simple usage to more complex MVVM style usage. With Header/Footer the primary reason developers have in the past been forced to put ListViews inside of ScrollViews is finally dead! If you are still placing a ListView inside a ScrollView we strongly suggest you consider porting.
```csharp
public object Header { get; set; } = null;
public DataTemplate HeaderTemplate { get; set; } = null;
public object Footer { get; set; } = null;
public DataTemplate FooterTemplate { get; set; } = null;
```
It is important to note that Header or Footer may be set directly to a View and the Template properties left null. This will cause the Header/Footer to be directly consumed by the renderer. All of these properties are bindable.

**Pull To Refresh**
PullToRefresh has been enabled on all current target platforms for ListView. To enable PullToRefresh in your app simple set `IsPullToRefreshEnabled` to true and make sure you respond to the correct events. It is important to note that this is the "easy" version of this API, in the future a more complete API with a standalone View may be added.
```csharp
public event EventHandler Refreshing;

public bool IsPullToRefreshEnabled { get; set; } = false;
public bool IsRefreshing { get; set; } = false;
public ICommand RefreshCommand { get; set; } = null;

public void BeginRefresh ();
public void EndRefresh ();
```
When the user triggers a `PullToRefresh` the Command will be invoked and the `Refreshed` event emitted. `IsRefreshing` will be set to true. The `ICommand.CanExecute` property is respected. The user must either call `EndRefresh` or assign `IsRefreshing` to false in order to end the refresh state.

All control parameters for these features and more are exposed through the IListViewController interface, which is explicitly implemented on ListView. This will assist those wishing to modify how these features work in custom renderers.

The Windows Phone implementation of PullToRefresh is a custom implementation as there is no platform idiom for doing this. In the future if the Windows platform decided to add a method of doing PullToRefresh by default, we intend to port.

### Forms.Application ###

The `Application` class now exposes 4 new events for dealing with Modal navigation.
```csharp
public event EventHandler<ModalPushedEventArgs> ModalPushed;
public event EventHandler<ModalPoppedEventArgs> ModalPopped;
public event EventHandler<ModalPushingEventArgs> ModalPushing;
public event EventHandler<ModalPoppingEventArgs> ModalPopping;
```
The `ModalPoppingEventArgs` contains a `Cancel` property which if set to true will cancel the Pop event and cause the application to enter the background (the operating system is informed of the unhandled back event).

In order to implement this feature, all pre-Application methods of creating a Forms app have been updated to create a default `Application` which is set as the root pages `Parent`. It is possible this may cause issues in some edge cases, if you have any issues please file a bug report. It is suggested you update your app to the new LoadApplication initialization methodology if possible.

Application now has a method of manually forcing the `Properties` dictionary to be saved to the IsolatedFileStore. This is to allow users to save their properties when it makes sense for them rather than risk them not getting serialized out due to a crash/being killed by the OS.
```csharp
public Task SavePropertiesAsync ()
```

### OpenGLRenderer ###

On Android `OpenGLRenderer` has been renamed `OpenGLViewRenderer` for consistency.

### Layout ###
Layout now contains a `ILayoutController` class which has an `IReadOnlyList<Element>` which can be used to enumerate the children of a Layout regardless of the type of the Layout.

## Other Features ##

- WebView now correctly supports javascript out of the box on Windows Phone 8.0

## Bug Fixes ##

- [Bug 27063](https://bugzilla.xamarin.com/show_bug.cgi?id=27063) - Navigation not always returning to the proper page.
- [Bug 27225](https://bugzilla.xamarin.com/show_bug.cgi?id=27225) - Secondary ToolbarItems cause app to hang during PushAsync
- [Bug 27437](https://bugzilla.xamarin.com/show_bug.cgi?id=27437) - [iOS] Context menu error after deleting an item from a ListView using ContextActions
- [Bug 27096](https://bugzilla.xamarin.com/show_bug.cgi?id=27096) - EntryCell has different fontsize on Android
- [Bug 21317](https://bugzilla.xamarin.com/show_bug.cgi?id=21317) - Stepper control .IsEnabled doesn't work on Android
- [Bug 26338](https://bugzilla.xamarin.com/show_bug.cgi?id=26338) - Unable to change page BackgroundImage from code
- [Bug 26588](https://bugzilla.xamarin.com/show_bug.cgi?id=26588) - [WinPhone] Entry does not trigger numeric keyboard when password masking is enabled


## Other Fixes ##

- Stepper default values now can be correctly inherited through a style.
- x:Static now correctly reports position on error in XAML.
- XAML now throws a more user friendly error on duplicate x:Name
- XAML will now use implicit operators when assigning values to properties
- XAML now supports baseclass indication for collection properties
- XAML string literals are now supported with `{}foo`
- iOS6 Modal pages should no longer sometimes have a 20px offset for no reason