How to add Google Maps plugin in Flutter

Share

Nowadays, having a map interface in an application is quite common to efficiently convey details of places, directions, and routes to the user.

In this shot, we will learn how to integrate the Google Maps plugin in Flutter using the Google Maps Flutter package.

To integrate the Google Maps plugin, we will need to perform the following steps:

  • Create a GCP project
  • Add Google Maps SDK (for both Android & iOS)
  • Create an API key
  • Set up Flutter application
  • Add Google Maps widget

Create a GCP project

To use the Google Maps plugin, we need a GCPGoogle Cloud Platform project and its corresponding API key. To create a new GCP project, follow the steps below.

  1. Head over to the GCP console.
  2. Open the “select a project” dialogue and click on “new project.”
  1. Enter project name and click on “create.”

With this, we have created the GCP project.

You can find the official documentation to create GCP projects here.

Add Google Maps SDK

To use the Google Maps plugin, we need to add the Maps SDK for both Android and iOS. To add the required SDK, follow the below steps.

  1. Go to “APIs & Services” from the Navigation menu and select “Library.”
  1. Search for “Maps” and enable Maps SDK for both Android & iOS.
widget

With this, we have added the required Maps SDK.

Create an API key

Finally, we need an API key to connect our Flutter application with this GCP project. To create an API key, follow the below steps.

  1. Go to “APIs & Services” from the Navigation menu and select “Credentials”.
  1. Click “Create Credentials” and select “API key.”

With this, we have created the API key that we will be using later in the flutter application.

Set up Flutter application

Create a new Flutter project and open it in any IDE.

flutter create flutter map

Go to pubspec.yaml file and add the google_maps_flutter plugin under dependencies and then run flutter pub get.

dependencies:
  ...
  google_maps_flutter: ^2.1.0

Android setup

Set the minSdkVersion in android/app/build.gradle.

android {
    defaultConfig {
        minSdkVersion 20
    }
}

Go to android/app/src/main/AndroidManifest.xml and add the following code inside the application tag.

<meta-data android:name="com.google.android.geo.API_KEY"
           android:value="YOUR KEY HERE"/>

Add the following code under manifest tag.

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION

iOS setup

Go to ios/Runner/AppDelegate.swift and replace the entire code with the following.

import UIKit
import Flutter
import GoogleMaps

@UIApplicationMain
@objc class AppDelegate: FlutterAppDelegate {
  override func application(
    _ application: UIApplication,
    didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
  ) -> Bool {
    GMSServices.provideAPIKey("YOUR KEY HERE")
    GeneratedPluginRegistrant.register(with: self)
    return super.application(application, didFinishLaunchingWithOptions: launchOptions)
  }
}

Go to ios/Runner/Info.plist and add the following code.

<key>NSLocationWhenInUseUsageDescription</key>
<string>Location Access.</string>

With this, we have completed the setup to use Google Maps plugin.

Add Google Maps widget

Let’s create a base where we will add the Map.

import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Map',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: Map(),
    );
  }
}

class Map extends StatefulWidget {
  @override
  _MapState createState() => _MapState();
}

class _MapState extends State<Map> {
  @override
  Widget build(BuildContext context) {
    var height = MediaQuery.of(context).size.height;
    var width = MediaQuery.of(context).size.width;

    return Container(
      height: height,
      width: width,
      child: Scaffold(
        body: Stack(
          children: <Widget>[
            // Todo: Add Map
          ],
        ),
      ),
    );
  }
}

We will use Stateful Widget, inside which we created a Container. As the child of Container, we are using a Scaffold widget whose body is the Stack widget. We will keep the Map in the background and every other widget on the top of it.

We have also calculated the width and height of the screen so that the Map can cover it entirely.

Now, let’s add the Google Map widget.

// import package
import 'package:google_maps_flutter/google_maps_flutter.dart';

// set an initial location of the Map
CameraPosition _initialCameraPosition = CameraPosition(target: LatLng(20.5937, 78.9629));

// add this to control the Map
GoogleMapController googleMapController;

// Replace "Todo: Add Map" with the following
GoogleMap(
  initialCameraPosition: _initialCameraPosition ,
  myLocationEnabled: true,
  myLocationButtonEnabled: true,
  mapType: MapType.normal,
  zoomGesturesEnabled: true,
  zoomControlsEnabled: true,
  onMapCreated: (GoogleMapController c) {
    // to control the camera position of the map
    googleMapController = c;
  },
),

Let’s explore the parameters that are used in the Google Maps widget.

  • initialCameraPosition: To load the map view on initial start up. It’s a required parameter.

  • myLocationEnabled: To show current location on the map with a blue dot.

  • myLocationButtonEnabled: To bring the user location to the center of the map.

  • mapType: To specify the displayed map type. Possible values are normal, satellite, hybrid, and terrain.

  • zoomGesturesEnabled: To determine whether the map should respond to zoom gestures.

  • zoomControlsEnabled: To show zoom controls.

  • onMapCreated: A callback function that gets executed when the map is ready.

With this, we have added the Google Map Widget in our Flutter application. Upon running the application, the output should look similar to the image below:

widget
Attributions:
  1. undefined by undefined
Copyright ©2024 Educative, Inc. All rights reserved