Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/samafshari/RedCorners.Forms.GoogleMaps

Enhanced Google Maps for Xamarin.Forms; based on Xamarin.Forms.GoogleMaps
https://github.com/samafshari/RedCorners.Forms.GoogleMaps

Last synced: 3 months ago
JSON representation

Enhanced Google Maps for Xamarin.Forms; based on Xamarin.Forms.GoogleMaps

Awesome Lists containing this project

README

        

Enhanced Google Maps for Xamarin Forms. Xamarin.Forms.GoogleMaps fork.

Nuget: [https://www.nuget.org/packages/RedCorners.Forms.GoogleMaps](https://www.nuget.org/packages/RedCorners.Forms.GoogleMaps)
Documentation: [http://redcorners.com/googlemaps/](http://redcorners.com/googlemaps/)

## Getting Started

`RedCorners.Forms.GoogleMaps` provides facilities to render and manage Google Maps based views on your iOS and Android Xamarin.Forms projects. In order to use `RedCorners.Forms.GoogleMaps`, you need to have the latest versions of the following packages installed:

- [`RedCorners.Forms.GoogleMaps`](https://www.nuget.org/packages/RedCorners.Forms.GoogleMaps/)
- [`RedCorners.Forms`](https://www.nuget.org/packages/RedCorners.Forms/)
- [`RedCorners`](https://www.nuget.org/packages/RedCorners/)

In case you wish to access the device's location, you must ask for the required permissions prior to enabling _My Location_ on the Google Maps view. Otherwise, the app will throw an exception due to the lack of required location permissions, or will not show _My Location_. These steps are platform-dependent and described below.

### iOS Setup

In your `AppDelegate` class, or before rendering the map, you have to call the `Init` method and inject your Google Maps API key:

```c#
public override bool FinishedLaunching(UIApplication app, NSDictionary options)
{
global::Xamarin.Forms.Forms.Init();
RedCorners.Forms.GoogleMapsSystem.Init("AIzaSyD8-xxxxxxxxxxxxxxxxxxxxxxxx");
// ...
LoadApplication(new App());
return base.FinishedLaunching(app, options);
}
```

Based on your use case, you need to configure the `info.plist` file as follows:

```xml
NSLocationAlwaysAndWhenInUseUsageDescription
This app needs access to location to continue.
NSLocationAlwaysUsageDescription
This app needs access to location to continue.
NSLocationWhenInUseUsageDescription
This app needs access to location to continue.
```

### Android Setup

You have to initialize `RedCorners.Forms.GoogleMaps` before using it. Typically you can do this in your `MainActivity.cs`:

```cs
protected override void OnCreate(Bundle savedInstanceState)
{
TabLayoutResource = Resource.Layout.Tabbar;
ToolbarResource = Resource.Layout.Toolbar;

base.OnCreate(savedInstanceState);
Xamarin.Forms.Forms.Init(this, savedInstanceState);

// Initialize RedCorners.Forms.GoogleMaps
RedCorners.Forms.GoogleMapsSystem.Init(this, savedInstanceState);

LoadApplication(new App());

// Optional: Ask for Location Permissions
if (
(ContextCompat.CheckSelfPermission(this, Manifest.Permission.AccessFineLocation) != Permission.Granted) ||
(ContextCompat.CheckSelfPermission(this, Manifest.Permission.AccessCoarseLocation) != Permission.Granted))
{
ActivityCompat.RequestPermissions(this, new [] {
Manifest.Permission.AccessFineLocation,
Manifest.Permission.AccessCoarseLocation}, 1);
};
}
```

Depending on your use case, you may want to request _Fine_ or _Coarse_ locations. To do this, first add the following lines in your `AndroidManifest.xml` file:

```xml

```

You should also add your API key to the manifest:

```xml

```

In case you get the `java.lang.NoClassDefFoundError: Failed resolution of: Lorg/apache/http/ProtocolVersion;` error, the following line can help:

```xml

```

The entire manifest can look like this:

```xml







```

### Showing a basic map

The first step is including the `RedCorners.Forms.GoogleMaps` namespace in your XAML file:

```xml
xmlns:map="clr-namespace:RedCorners.Forms.GoogleMaps;assembly=RedCorners.Forms.GoogleMaps"
```

Afterwards, you can use `map:Map` or other variants of it such as `map:LocationPickerView` or `map:MapDrawView` to show a Google Map:

```xml

```