CINXE.COM

Google Maps Platform FAQ  |  Google for Developers

<!doctype html> <html lang="en" dir="ltr"> <head> <meta name="google-signin-client-id" content="721724668570-nbkv1cfusk7kk4eni4pjvepaus73b13t.apps.googleusercontent.com"> <meta name="google-signin-scope" content="profile email https://www.googleapis.com/auth/developerprofiles https://www.googleapis.com/auth/developerprofiles.award"> <meta property="og:site_name" content="Google for Developers"> <meta property="og:type" content="website"><meta name="theme-color" content="#fff"><meta charset="utf-8"> <meta content="IE=Edge" http-equiv="X-UA-Compatible"> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="manifest" href="/_pwa/developers/manifest.json" crossorigin="use-credentials"> <link rel="preconnect" href="//www.gstatic.com" crossorigin> <link rel="preconnect" href="//fonts.gstatic.com" crossorigin> <link rel="preconnect" href="//fonts.googleapis.com" crossorigin> <link rel="preconnect" href="//apis.google.com" crossorigin> <link rel="preconnect" href="//www.google-analytics.com" crossorigin><link rel="stylesheet" href="//fonts.googleapis.com/css?family=Google+Sans:400,500|Roboto:400,400italic,500,500italic,700,700italic|Roboto+Mono:400,500,700&display=swap"> <link rel="stylesheet" href="//fonts.googleapis.com/css2?family=Material+Icons&family=Material+Symbols+Outlined&display=block"><link rel="stylesheet" href="https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f/developers/css/app.css"> <link rel="shortcut icon" href="https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f/developers/images/favicon-new.png"> <link rel="apple-touch-icon" href="https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f/developers/images/touchicon-180-new.png"><link rel="canonical" href="https://developers.google.com/maps/faq"><link rel="search" type="application/opensearchdescription+xml" title="Google for Developers" href="https://developers.google.com/s/opensearch.xml"> <link rel="alternate" hreflang="en" href="https://developers.google.com/maps/faq" /><link rel="alternate" hreflang="x-default" href="https://developers.google.com/maps/faq" /><link rel="alternate" hreflang="ar" href="https://developers.google.com/maps/faq?hl=ar" /><link rel="alternate" hreflang="bn" href="https://developers.google.com/maps/faq?hl=bn" /><link rel="alternate" hreflang="zh-Hans" href="https://developers.google.com/maps/faq?hl=zh-cn" /><link rel="alternate" hreflang="zh-Hant" href="https://developers.google.com/maps/faq?hl=zh-tw" /><link rel="alternate" hreflang="fa" href="https://developers.google.com/maps/faq?hl=fa" /><link rel="alternate" hreflang="fr" href="https://developers.google.com/maps/faq?hl=fr" /><link rel="alternate" hreflang="de" href="https://developers.google.com/maps/faq?hl=de" /><link rel="alternate" hreflang="he" href="https://developers.google.com/maps/faq?hl=he" /><link rel="alternate" hreflang="hi" href="https://developers.google.com/maps/faq?hl=hi" /><link rel="alternate" hreflang="id" href="https://developers.google.com/maps/faq?hl=id" /><link rel="alternate" hreflang="it" href="https://developers.google.com/maps/faq?hl=it" /><link rel="alternate" hreflang="ja" href="https://developers.google.com/maps/faq?hl=ja" /><link rel="alternate" hreflang="ko" href="https://developers.google.com/maps/faq?hl=ko" /><link rel="alternate" hreflang="pl" href="https://developers.google.com/maps/faq?hl=pl" /><link rel="alternate" hreflang="pt-BR" href="https://developers.google.com/maps/faq?hl=pt-br" /><link rel="alternate" hreflang="ru" href="https://developers.google.com/maps/faq?hl=ru" /><link rel="alternate" hreflang="es-419" href="https://developers.google.com/maps/faq?hl=es-419" /><link rel="alternate" hreflang="th" href="https://developers.google.com/maps/faq?hl=th" /><link rel="alternate" hreflang="tr" href="https://developers.google.com/maps/faq?hl=tr" /><link rel="alternate" hreflang="vi" href="https://developers.google.com/maps/faq?hl=vi" /><title>Google Maps Platform FAQ &nbsp;|&nbsp; Google for Developers</title> <meta property="og:title" content="Google Maps Platform FAQ &nbsp;|&nbsp; Google for Developers"><meta property="og:url" content="https://developers.google.com/maps/faq"><meta property="og:image" content="https://developers.google.com/static/maps/images/google-maps-platform-1200x675.png"> <meta property="og:image:width" content="1200"> <meta property="og:image:height" content="675"><meta property="og:locale" content="en"><meta name="twitter:card" content="summary_large_image"><meta name="twitter:site" content="@GMapsPlatform"><script type="application/ld+json"> { "@context": "https://schema.org", "@type": "Article", "headline": "Google Maps Platform FAQ" } </script><script type="application/ld+json"> { "@context": "https://schema.org", "@type": "BreadcrumbList", "itemListElement": [{ "@type": "ListItem", "position": 1, "name": "Google Maps Platform", "item": "https://developers.google.com/maps" },{ "@type": "ListItem", "position": 2, "name": "Google Maps Platform FAQ", "item": "https://developers.google.com/maps/faq" }] } </script> <link rel="stylesheet" href="/extras.css"></head> <body class="" template="page" theme="white" type="article" layout="docs" concierge='closed' display-toc pending> <devsite-progress type="indeterminate" id="app-progress"></devsite-progress> <a href="#main-content" class="skip-link button"> Skip to main content </a> <section class="devsite-wrapper"> <devsite-cookie-notification-bar></devsite-cookie-notification-bar><devsite-header role="banner"> <div class="devsite-header--inner nocontent"> <div class="devsite-top-logo-row-wrapper-wrapper"> <div class="devsite-top-logo-row-wrapper"> <div class="devsite-top-logo-row"> <button type="button" id="devsite-hamburger-menu" class="devsite-header-icon-button button-flat material-icons gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Navigation menu button" visually-hidden aria-label="Open menu"> </button> <div class="devsite-product-name-wrapper"> <a href="https://developers.google.com/maps"> <div class="devsite-product-logo-container" size="medium" > <picture> <img class="devsite-product-logo" alt="Google Maps Platform" src="https://developers.google.com/static/maps/images/maps-icon.svg" srcset=" /static/maps/images/maps-icon.svg" sizes="64px" loading="lazy" > </picture> </div> </a> <span class="devsite-product-name"> <ul class="devsite-breadcrumb-list" > <li class="devsite-breadcrumb-item devsite-has-google-wordmark"> <a href="https://developers.google.com/maps" class="devsite-breadcrumb-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Upper Header" data-value="1" track-type="globalNav" track-name="breadcrumb" track-metadata-position="1" track-metadata-eventdetail="Google Maps Platform" > <svg class="devsite-google-wordmark" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 148 48"> <title>Google</title> <path class="devsite-google-wordmark-svg-path" d="M19.58,37.65c-9.87,0-18.17-8.04-18.17-17.91c0-9.87,8.3-17.91,18.17-17.91c5.46,0,9.35,2.14,12.27,4.94l-3.45,3.45c-2.1-1.97-4.93-3.49-8.82-3.49c-7.21,0-12.84,5.81-12.84,13.02c0,7.21,5.64,13.02,12.84,13.02c4.67,0,7.34-1.88,9.04-3.58c1.4-1.4,2.32-3.41,2.66-6.16H19.58v-4.89h16.47c0.18,0.87,0.26,1.92,0.26,3.06c0,3.67-1.01,8.21-4.24,11.44C28.93,35.9,24.91,37.65,19.58,37.65z M61.78,26.12c0,6.64-5.1,11.53-11.36,11.53s-11.36-4.89-11.36-11.53c0-6.68,5.1-11.53,11.36-11.53S61.78,19.43,61.78,26.12z M56.8,26.12c0-4.15-2.96-6.99-6.39-6.99c-3.43,0-6.39,2.84-6.39,6.99c0,4.11,2.96,6.99,6.39,6.99C53.84,33.11,56.8,30.22,56.8,26.12z M87.25,26.12c0,6.64-5.1,11.53-11.36,11.53c-6.26,0-11.36-4.89-11.36-11.53c0-6.68,5.1-11.53,11.36-11.53C82.15,14.59,87.25,19.43,87.25,26.12zM82.28,26.12c0-4.15-2.96-6.99-6.39-6.99c-3.43,0-6.39,2.84-6.39,6.99c0,4.11,2.96,6.99,6.39,6.99C79.32,33.11,82.28,30.22,82.28,26.12z M112.09,15.29v20.7c0,8.52-5.02,12.01-10.96,12.01c-5.59,0-8.95-3.76-10.22-6.81l4.41-1.83c0.79,1.88,2.71,4.1,5.81,4.1c3.8,0,6.16-2.36,6.16-6.77v-1.66h-0.18c-1.14,1.4-3.32,2.62-6.07,2.62c-5.76,0-11.05-5.02-11.05-11.49c0-6.51,5.28-11.57,11.05-11.57c2.75,0,4.93,1.22,6.07,2.58h0.18v-1.88H112.09z M107.64,26.16c0-4.06-2.71-7.03-6.16-7.03c-3.49,0-6.42,2.97-6.42,7.03c0,4.02,2.93,6.94,6.42,6.94C104.93,33.11,107.64,30.18,107.64,26.16z M120.97,3.06v33.89h-5.07V3.06H120.97z M140.89,29.92l3.93,2.62c-1.27,1.88-4.32,5.11-9.61,5.11c-6.55,0-11.28-5.07-11.28-11.53c0-6.86,4.77-11.53,10.71-11.53c5.98,0,8.91,4.76,9.87,7.34l0.52,1.31l-15.42,6.38c1.18,2.31,3.01,3.49,5.59,3.49C137.79,33.11,139.58,31.84,140.89,29.92zM128.79,25.77l10.31-4.28c-0.57-1.44-2.27-2.45-4.28-2.45C132.24,19.04,128.66,21.31,128.79,25.77z"/> </svg>Maps Platform </a> </li> </ul> </span> </div> <div class="devsite-top-logo-row-middle"> <div class="devsite-header-upper-tabs"> <devsite-tabs class="upper-tabs"> <nav class="devsite-tabs-wrapper" aria-label="Upper tabs"> <tab > <a href="https://mapsplatform.google.com/" class="devsite-tabs-content gc-analytics-event " track-metadata-eventdetail="https://mapsplatform.google.com/" track-type="nav" track-metadata-position="nav - overview" track-metadata-module="primary nav" data-category="home" data-label="navTopMenu" track-name="overview" data-action="tabClick" > Overview </a> </tab> <tab > <a href="https://mapsplatform.google.com/maps-products/" class="devsite-tabs-content gc-analytics-event " track-metadata-eventdetail="https://mapsplatform.google.com/maps-products/" track-type="nav" track-metadata-position="nav - products" track-metadata-module="primary nav" data-category="products" data-label="navTopMenu" track-name="products" data-action="tabClick" > Products </a> </tab> <tab > <a href="https://mapsplatform.google.com/pricing/" class="devsite-tabs-content gc-analytics-event " track-metadata-eventdetail="https://mapsplatform.google.com/pricing/" track-type="nav" track-metadata-position="nav - pricing" track-metadata-module="primary nav" data-category="pricing" data-label="navTopMenu" track-name="pricing" data-action="tabClick" > Pricing </a> </tab> <tab class="devsite-dropdown devsite-dropdown-full devsite-active "> <a href="https://developers.google.com/maps/documentation" class="devsite-tabs-content gc-analytics-event " track-metadata-eventdetail="https://developers.google.com/maps/documentation" track-type="nav" track-metadata-position="nav - documentation" track-metadata-module="primary nav" aria-label="Documentation, selected" data-category="documentation" data-label="navTopMenu" track-name="documentation" data-action="tabClick" > Documentation </a> <button aria-haspopup="menu" aria-expanded="false" aria-label="Dropdown menu for Documentation" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation" track-metadata-position="nav - documentation" track-metadata-module="primary nav" data-category="documentation" data-label="navTopMenu" track-name="documentation" data-action="tabClick" class="devsite-tabs-dropdown-toggle devsite-icon devsite-icon-arrow-drop-down"></button> <div class="devsite-tabs-dropdown" role="menu" aria-label="submenu" hidden> <div class="devsite-tabs-dropdown-content"> <div class="devsite-tabs-dropdown-column "> <ul class="devsite-tabs-dropdown-section "> <li class="devsite-nav-title" role="heading" tooltip>Get Started</li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/get-started" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/get-started" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> Get Started with Google Maps Platform </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/api-picker" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/api-picker" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> API Picker </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/billing-and-pricing/overview" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/billing-and-pricing/overview" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> Billing & Pricing </div> </a> </li> <li class="devsite-nav-item"> <a href="https://mapsplatform.google.com/resources/trust-center" track-type="nav" track-metadata-eventdetail="https://mapsplatform.google.com/resources/trust-center" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> Security & Compliance </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/reporting-and-monitoring/overview" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/reporting-and-monitoring/overview" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> Reporting & Monitoring </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/faq" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/faq" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> FAQ </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/support" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/support" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> Support and Resources </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/support/care" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/support/care" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> Customer Care </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/incident-management" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/incident-management" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="get started" tooltip > <div class="devsite-nav-item-title"> Incident Management </div> </a> </li> </ul> </div> <div class="devsite-tabs-dropdown-column "> <ul class="devsite-tabs-dropdown-section "> <li class="devsite-nav-title" role="heading" tooltip>Maps</li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/javascript" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/javascript" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Maps JavaScript API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/android-sdk" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/android-sdk" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Maps SDK for Android </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/ios-sdk" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/ios-sdk" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Maps SDK for iOS </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/flutter-package/overview" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/flutter-package/overview" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Google Maps for Flutter </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/embed" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/embed" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Maps Embed API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/maps-static" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/maps-static" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Maps Static API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/streetview" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/streetview" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Street View Static API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/urls" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/urls" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Maps URLs </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/aerial-view" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/aerial-view" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Aerial View API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/elevation" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/elevation" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Elevation API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/tile" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/tile" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Map Tiles API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/datasets" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/datasets" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Maps Datasets API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/web-components" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/web-components" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="maps" tooltip > <div class="devsite-nav-item-title"> Web Components (Preview) </div> </a> </li> </ul> </div> <div class="devsite-tabs-dropdown-column "> <ul class="devsite-tabs-dropdown-section "> <li class="devsite-nav-title" role="heading" tooltip>Routes</li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/routes" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/routes" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Routes API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/navigation/android-sdk" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/navigation/android-sdk" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Navigation SDK for Android </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/navigation/ios-sdk" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/navigation/ios-sdk" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Navigation SDK for iOS </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/cross-platform/navigation" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/cross-platform/navigation" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Navigation for Flutter </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/cross-platform/navigation" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/cross-platform/navigation" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Navigation for React Native </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/roads" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/roads" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Roads API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/directions" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/directions" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Directions API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/distance-matrix" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/distance-matrix" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Distance Matrix API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/route-optimization" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/route-optimization" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Route Optimization API </div> </a> </li> </ul> <ul class="devsite-tabs-dropdown-section "> <li class="devsite-nav-title" role="heading" tooltip>Solutions</li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/solutions" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/solutions" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Industry solutions </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/mobility" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/mobility" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="routes" tooltip > <div class="devsite-nav-item-title"> Mobility services </div> </a> </li> </ul> </div> <div class="devsite-tabs-dropdown-column "> <ul class="devsite-tabs-dropdown-section "> <li class="devsite-nav-title" role="heading" tooltip>Places</li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/places/web-service" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/places/web-service" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Places API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/places/android-sdk" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/places/android-sdk" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Places SDK for Android </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/places/ios-sdk" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/places/ios-sdk" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Places SDK for iOS </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/javascript/places-js" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/javascript/places-js" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Places Library, Maps JavaScript API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/geocoding" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/geocoding" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Geocoding API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/geolocation" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/geolocation" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Geolocation API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/address-validation" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/address-validation" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Address Validation API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/timezone" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/timezone" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Time Zone API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/places-insights" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/places-insights" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Places Insights API (Preview) </div> </a> </li> </ul> <ul class="devsite-tabs-dropdown-section "> <li class="devsite-nav-title" role="heading" tooltip>Environment</li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/air-quality" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/air-quality" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Air Quality API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/pollen" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/pollen" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Pollen API </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/documentation/solar" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/documentation/solar" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="places" tooltip > <div class="devsite-nav-item-title"> Solar API </div> </a> </li> </ul> </div> <div class="devsite-tabs-dropdown-column "> <ul class="devsite-tabs-dropdown-section "> <li class="devsite-nav-title" role="heading" tooltip>Additional Resources</li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/api-security-best-practices" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/api-security-best-practices" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> API Security Best Practices </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/digital-signature" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/digital-signature" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> Digital Signature Guide </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/coverage" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/coverage" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> Map Coverage Details </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/optimization-guide" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/optimization-guide" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> Optimization Guide </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/software-support" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/software-support" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> Mobile OS and software support </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/launch-stages" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/launch-stages" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> Launch stages </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/legacy" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/legacy" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> Legacy products </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/deprecations" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/deprecations" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> Deprecations </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/asset-tracking-plan" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/asset-tracking-plan" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> Asset Tracking Plan </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/url-encoding" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/url-encoding" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> URL Encoding </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/third-party-platforms/wordpress" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/third-party-platforms/wordpress" track-metadata-position="nav - documentation" track-metadata-module="tertiary nav" track-metadata-module_headline="additional resources" tooltip > <div class="devsite-nav-item-title"> WordPress Users </div> </a> </li> </ul> </div> </div> </div> </tab> <tab > <a href="https://mapsplatform.google.com/resources/blog" class="devsite-tabs-content gc-analytics-event " track-metadata-eventdetail="https://mapsplatform.google.com/resources/blog" track-type="nav" track-metadata-position="nav - blog" track-metadata-module="primary nav" data-category="blog" data-label="navTopMenu" track-name="blog" data-action="tabClick" > Blog </a> </tab> <tab class="devsite-dropdown "> <a href="https://developers.google.com/maps/developer-community" class="devsite-tabs-content gc-analytics-event " track-metadata-eventdetail="https://developers.google.com/maps/developer-community" track-type="nav" track-metadata-position="nav - community" track-metadata-module="primary nav" data-category="community" data-label="navTopMenu" track-name="community" data-action="tabClick" > Community </a> <button aria-haspopup="menu" aria-expanded="false" aria-label="Dropdown menu for Community" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/developer-community" track-metadata-position="nav - community" track-metadata-module="primary nav" data-category="community" data-label="navTopMenu" track-name="community" data-action="tabClick" class="devsite-tabs-dropdown-toggle devsite-icon devsite-icon-arrow-drop-down"></button> <div class="devsite-tabs-dropdown" role="menu" aria-label="submenu" hidden> <div class="devsite-tabs-dropdown-content"> <div class="devsite-tabs-dropdown-column "> <ul class="devsite-tabs-dropdown-section "> <li class="devsite-nav-item"> <a href="https://github.com/googlemaps/" track-type="nav" track-metadata-eventdetail="https://github.com/googlemaps/" track-metadata-position="nav - community" track-metadata-module="tertiary nav" tooltip > <div class="devsite-nav-item-title"> GitHub </div> </a> </li> <li class="devsite-nav-item"> <a href="https://www.youtube.com/c/GoogleMapsPlatform" track-type="nav" track-metadata-eventdetail="https://www.youtube.com/c/GoogleMapsPlatform" track-metadata-position="nav - community" track-metadata-module="tertiary nav" tooltip > <div class="devsite-nav-item-title"> YouTube </div> </a> </li> <li class="devsite-nav-item"> <a href="https://www.linkedin.com/showcase/googlemapsplatform/" track-type="nav" track-metadata-eventdetail="https://www.linkedin.com/showcase/googlemapsplatform/" track-metadata-position="nav - community" track-metadata-module="tertiary nav" tooltip > <div class="devsite-nav-item-title"> LinkedIn </div> </a> </li> <li class="devsite-nav-item"> <a href="https://discord.gg/f4hvx8Rp2q" track-type="nav" track-metadata-eventdetail="https://discord.gg/f4hvx8Rp2q" track-metadata-position="nav - community" track-metadata-module="tertiary nav" tooltip > <div class="devsite-nav-item-title"> Discord </div> </a> </li> <li class="devsite-nav-item"> <a href="https://developers.google.com/maps/innovators" track-type="nav" track-metadata-eventdetail="https://developers.google.com/maps/innovators" track-metadata-position="nav - community" track-metadata-module="tertiary nav" tooltip > <div class="devsite-nav-item-title"> Innovators </div> </a> </li> <li class="devsite-nav-item"> <a href="https://issuetracker.google.com/bookmark-groups/76561" track-type="nav" track-metadata-eventdetail="https://issuetracker.google.com/bookmark-groups/76561" track-metadata-position="nav - community" track-metadata-module="tertiary nav" tooltip > <div class="devsite-nav-item-title"> Issue Tracker </div> </a> </li> </ul> </div> </div> </div> </tab> </nav> </devsite-tabs> </div> <devsite-search enable-signin enable-search enable-suggestions enable-query-completion project-name="Google Maps Platform" tenant-name="Google for Developers" project-scope="/maps" url-scoped="https://developers.google.com/s/results/maps" > <form class="devsite-search-form" action="https://developers.google.com/s/results" method="GET"> <div class="devsite-search-container"> <button type="button" search-open class="devsite-search-button devsite-header-icon-button button-flat material-icons" aria-label="Open search"></button> <div class="devsite-searchbox"> <input aria-activedescendant="" aria-autocomplete="list" aria-label="Search" aria-expanded="false" aria-haspopup="listbox" autocomplete="off" class="devsite-search-field devsite-search-query" name="q" placeholder="Search" role="combobox" type="text" value="" > <div class="devsite-search-image material-icons" aria-hidden="true"> </div> <div class="devsite-search-shortcut-icon-container" aria-hidden="true"> <kbd class="devsite-search-shortcut-icon">/</kbd> </div> </div> </div> </form> <button type="button" search-close class="devsite-search-button devsite-header-icon-button button-flat material-icons" aria-label="Close search"></button> </devsite-search> </div> <devsite-language-selector> <ul role="presentation"> <li role="presentation"> <a role="menuitem" lang="en" >English</a> </li> <li role="presentation"> <a role="menuitem" lang="de" >Deutsch</a> </li> <li role="presentation"> <a role="menuitem" lang="es" >Español</a> </li> <li role="presentation"> <a role="menuitem" lang="es_419" >Español – América Latina</a> </li> <li role="presentation"> <a role="menuitem" lang="fr" >Français</a> </li> <li role="presentation"> <a role="menuitem" lang="id" >Indonesia</a> </li> <li role="presentation"> <a role="menuitem" lang="it" >Italiano</a> </li> <li role="presentation"> <a role="menuitem" lang="pl" >Polski</a> </li> <li role="presentation"> <a role="menuitem" lang="pt_br" >Português – Brasil</a> </li> <li role="presentation"> <a role="menuitem" lang="vi" >Tiếng Việt</a> </li> <li role="presentation"> <a role="menuitem" lang="tr" >Türkçe</a> </li> <li role="presentation"> <a role="menuitem" lang="ru" >Русский</a> </li> <li role="presentation"> <a role="menuitem" lang="he" >עברית</a> </li> <li role="presentation"> <a role="menuitem" lang="ar" >العربيّة</a> </li> <li role="presentation"> <a role="menuitem" lang="fa" >فارسی</a> </li> <li role="presentation"> <a role="menuitem" lang="hi" >हिंदी</a> </li> <li role="presentation"> <a role="menuitem" lang="bn" >বাংলা</a> </li> <li role="presentation"> <a role="menuitem" lang="th" >ภาษาไทย</a> </li> <li role="presentation"> <a role="menuitem" lang="zh_cn" >中文 – 简体</a> </li> <li role="presentation"> <a role="menuitem" lang="zh_tw" >中文 – 繁體</a> </li> <li role="presentation"> <a role="menuitem" lang="ja" >日本語</a> </li> <li role="presentation"> <a role="menuitem" lang="ko" >한국어</a> </li> </ul> </devsite-language-selector> <devsite-user enable-profiles fp-auth id="devsite-user"> <span class="button devsite-top-button" aria-hidden="true" visually-hidden>Sign in</span> </devsite-user> </div> </div> </div> <div class="devsite-collapsible-section devsite-header-no-lower-tabs "> <div class="devsite-header-background"> <div class="devsite-product-id-row" > <div class="devsite-product-description-row"> <ul class="devsite-breadcrumb-list" > <li class="devsite-breadcrumb-item "> <a href="https://developers.google.com/maps/documentation" class="devsite-breadcrumb-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Lower Header" data-value="1" track-type="globalNav" track-name="breadcrumb" track-metadata-position="1" track-metadata-eventdetail="" > Documentation </a> </li> </ul> </div> </div> </div> </div> </div> </devsite-header> <devsite-book-nav scrollbars > <div class="devsite-book-nav-filter" > <span class="filter-list-icon material-icons" aria-hidden="true"></span> <input type="text" placeholder="Filter" aria-label="Type to filter" role="searchbox"> <span class="filter-clear-button hidden" data-title="Clear filter" aria-label="Clear filter" role="button" tabindex="0"></span> </div> <nav class="devsite-book-nav devsite-nav nocontent" aria-label="Side menu"> <div class="devsite-mobile-header"> <button type="button" id="devsite-close-nav" class="devsite-header-icon-button button-flat material-icons gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Close navigation" aria-label="Close navigation"> </button> <div class="devsite-product-name-wrapper"> <a href="https://developers.google.com/maps"> <div class="devsite-product-logo-container" size="medium" > <picture> <img class="devsite-product-logo" alt="Google Maps Platform" src="https://developers.google.com/static/maps/images/maps-icon.svg" srcset=" /static/maps/images/maps-icon.svg" sizes="64px" loading="lazy" > </picture> </div> </a> <span class="devsite-product-name"> <ul class="devsite-breadcrumb-list" > <li class="devsite-breadcrumb-item devsite-has-google-wordmark"> <a href="https://developers.google.com/maps" class="devsite-breadcrumb-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Upper Header" data-value="1" track-type="globalNav" track-name="breadcrumb" track-metadata-position="1" track-metadata-eventdetail="Google Maps Platform" > <svg class="devsite-google-wordmark" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 148 48"> <title>Google</title> <path class="devsite-google-wordmark-svg-path" d="M19.58,37.65c-9.87,0-18.17-8.04-18.17-17.91c0-9.87,8.3-17.91,18.17-17.91c5.46,0,9.35,2.14,12.27,4.94l-3.45,3.45c-2.1-1.97-4.93-3.49-8.82-3.49c-7.21,0-12.84,5.81-12.84,13.02c0,7.21,5.64,13.02,12.84,13.02c4.67,0,7.34-1.88,9.04-3.58c1.4-1.4,2.32-3.41,2.66-6.16H19.58v-4.89h16.47c0.18,0.87,0.26,1.92,0.26,3.06c0,3.67-1.01,8.21-4.24,11.44C28.93,35.9,24.91,37.65,19.58,37.65z M61.78,26.12c0,6.64-5.1,11.53-11.36,11.53s-11.36-4.89-11.36-11.53c0-6.68,5.1-11.53,11.36-11.53S61.78,19.43,61.78,26.12z M56.8,26.12c0-4.15-2.96-6.99-6.39-6.99c-3.43,0-6.39,2.84-6.39,6.99c0,4.11,2.96,6.99,6.39,6.99C53.84,33.11,56.8,30.22,56.8,26.12z M87.25,26.12c0,6.64-5.1,11.53-11.36,11.53c-6.26,0-11.36-4.89-11.36-11.53c0-6.68,5.1-11.53,11.36-11.53C82.15,14.59,87.25,19.43,87.25,26.12zM82.28,26.12c0-4.15-2.96-6.99-6.39-6.99c-3.43,0-6.39,2.84-6.39,6.99c0,4.11,2.96,6.99,6.39,6.99C79.32,33.11,82.28,30.22,82.28,26.12z M112.09,15.29v20.7c0,8.52-5.02,12.01-10.96,12.01c-5.59,0-8.95-3.76-10.22-6.81l4.41-1.83c0.79,1.88,2.71,4.1,5.81,4.1c3.8,0,6.16-2.36,6.16-6.77v-1.66h-0.18c-1.14,1.4-3.32,2.62-6.07,2.62c-5.76,0-11.05-5.02-11.05-11.49c0-6.51,5.28-11.57,11.05-11.57c2.75,0,4.93,1.22,6.07,2.58h0.18v-1.88H112.09z M107.64,26.16c0-4.06-2.71-7.03-6.16-7.03c-3.49,0-6.42,2.97-6.42,7.03c0,4.02,2.93,6.94,6.42,6.94C104.93,33.11,107.64,30.18,107.64,26.16z M120.97,3.06v33.89h-5.07V3.06H120.97z M140.89,29.92l3.93,2.62c-1.27,1.88-4.32,5.11-9.61,5.11c-6.55,0-11.28-5.07-11.28-11.53c0-6.86,4.77-11.53,10.71-11.53c5.98,0,8.91,4.76,9.87,7.34l0.52,1.31l-15.42,6.38c1.18,2.31,3.01,3.49,5.59,3.49C137.79,33.11,139.58,31.84,140.89,29.92zM128.79,25.77l10.31-4.28c-0.57-1.44-2.27-2.45-4.28-2.45C132.24,19.04,128.66,21.31,128.79,25.77z"/> </svg>Maps Platform </a> </li> </ul> </span> </div> </div> <div class="devsite-book-nav-wrapper"> <div class="devsite-mobile-nav-top"> <ul class="devsite-nav-list"> <li class="devsite-nav-item"> <a href="https://mapsplatform.google.com/" class="devsite-nav-title gc-analytics-event " data-category="home" data-label="navTopMenu" track-name="overview" data-action="tabClick" data-category="Site-Wide Custom Events" data-label="Responsive Tab: Overview" track-type="globalNav" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Overview </span> </a> </li> <li class="devsite-nav-item"> <a href="https://mapsplatform.google.com/maps-products/" class="devsite-nav-title gc-analytics-event " data-category="products" data-label="navTopMenu" track-name="products" data-action="tabClick" data-category="Site-Wide Custom Events" data-label="Responsive Tab: Products" track-type="globalNav" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Products </span> </a> </li> <li class="devsite-nav-item"> <a href="https://mapsplatform.google.com/pricing/" class="devsite-nav-title gc-analytics-event " data-category="pricing" data-label="navTopMenu" track-name="pricing" data-action="tabClick" data-category="Site-Wide Custom Events" data-label="Responsive Tab: Pricing" track-type="globalNav" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Pricing </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation" class="devsite-nav-title gc-analytics-event devsite-nav-has-children devsite-nav-active" data-category="documentation" data-label="navTopMenu" track-name="documentation" data-action="tabClick" data-category="Site-Wide Custom Events" data-label="Responsive Tab: Documentation" track-type="globalNav" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Documentation </span> <span class="devsite-nav-icon material-icons" data-icon="forward" > </span> </a> <ul class="devsite-nav-responsive-tabs devsite-nav-has-menu "> <li class="devsite-nav-item"> <span class="devsite-nav-title" tooltip data-category="documentation" data-label="navTopMenu" track-name="documentation" data-action="tabClick" > <span class="devsite-nav-text" tooltip menu="Documentation"> More </span> <span class="devsite-nav-icon material-icons" data-icon="forward" menu="Documentation"> </span> </span> </li> </ul> </li> <li class="devsite-nav-item"> <a href="https://mapsplatform.google.com/resources/blog" class="devsite-nav-title gc-analytics-event " data-category="blog" data-label="navTopMenu" track-name="blog" data-action="tabClick" data-category="Site-Wide Custom Events" data-label="Responsive Tab: Blog" track-type="globalNav" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Blog </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/developer-community" class="devsite-nav-title gc-analytics-event " data-category="community" data-label="navTopMenu" track-name="community" data-action="tabClick" data-category="Site-Wide Custom Events" data-label="Responsive Tab: Community" track-type="globalNav" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Community </span> </a> <ul class="devsite-nav-responsive-tabs devsite-nav-has-menu "> <li class="devsite-nav-item"> <span class="devsite-nav-title" tooltip data-category="community" data-label="navTopMenu" track-name="community" data-action="tabClick" > <span class="devsite-nav-text" tooltip menu="Community"> More </span> <span class="devsite-nav-icon material-icons" data-icon="forward" menu="Community"> </span> </span> </li> </ul> </li> </ul> </div> <div class="devsite-mobile-nav-bottom"> <ul class="devsite-nav-list" menu="_book"> <li class="devsite-nav-item"><a href="/maps/documentation" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation" ><span class="devsite-nav-text" tooltip>Google Maps Platform Documentation</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Get Started</span> </div></li> <li class="devsite-nav-item"><a href="/maps/get-started" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/get-started" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/get-started" ><span class="devsite-nav-text" tooltip>Get Started with Google Maps Platform</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/api-picker" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/api-picker" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/api-picker" ><span class="devsite-nav-text" tooltip>API Picker</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/get-map-id" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/get-map-id" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/get-map-id" ><span class="devsite-nav-text" tooltip>Map IDs</span></a></li> <li class="devsite-nav-item"><a href="/maps/faq" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/faq" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/faq" ><span class="devsite-nav-text" tooltip>FAQ</span></a></li> <li class="devsite-nav-item"><a href="/maps/support" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/support" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/support" ><span class="devsite-nav-text" tooltip>Support and Resources</span></a></li> <li class="devsite-nav-item"><a href="/maps/support/care" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/support/care" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/support/care" ><span class="devsite-nav-text" tooltip>Customer Care</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Best Practices</span> </div><ul class="devsite-nav-section"><li class="devsite-nav-item"><a href="/maps/api-security-best-practices" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/api-security-best-practices" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/api-security-best-practices" ><span class="devsite-nav-text" tooltip>API security best practices</span></a></li><li class="devsite-nav-item"><a href="/maps/digital-signature" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/digital-signature" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/digital-signature" ><span class="devsite-nav-text" tooltip>Digital Signature Guide</span></a></li><li class="devsite-nav-item"><a href="/maps/optimization-guide" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/optimization-guide" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/optimization-guide" ><span class="devsite-nav-text" tooltip>Optimization Guide</span></a></li><li class="devsite-nav-item"><a href="/maps/optimize-web-services" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/optimize-web-services" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/optimize-web-services" ><span class="devsite-nav-text" tooltip>Optimizing Web Service Usage</span></a></li></ul></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Billing &amp; Pricing</span> </div></li> <li class="devsite-nav-item"><a href="/maps/billing-and-pricing/overview" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/billing-and-pricing/overview" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/billing-and-pricing/overview" ><span class="devsite-nav-text" tooltip>Billing &amp; Pricing Overview</span></a></li> <li class="devsite-nav-item"><a href="/maps/billing-and-pricing/billing" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/billing-and-pricing/billing" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/billing-and-pricing/billing" ><span class="devsite-nav-text" tooltip>Billing</span></a></li> <li class="devsite-nav-item"><a href="/maps/billing-and-pricing/pricing" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/billing-and-pricing/pricing" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/billing-and-pricing/pricing" ><span class="devsite-nav-text" tooltip>Pricing</span></a></li> <li class="devsite-nav-item"><a href="/maps/billing-and-pricing/faq" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/billing-and-pricing/faq" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/billing-and-pricing/faq" ><span class="devsite-nav-text" tooltip>Pricing FAQ</span></a></li> <li class="devsite-nav-item"><a href="/maps/billing-and-pricing/pricing-india" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/billing-and-pricing/pricing-india" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/billing-and-pricing/pricing-india" ><span class="devsite-nav-text" tooltip>Pricing - India</span></a></li> <li class="devsite-nav-item"><a href="/maps/billing-and-pricing/india" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/billing-and-pricing/india" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/billing-and-pricing/india" ><span class="devsite-nav-text" tooltip>Pricing - India FAQ</span></a></li> <li class="devsite-nav-item"><a href="/maps/billing-and-pricing/public-programs" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/billing-and-pricing/public-programs" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/billing-and-pricing/public-programs" ><span class="devsite-nav-text" tooltip>Public Programs</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Reporting &amp; Monitoring</span> </div></li> <li class="devsite-nav-item"><a href="/maps/reporting-and-monitoring/overview" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/reporting-and-monitoring/overview" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/reporting-and-monitoring/overview" ><span class="devsite-nav-text" tooltip>Reporting &amp; Monitoring Overview</span></a></li> <li class="devsite-nav-item"><a href="/maps/reporting-and-monitoring/reporting" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/reporting-and-monitoring/reporting" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/reporting-and-monitoring/reporting" ><span class="devsite-nav-text" tooltip>Reporting</span></a></li> <li class="devsite-nav-item"><a href="/maps/reporting-and-monitoring/monitoring" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/reporting-and-monitoring/monitoring" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/reporting-and-monitoring/monitoring" ><span class="devsite-nav-text" tooltip>Monitoring</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Security &amp; Compliance</span> </div></li> <li class="devsite-nav-item"><a href="/maps/security/compliance/security-compliance" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/security/compliance/security-compliance" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/security/compliance/security-compliance" ><span class="devsite-nav-text" tooltip>Overview</span></a></li> <li class="devsite-nav-item"><a href="/maps/api-security-best-practices" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/api-security-best-practices" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/api-security-best-practices" ><span class="devsite-nav-text" tooltip>Security guidance</span></a></li> <li class="devsite-nav-item"><a href="/maps/security/compliance/services-in-scope" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/security/compliance/services-in-scope" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/security/compliance/services-in-scope" ><span class="devsite-nav-text" tooltip>Services in scope</span></a></li> <li class="devsite-nav-item"><a href="/maps/incident-management" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/incident-management" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/incident-management" ><span class="devsite-nav-text" tooltip>Incident Management</span></a></li> <li class="devsite-nav-item devsite-nav-external"><a href="https://mapsplatform.google.com/resources/trust-center" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: https://mapsplatform.google.com/resources/trust-center" track-type="bookNav" track-name="click" track-metadata-eventdetail="https://mapsplatform.google.com/resources/trust-center" ><span class="devsite-nav-text" tooltip>Trust Center</span><span class="devsite-nav-icon material-icons" data-icon="external" data-title="External" aria-hidden="true"></span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Utilities</span> </div></li> <li class="devsite-nav-item"><a href="/maps/documentation/utilities/polylinealgorithm" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/utilities/polylinealgorithm" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/utilities/polylinealgorithm" ><span class="devsite-nav-text" tooltip>Encoded Polyline Algorithm Format</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/utilities/polylineutility" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/utilities/polylineutility" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/utilities/polylineutility" ><span class="devsite-nav-text" tooltip>Interactive Polyline Encoder Utility</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/routes/polylinedecoder" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/routes/polylinedecoder" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/routes/polylinedecoder" ><span class="devsite-nav-text" tooltip>Interactive Polyline Decoder Utility</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Maps</span> </div></li> <li class="devsite-nav-item"><a href="/maps/documentation/javascript" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/javascript" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/javascript" ><span class="devsite-nav-text" tooltip>Maps JavaScript API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/android-sdk" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/android-sdk" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/android-sdk" ><span class="devsite-nav-text" tooltip>Maps SDK for Android</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/ios-sdk" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/ios-sdk" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/ios-sdk" ><span class="devsite-nav-text" tooltip>Maps SDK for iOS</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/tile" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/tile" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/tile" ><span class="devsite-nav-text" tooltip>Map Tiles API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/aerial-view" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/aerial-view" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/aerial-view" ><span class="devsite-nav-text" tooltip>Maps Aerial View API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/maps-static" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/maps-static" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/maps-static" ><span class="devsite-nav-text" tooltip>Maps Static API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/streetview" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/streetview" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/streetview" ><span class="devsite-nav-text" tooltip>Street View Static API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/embed" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/embed" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/embed" ><span class="devsite-nav-text" tooltip>Maps Embed API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/urls" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/urls" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/urls" ><span class="devsite-nav-text" tooltip>Maps URLs</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/datasets" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/datasets" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/datasets" ><span class="devsite-nav-text" tooltip>Maps Datasets API</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Routes</span> </div></li> <li class="devsite-nav-item"><a href="/maps/documentation/routes" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/routes" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/routes" ><span class="devsite-nav-text" tooltip>Routes API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/navigation/android-sdk" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/navigation/android-sdk" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/navigation/android-sdk" ><span class="devsite-nav-text" tooltip>Navigation SDK for Android</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/navigation/ios-sdk" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/navigation/ios-sdk" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/navigation/ios-sdk" ><span class="devsite-nav-text" tooltip>Navigation SDK for iOS</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/roads" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/roads" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/roads" ><span class="devsite-nav-text" tooltip>Roads API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/directions" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/directions" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/directions" ><span class="devsite-nav-text" tooltip>Directions API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/distance-matrix" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/distance-matrix" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/distance-matrix" ><span class="devsite-nav-text" tooltip>Distance Matrix API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/route-optimization" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/route-optimization" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/route-optimization" ><span class="devsite-nav-text" tooltip>Route Optimization API</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Places</span> </div></li> <li class="devsite-nav-item"><a href="/maps/documentation/places/web-service" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/places/web-service" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/places/web-service" ><span class="devsite-nav-text" tooltip>Places API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/places/android-sdk" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/places/android-sdk" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/places/android-sdk" ><span class="devsite-nav-text" tooltip>Places SDK for Android</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/places/ios-sdk" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/places/ios-sdk" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/places/ios-sdk" ><span class="devsite-nav-text" tooltip>Places SDK for iOS</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/javascript/places" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/javascript/places" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/javascript/places" ><span class="devsite-nav-text" tooltip>Places Library, Maps JavaScript API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/geocoding" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/geocoding" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/geocoding" ><span class="devsite-nav-text" tooltip>Geocoding API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/geolocation" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/geolocation" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/geolocation" ><span class="devsite-nav-text" tooltip>Geolocation API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/timezone" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/timezone" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/timezone" ><span class="devsite-nav-text" tooltip>Time Zone API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/elevation" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/elevation" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/elevation" ><span class="devsite-nav-text" tooltip>Elevation API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/address-validation" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/address-validation" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/address-validation" ><span class="devsite-nav-text" tooltip>Address Validation API</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Environment</span> </div></li> <li class="devsite-nav-item"><a href="/maps/documentation/air-quality" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/air-quality" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/air-quality" ><span class="devsite-nav-text" tooltip>Air Quality API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/pollen" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/pollen" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/pollen" ><span class="devsite-nav-text" tooltip>Pollen API</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/solar" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/solar" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/solar" ><span class="devsite-nav-text" tooltip>Solar API</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Solutions</span> </div></li> <li class="devsite-nav-item"><a href="/maps/solutions" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/solutions" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/solutions" ><span class="devsite-nav-text" tooltip>Industry Solutions</span></a></li> <li class="devsite-nav-item"><a href="/maps/solutions" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/solutions" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/solutions" ><span class="devsite-nav-text" tooltip>Retail</span></a></li> <li class="devsite-nav-item"><a href="/maps/documentation/unity" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/documentation/unity" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/documentation/unity" ><span class="devsite-nav-text" tooltip>Unity</span></a></li> <li class="devsite-nav-item devsite-nav-heading"><div class="devsite-nav-title devsite-nav-title-no-path"> <span class="devsite-nav-text" tooltip>Additional Resources</span> </div></li> <li class="devsite-nav-item"><a href="/maps/coverage" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/coverage" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/coverage" ><span class="devsite-nav-text" tooltip>Map Coverage Details</span></a></li> <li class="devsite-nav-item"><a href="/maps/software-support" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/software-support" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/software-support" ><span class="devsite-nav-text" tooltip>Mobile OS and software support</span></a></li> <li class="devsite-nav-item"><a href="/maps/launch-stages" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/launch-stages" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/launch-stages" ><span class="devsite-nav-text" tooltip>Launch stages</span></a></li> <li class="devsite-nav-item"><a href="/maps/legacy" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/legacy" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/legacy" ><span class="devsite-nav-text" tooltip>Legacy products</span></a></li> <li class="devsite-nav-item"><a href="/maps/deprecations" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/deprecations" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/deprecations" ><span class="devsite-nav-text" tooltip>Deprecations</span></a></li> <li class="devsite-nav-item"><a href="/maps/asset-tracking-plan" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/asset-tracking-plan" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/asset-tracking-plan" ><span class="devsite-nav-text" tooltip>Asset Tracking Plan</span></a></li> <li class="devsite-nav-item"><a href="/maps/root-ca-faq" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/root-ca-faq" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/root-ca-faq" ><span class="devsite-nav-text" tooltip>Root CA Migration FAQ</span></a></li> <li class="devsite-nav-item"><a href="/maps/domains" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/domains" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/domains" ><span class="devsite-nav-text" tooltip>Domains</span></a></li> <li class="devsite-nav-item"><a href="/maps/roles" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/roles" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/roles" ><span class="devsite-nav-text" tooltip>Project roles comparison</span></a></li> <li class="devsite-nav-item"><a href="/maps/prelaunch-checklist" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/prelaunch-checklist" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/prelaunch-checklist" ><span class="devsite-nav-text" tooltip>Pre-Launch Checklist</span></a></li> <li class="devsite-nav-item"><a href="/maps/premium/overview" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/premium/overview" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/premium/overview" ><span class="devsite-nav-text" tooltip>Premium Plan</span></a></li> <li class="devsite-nav-item"><a href="/maps/url-encoding" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/url-encoding" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/url-encoding" ><span class="devsite-nav-text" tooltip>URL Encoding</span></a></li> <li class="devsite-nav-item"><a href="/maps/third-party-platforms/wordpress" class="devsite-nav-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Book nav link, pathname: /maps/third-party-platforms/wordpress" track-type="bookNav" track-name="click" track-metadata-eventdetail="/maps/third-party-platforms/wordpress" ><span class="devsite-nav-text" tooltip>WordPress Users</span></a></li> </ul> <ul class="devsite-nav-list" menu="Documentation" aria-label="Side menu" hidden> <li class="devsite-nav-item devsite-nav-heading"> <span class="devsite-nav-title" tooltip > <span class="devsite-nav-text" tooltip > Get Started </span> </span> </li> <li class="devsite-nav-item"> <a href="/maps/get-started" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Get Started with Google Maps Platform" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Get Started with Google Maps Platform </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/api-picker" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: API Picker" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > API Picker </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/billing-and-pricing/overview" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Billing &amp; Pricing" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Billing &amp; Pricing </span> </a> </li> <li class="devsite-nav-item"> <a href="https://mapsplatform.google.com/resources/trust-center" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Security &amp; Compliance" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Security &amp; Compliance </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/reporting-and-monitoring/overview" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Reporting &amp; Monitoring" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Reporting &amp; Monitoring </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/faq" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: FAQ" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > FAQ </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/support" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Support and Resources" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Support and Resources </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/support/care" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Customer Care" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Customer Care </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/incident-management" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Incident Management" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Incident Management </span> </a> </li> <li class="devsite-nav-item devsite-nav-heading"> <span class="devsite-nav-title" tooltip > <span class="devsite-nav-text" tooltip > Maps </span> </span> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/javascript" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Maps JavaScript API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Maps JavaScript API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/android-sdk" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Maps SDK for Android" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Maps SDK for Android </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/ios-sdk" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Maps SDK for iOS" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Maps SDK for iOS </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/flutter-package/overview" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Google Maps for Flutter" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Google Maps for Flutter </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/embed" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Maps Embed API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Maps Embed API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/maps-static" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Maps Static API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Maps Static API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/streetview" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Street View Static API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Street View Static API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/urls" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Maps URLs" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Maps URLs </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/aerial-view" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Aerial View API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Aerial View API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/elevation" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Elevation API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Elevation API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/tile" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Map Tiles API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Map Tiles API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/datasets" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Maps Datasets API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Maps Datasets API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/web-components" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Web Components (Preview)" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Web Components (Preview) </span> </a> </li> <li class="devsite-nav-item devsite-nav-heading"> <span class="devsite-nav-title" tooltip > <span class="devsite-nav-text" tooltip > Routes </span> </span> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/routes" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Routes API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Routes API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/navigation/android-sdk" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Navigation SDK for Android" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Navigation SDK for Android </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/navigation/ios-sdk" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Navigation SDK for iOS" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Navigation SDK for iOS </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/cross-platform/navigation" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Navigation for Flutter" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Navigation for Flutter </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/cross-platform/navigation" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Navigation for React Native" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Navigation for React Native </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/roads" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Roads API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Roads API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/directions" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Directions API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Directions API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/distance-matrix" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Distance Matrix API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Distance Matrix API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/route-optimization" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Route Optimization API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Route Optimization API </span> </a> </li> <li class="devsite-nav-item devsite-nav-heading"> <span class="devsite-nav-title" tooltip > <span class="devsite-nav-text" tooltip > Solutions </span> </span> </li> <li class="devsite-nav-item"> <a href="/maps/solutions" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Industry solutions" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Industry solutions </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/mobility" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Mobility services" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Mobility services </span> </a> </li> <li class="devsite-nav-item devsite-nav-heading"> <span class="devsite-nav-title" tooltip > <span class="devsite-nav-text" tooltip > Places </span> </span> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/places/web-service" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Places API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Places API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/places/android-sdk" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Places SDK for Android" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Places SDK for Android </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/places/ios-sdk" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Places SDK for iOS" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Places SDK for iOS </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/javascript/places-js" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Places Library, Maps JavaScript API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Places Library, Maps JavaScript API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/geocoding" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Geocoding API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Geocoding API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/geolocation" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Geolocation API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Geolocation API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/address-validation" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Address Validation API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Address Validation API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/timezone" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Time Zone API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Time Zone API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/places-insights" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Places Insights API (Preview)" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Places Insights API (Preview) </span> </a> </li> <li class="devsite-nav-item devsite-nav-heading"> <span class="devsite-nav-title" tooltip > <span class="devsite-nav-text" tooltip > Environment </span> </span> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/air-quality" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Air Quality API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Air Quality API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/pollen" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Pollen API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Pollen API </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/documentation/solar" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Solar API" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Solar API </span> </a> </li> <li class="devsite-nav-item devsite-nav-heading"> <span class="devsite-nav-title" tooltip > <span class="devsite-nav-text" tooltip > Additional Resources </span> </span> </li> <li class="devsite-nav-item"> <a href="/maps/api-security-best-practices" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: API Security Best Practices" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > API Security Best Practices </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/digital-signature" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Digital Signature Guide" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Digital Signature Guide </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/coverage" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Map Coverage Details" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Map Coverage Details </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/optimization-guide" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Optimization Guide" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Optimization Guide </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/software-support" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Mobile OS and software support" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Mobile OS and software support </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/launch-stages" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Launch stages" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Launch stages </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/legacy" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Legacy products" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Legacy products </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/deprecations" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Deprecations" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Deprecations </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/asset-tracking-plan" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Asset Tracking Plan" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Asset Tracking Plan </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/url-encoding" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: URL Encoding" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > URL Encoding </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/third-party-platforms/wordpress" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: WordPress Users" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > WordPress Users </span> </a> </li> </ul> <ul class="devsite-nav-list" menu="Community" aria-label="Side menu" hidden> <li class="devsite-nav-item"> <a href="https://github.com/googlemaps/" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: GitHub" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > GitHub </span> </a> </li> <li class="devsite-nav-item"> <a href="https://www.youtube.com/c/GoogleMapsPlatform" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: YouTube" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > YouTube </span> </a> </li> <li class="devsite-nav-item"> <a href="https://www.linkedin.com/showcase/googlemapsplatform/" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: LinkedIn" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > LinkedIn </span> </a> </li> <li class="devsite-nav-item"> <a href="https://discord.gg/f4hvx8Rp2q" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Discord" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Discord </span> </a> </li> <li class="devsite-nav-item"> <a href="/maps/innovators" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Innovators" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Innovators </span> </a> </li> <li class="devsite-nav-item"> <a href="https://issuetracker.google.com/bookmark-groups/76561" class="devsite-nav-title gc-analytics-event " data-category="Site-Wide Custom Events" data-label="Responsive Tab: Issue Tracker" track-type="navMenu" track-metadata-eventDetail="globalMenu" track-metadata-position="nav"> <span class="devsite-nav-text" tooltip > Issue Tracker </span> </a> </li> </ul> </div> </div> </nav> </devsite-book-nav> <section id="gc-wrapper"> <main role="main" id="main-content" class="devsite-main-content" has-book-nav > <devsite-content> <article class="devsite-article"><style> /* Styles inlined from /maps/documentation/local_extensions.css */ .version { text-align: right; } .code { color: #006000; font-family: "Courier", monospace; font-size: 100%; } .grid td { padding: 4px; border-collapse: collapse; border: 1px solid gray; } .header td { font-weight: bold; background: #EEEEEE; } .encodeBox { width: 550px; height: 40px; font-size: 14px; font-family: Courier; } .inputField { width: 160px; } #pointList { width: 300px; font-size: 12px; } #txtAddress { width: 14em; } .welcome { border: none; } .welcome td{ border: none; padding:0 10px 0 10px; } .number { background-color: #E5ECF9; text-align:center; vertical-align:middle; padding: 0 5px; } .leftpadding { padding: 0 0 0 10px; } .identifier { color: black; } /* List the contents inline to save vertical space */ .summarylist { margin-right: 4em; } .summarylist li { display: inline; margin: 0em; margin-right: 0.2em; line-height: 1.5em; } /* Self-links for Maps API for Flash */ a.self-link:link { color: #0000cc; text-decoration: none; } a.self-link:active { color: #0000cc; text-decoration: none; } a.self-link:visited { color: #0000cc; text-decoration: none; } /* Self-links for Maps API */ .self-link { cursor: pointer; } .blackbg { background: #333; } </style><style> /* Styles inlined from /maps/styles/common.css */ /* Enable Billing Modal Dialog Styles */ .devsite-enable-billing-dialog { left: 50%; margin-left: -274px; top: 25%; width: 548px; } .devsite-dialog-close { color: #747474; } #devsite-dialog-onload-billing-enabled { padding: 0; } #devsite-dialog-onload-billing-enabled .get-key-check { background: no-repeat #8cc152 center/72px url(/maps/images/lhimages/v2/check@2x.png); height: 150px; width: 100%; } #devsite-dialog-onload-billing-enabled .devsite-dialog-contents, #devsite-dialog-onload-billing-enabled .devsite-dialog-buttons { margin: 8px; } .devsite-enable-billing-dialog ol { list-style: none; margin: 40px 0; padding: 0; } .devsite-enable-billing-dialog li { counter-increment: step-counter; font-size: 14px; line-height: 16px; margin-bottom: 28px; } .devsite-enable-billing-dialog li::before { border-radius: 50%; border: 2px solid #ececec; color: #00bcd4; content: counter(step-counter); font-size: 14px; font-weight: 500; margin-right: 22px; padding: 6px 10px; } /* Style Wizard introduction */ .styleWizardIntroMain { border-radius: 3px; height: 500; width: 640; } .styleWizardIntroSixMapSamples { left: calc(50% - (500px / 2)); line-height: 1; position: relative; text-align: center; width: 500px; } .styleWizardIntroSample { border: 1px solid rgba(0,0,0,0.07); border-radius: 3px; box-shadow: 0 1px 12px 0 rgba(0,0,0,0.10); display: inline-block; height: 140px; margin: 10px; overflow: hidden; width: 140px; } .styleWizardIntroCaption { text-align: center; } /* TODO(cl/330601385) waiting on fix to be deployed */ .devsite-jsfiddle-hide { position:absolute; top: -99999px; left: -99999px; display:block; } /* Styles for /maps/solutions best practices content */ #bp-background { border-radius: 25px; background: #e8eaed; } #bp-heading span { float:left; margin-right:10px; position:relative; padding: 10px; } /* Use as <ul id="bp-bullet><li>{{ [bp|add]_bullet }}Text here... to have icons serve as the bullet symbol. */ #bp-bullet { list-style-type: none; text-indent: -20px; margin-left: 50px; } #platform-box { float: right; position: relative; width: 35%; padding: 20px 20px 0 20px; margin-left: 30px; margin-bottom: 30px; background-color: #ceead6; border-color: #e8eaed; border-style: solid; } #sb-box { float: right; position: relative; width: 25%; padding: 20px 20px 0 20px; margin-left: 30px; margin-bottom: 30px; background-color: #d2e3fc; border-color: #e8eaed; border-style: solid; } /** Table formatting used in the How to use, How to access, and Inputs and * outputs sections of the API overviews. You can leave the first column blank, * as shown in the How to access sections. For questions, contact @wildwood **/ .implementation-path tr td:first-of-type { background: var(--tenant-background-1) !important; max-width: 48px; vertical-align: top; } .implementation-path tr td:nth-of-type(2) { background: var(--tenant-background-1) !important; color: var(--tenant-primary-text-color); min-width: 200px; text-align: left; vertical-align: top; } .implementation-path tr td { color: var(--tenant-secondary-text-color); padding: 24px; } .implementation-path tr { border-top: var(--tenant-primary-border); vertical-align: top; } /** From docs-intro.css - This forms the bubbles with numbers in the above table. **/ .implementation-path .numbered { background: var(--tenant-numbered-row-background-color, #BDBDBD); border-radius: 50%; color: var(--tenant-inverted-text-color); display: inline-block; font-size: 20px; height: 36px; line-height: 36px; margin-right: 20px; text-align: center; vertical-align: top; width: 36px; position: relative; top:-8px; } </style><style> /* customize BG color in THs & TDs (columns) of Maps keys tables*/ .maps-keys td:nth-of-type(1), { background-color:#e4eaf2; } .maps-keys th:nth-of-type(2) { background-color:#3949ab; } .maps-keys td:nth-of-type(2) { background-color:#e5e7f4; } .maps-keys th:nth-of-type(3) { background-color:#7cb342; } .maps-keys td:nth-of-type(3) { background-color:#eef5e7; } tr.example td code { font-size: 80%; } table.usage td:nth-of-type(2), table.usage th:nth-of-type(2) { text-align: center; } table.usage td:nth-of-type(3), table.usage th:nth-of-type(3) { text-align: right; } .supnote { font-size:80%; margin-bottom: 3em; } dt { font-size: 120%; } h4 { border-bottom: 1px solid #ebebeb; } li.margin-top { margin-top:2em; } .center { text-align: center } </style> <div class="devsite-article-meta nocontent" role="navigation"> <ul class="devsite-breadcrumb-list" aria-label="Breadcrumb"> <li class="devsite-breadcrumb-item "> <a href="https://developers.google.com/" class="devsite-breadcrumb-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Breadcrumbs" data-value="1" track-type="globalNav" track-name="breadcrumb" track-metadata-position="1" track-metadata-eventdetail="" > Home </a> </li> <li class="devsite-breadcrumb-item "> <div class="devsite-breadcrumb-guillemet material-icons" aria-hidden="true"></div> <a href="https://developers.google.com/products" class="devsite-breadcrumb-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Breadcrumbs" data-value="2" track-type="globalNav" track-name="breadcrumb" track-metadata-position="2" track-metadata-eventdetail="" > Products </a> </li> <li class="devsite-breadcrumb-item "> <div class="devsite-breadcrumb-guillemet material-icons" aria-hidden="true"></div> <a href="https://developers.google.com/maps" class="devsite-breadcrumb-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Breadcrumbs" data-value="3" track-type="globalNav" track-name="breadcrumb" track-metadata-position="3" track-metadata-eventdetail="Google Maps Platform" > Google Maps Platform </a> </li> <li class="devsite-breadcrumb-item "> <div class="devsite-breadcrumb-guillemet material-icons" aria-hidden="true"></div> <a href="https://developers.google.com/maps/documentation" class="devsite-breadcrumb-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Breadcrumbs" data-value="4" track-type="globalNav" track-name="breadcrumb" track-metadata-position="4" track-metadata-eventdetail="" > Documentation </a> </li> </ul> <devsite-thumb-rating position="header"> </devsite-thumb-rating> </div> <devsite-feedback position="header" project-name="Google Maps Platform" product-id="81777" bucket="" context="Maps API Product Family" version="t-devsite-webserver-20250211-r00-rc00.466928320959134316" data-label="Send Feedback Button" track-type="feedback" track-name="sendFeedbackLink" track-metadata-position="header" class="nocontent" project-icon="https://developers.google.com/static/maps/images/maps-icon.svg" > <button> Send feedback </button> </devsite-feedback> <h1 class="devsite-page-title" tabindex="-1"> Google Maps Platform FAQ </h1> <devsite-feature-tooltip ack-key="AckCollectionsBookmarkTooltipDismiss" analytics-category="Site-Wide Custom Events" analytics-action-show="Callout Profile displayed" analytics-action-close="Callout Profile dismissed" analytics-label="Create Collection Callout" class="devsite-page-bookmark-tooltip nocontent" dismiss-button="true" id="devsite-collections-dropdown" dismiss-button-text="Dismiss" close-button-text="Got it"> <devsite-bookmark></devsite-bookmark> <span slot="popout-heading"> Stay organized with collections </span> <span slot="popout-contents"> Save and categorize content based on your preferences. </span> </devsite-feature-tooltip> <devsite-key-takeaways></devsite-key-takeaways> <div class="devsite-page-title-meta"><devsite-view-release-notes></devsite-view-release-notes></div> <devsite-toc class="devsite-nav" depth="2" devsite-toc-embedded > </devsite-toc> <div class="devsite-article-body clearfix "> <h4 id="getting-started" data-text="Getting Started" tabindex="-1">Getting Started</h4> <ul> <li> <a href="#whatis"> What is the Google Maps Platform? </a> </li> <li> <a href="#getstarted"> How do I get started with Google Maps Platform? </a> </li> <li> <a href="#whichapi"> Which API do I need? </a> </li> <li> <a href="#startapi"> How do I start using the APIs on my site? </a> </li> <li> <a href="#whatcountries"> Which countries does the Google Maps Platform cover? </a> </li> <li> <a href="#mapswithoutapi"> Can I put Google Maps on my site without using Google Maps Platform products? </a> </li> <li> <a href="#mapsformobile"> How do I deliver Maps applications on mobile devices? </a> </li> <li> <a href="#browsersupport"> Which web browsers do the Maps JavaScript API and Maps Embed API support? </a> </li> <li> <a href="#print"> Can I print maps from the Maps JavaScript API? </a> </li> <li> <a href="#notify"> How can I be notified when there are changes to Google Maps Platform products? </a> </li> <li> <a href="#support"> How do I contact technical support? </a> </li> <li> <a href="#support_available"> When is technical support available? </a> </li> <li> <a href="#recover-gaccount-access"> How do I recover access to my Google Account? </a> </li> <li> <a href="#recover-project-access"> How do I recover access to a specific project? </a> </li> <li> <a href="#arm-based-macs"> Can I use the Maps and Places SDK for iOS on Arm-based Macs? </a> </li> </ul> <h4 id="understand-the-terms-of-service" data-text="Understand the terms of service" tabindex="-1">Understand the terms of service</h4> <ul> <li> <a href="#tos"> What are the terms of service for Google Maps Platform products? </a> </li> <li> <a href="#tos_mysite"> Does my site meet the Google Maps Platform Terms of Service? </a> </li> <li> <a href="#tos_tiles"> Can I directly access map tiles and satellite imagery? </a> </li> <li> <a href="#tos_tracking"> Can I use Google Maps Platform products for tracking applications? </a> </li> <li> <a href="#tos_nonweb"> Can I use Google Maps Platform products in my non-Web application? </a> </li> <li> <a href="#tos_password"> Can I use Google Maps Platform products on a site that is password protected? </a> </li> <li> <a href="#tos_export"> Can I create an application that includes Google Maps Platform data in a document? </a> </li> <li> <a href="#tos_optout"> How can I opt out of including my content in Google Search results? </a> </li> <li> <a href="#tos_staticmaps_reuse"> Can I generate a map image using the Maps Static API which I store and serve from my website? </a> </li> </ul> <h4 id="usage-limits-and-billing" data-text="Usage limits and billing" tabindex="-1">Usage limits and billing</h4> <ul> <li> <a href="#setup_billing"> How do I set up billing for my project? </a> </li> <li> <a href="#GCP_paid_account"> How do Google Cloud Free Tier customers upgrade to a paid account? </a> </li> <li> <a href="#usage_apis"> Does the Google Maps Platform have usage limits? </a> </li> <li> <a href="#usage_quotacalc"> How is usage cost calculated? </a> </li> <li> <a href="#usage_mapload"> How are map loads counted on the Google Maps Platform? </a> </li> <li> <a href="#usage-monitor"> How do I monitor my quota usage? </a> </li> <li> <a href="#usage_exceed"> What happens if I exceed the usage limits? </a> </li> <li> <a href="#hightrafficsite"> My site gets a lot of traffic. Can I use Google Maps Platform products? </a> </li> <li> <a href="#usage_popular"> If my website or application becomes suddenly popular, will my maps stop working? </a> </li> <li> <a href="#usage_calculated"> How will usage be calculated and billed? </a> </li> <li> <a href="#usage_pricing"> How much does it cost to use the Google Maps Platform? </a> </li> <li> <a href="#usage_currencies"> Is pricing available in other currencies? </a> </li> <li> <a href="#usage_viewbill"> I've set up billing. How do I view my bill? </a> </li> <li> <a href="#usage_cap"> How do I avoid a large bill if my usage unexpectedly increases? </a> </li> <li> <a href="#transition_account"> I got a message saying that my project is linked to the "Google Maps Platform Transition Account", but I don't have access to that account. What do I do? </a> </li> <li> <a href="#limit_1"> Why is my quota limit set to 1 request per day? How can I raise this limit? </a> </li> <li> <a href="#billing-violation-notice"> I received a billing violation notice. How do I resolve this? </a> </li> </ul> <h4 id="use-maps-apis" data-text="Use the Google Maps Platform" tabindex="-1">Use the Google Maps Platform</h4> <ul> <li> <a href="#keysystem"> Which keys or credentials should I use for different Google Maps Platform products? </a> </li> <li> <a href="#switch-key-type"> How do I switch my key restriction type from an HTTP referer to an IP address restriction? </a> </li> <li> <a href="#new-key"> How do I get a new API key? </a> </li> <li> <a href="#versionchanges"> How can I find the changes introduced in each version of the Google Maps Platform? </a> </li> <li> <a href="#loadasync"> How can I load the API into a page asynchronously after the page has loaded? </a> </li> <li> <a href="#languagesupport"> How can I get Google Maps Platform products to display in a language other than English? </a> </li> <li> <a href="#ssl"> Can the Google Maps Platform be accessed over SSL (HTTPS)? </a> </li> <li> <a href="#reportissue"> How do I report a bug or request a new feature in the Google Maps Platform? </a> </li> <li> <a href="#api_cookies"> How do Google Maps Platform APIs use site cookies? </a> </li> <li> <a href="#morehelp"> I can't find the answer to my question. Who should I contact? </a> </li> </ul> <h4 id="errors-and-troubleshooting" data-text="Errors and troubleshooting" tabindex="-1">Errors and troubleshooting</h4> <ul> <li> <a href="#errorcodes"> What does this error mean? </a> </li> <li> <a href="#api-key-billing-errors"> My maps appear darker than usual. What's happening? </a> </li> <li> <a href="#over-limit-key-error"> How do I resolve the error codes <code translate="no" dir="ltr">OVER_DAILY_LIMIT</code> or <code translate="no" dir="ltr">OVER_QUERY_LIMIT</code>? </a> </li> <li> <a href="#rate-limit-exceeded-error"> How do I resolve the error codes: <code translate="no" dir="ltr">kGMSPlacesRateLimitExceeded</code> or <code translate="no" dir="ltr">9005 PLACES_API_RATE_LIMIT_EXCEEDED</code>? </a> </li> <li> <a href="#api-key-error"> How do I resolve the error: "This IP, site or mobile application is not authorized to use this API key."? </a> </li> <li> <a href="#browser-keys-blocked-error"> How do I resolve the error: "API keys with referer restrictions cannot be used with this API."? </a> </li> </ul> <h4 id="places-api" data-text="Google Maps Platform Services" tabindex="-1">Google Maps Platform Services</h4> <ul> <li> <a href="#geocoder_exists"> I need to convert addresses to latitude/longitude pairs. Can I do that with the Google Maps Platform? </a> </li> <li> <a href="#geocoder_countries"> Which countries is geocoding available in? </a> </li> <li> <a href="#geocoder_differences"> Why do the Google Maps Platform Geocoders provide different locations than Google Maps? </a> </li> <li> <a href="#geocoder_queryformat"> How should I format my geocoder queries to maximise the number of successful requests? </a> </li> <li> <a href="#geocoder_highways"> How should I format a US address on a numbered highway for geocoding? </a> </li> <li> <a href="#geocoder_classorhttp"> When should I use an API geocoder class and when should I use the HTTP Geocoding Service? </a> </li> <li> <a href="#directions_exists"> How do I provide driving directions with the Google Maps Platform? </a> </li> <li> <a href="#directions_countries"> In which countries are driving directions available? </a> </li> <li> <a href="#transit_directions_countries"> In which countries are transit directions available? </a> </li> <li> <a href="#geoxmlsupport"> Which KML and GeoRSS features are supported in the Maps JavaScript API? </a> </li> <li> <a href="#geoxmllimits"> What are the limits on the size and complexity of KML that can be displayed using the KmlLayer class of the Maps JavaScript API? </a> </li> <li><a href="#intranet_kml">How do I render KML files that are hosted on intranet sites on a map?</a> </li> <li> <a href="#staticmap_limits"> What is the maximum number of markers or path vertices supported by the Maps Static API? </a> </li> <li> <a href="#prohibited_territories_ws_access"> Why can't I access Google Maps Platform products for certain countries? </a> </li> <li> <a href="#data-issues"> How do I report a problem on the Google basemap? </a> </li> <li> <a href="#uptime_slo"> How is performance monitored for the services used with Maps JavaScript API? </a> </li> </ul> <h4 id="places-api-ws" data-text="Maps JavaScript API" tabindex="-1">Maps JavaScript API</h4> <ul> <li> <a href="#jsrefresh">How long will the Maps JavaScript API work after it has been loaded?</a> </li> </ul> <h4 id="google-maps-sdk-for-ios" data-text="Google Maps SDK for iOS" tabindex="-1">Google Maps SDK for iOS</h4> <ul> <li> <a href="#rate-limit-error-ios"> How do I resolve the error: <code translate="no" dir="ltr">kGMSPlacesRateLimitExceeded</code>? </a> </li> <li> <a href="#ios8-debug"> I'm getting crashes when debugging with an iOS 8.x device. What should I do? </a> </li> <li> <a href="#iphone-x"> What's the impact of rounded and wider screens on the Google Maps iOS SDK? </a> </li> </ul> <h4 id="google-maps-sdk-for-android" data-text="Google Maps SDK for Android" tabindex="-1">Google Maps SDK for Android</h4> <ul> <li> <a href="#9005-error-android"> How do I resolve the error: <code translate="no" dir="ltr">9001 Operation failed due to exceeding the quota usage limit</code>? </a> </li> <li> <a href="#android-grey-tiles"> My app only shows blank grey tiles instead of a map. How can I resolve this? </a> </li> </ul> <h4 id="url-signing" data-text="URL signing" tabindex="-1">URL signing</h4> <ul> <li><a href="#signature_js">Can I sign URLs using JavaScript?</a></li> <li><a href="#signature_403">Why am I receiving a HTTP 403 Forbidden response to my Maps API web service requests?</a></li> </ul> <h2 id="getting-started" data-text="Getting Started" tabindex="-1">Getting Started</h2> <dl> <dt id="whatis"> What is the Google Maps Platform? </dt> <dd> <p>The Google Maps Platform is a set of APIs and SDKs that allows developers to embed Google Maps into mobile apps and web pages, or to retrieve data from Google Maps. There are several offerings. Depending on your needs, you may find yourself using one or a combination of these APIs and SDKs:</p> <p>Maps:</p> <ul> <li><a href="/maps/documentation/javascript">Maps JavaScript API</a></li> <li><a href="/maps/documentation/android-sdk">Maps SDK for Android</a></li> <li><a href="/maps/documentation/ios-sdk">Maps SDK for iOS</a></li> <li><a href="/maps/documentation/tile">Map Tiles API</a></li> <li><a href="/maps/documentation/aerial-view">Aerial View API</a></li> <li><a href="/maps/documentation/maps-static">Maps Static API</a></li> <li><a href="/maps/documentation/streetview">Street View Static API</a></li> <li><a href="/maps/documentation/urls/guide">Maps URLs</a></li> <li><a href="/maps/documentation/embed">Maps Embed API</a></li> <li><a href="/maps/documentation/datasets">Maps Datasets API</a></li> </ul> <p>Routes:</p> <ul> <li><a href="/maps/documentation/routes">Routes API</a></li> <li><a href="/maps/documentation/roads">Roads API</a></li> <li><a href="/maps/documentation/directions">Directions API</a></li> <li><a href="/maps/documentation/distance-matrix">Distance Matrix API</a></li> <li><a href="/maps/documentation/route-optimization">Route Optimization API</a></li> <li><a href="/maps/documentation/navigation/android-sdk">Navigation SDK for Android</a></li> <li><a href="/maps/documentation/navigation/ios-sdk">Navigation SDK for iOS</a></li> </ul> <p>Places:</p> <ul> <li><a href="/maps/documentation/places/web-service">Places API</a></li> <li><a href="/maps/documentation/places/android-sdk">Places SDK for Android</a></li> <li><a href="/maps/documentation/places/ios-sdk">Places SDK for iOS</a></li> <li><a href="/maps/documentation/javascript/places">Places Library, Maps JavaScript API</a></li> <li><a href="/maps/documentation/address-validation">Address Validation API</a></li> <li><a href="/maps/documentation/geocoding">Geocoding API</a></li> <li><a href="/maps/documentation/geolocation">Geolocation API</a></li> <li><a href="/maps/documentation/timezone">Time Zone API</a></li> </ul> <p>Environment:</p> <ul> <li><a href="/maps/documentation/air-quality">Air Quality API</a></li> <li><a href="/maps/documentation/pollen">Pollen API</a></li> <li><a href="/maps/documentation/solar">Solar API</a></li> </ul> </dd> <dt id="getstarted"> How do I get started with Google Maps Platform? </dt> <dd> <p> See <a href="/maps/get-started">Get Started with Google Maps Platform</a>. </p> </dd> <dt id="whichapi"> Which API do I need? </dt> <dd> <p> For help in finding the right API based on your functional requirements, take a look at the <a href="/maps/documentation/api-picker">API picker</a>. </p> </dd> <dt id="startapi"> How do I start using the APIs on my site? </dt> <dd> <p> See the Overview, Developer, and Get Started guides for the specific API or SDK you are interested in. For example, check out the guides for <a href="/maps/documentation/android-sdk/intro">Maps SDK for Android</a> or <a href="/maps/documentation/javascript/tutorial">Maps JavaScript API</a>. </p> </dd> <dt id="whatcountries"> Which countries does the Google Maps Platform cover? </dt> <dd> <p> The Google Maps team is constantly pushing new map data out and increasing our international coverage. Consult the <a href="/maps/coverage">Google Maps coverage data</a> for the latest coverage information. You can filter the data with the filter box at the top of the page. Coverage data can change if licensing agreements with the data providers change. </p> <p>Also see:</p> <ul> <li><a href="#languagesupport">How can I get Google Maps Platform products to display in a language other than English?</a></li> <li><a href="#transit_directions_countries">In which countries are transit directions available?</a></li> </ul> </dd> <dt id="mapswithoutapi"> Can I put Google Maps on my site without using Google Maps Platform products? </dt> <dd> <p> Yes. <a href="http://maps.google.com" class="external">Google Maps</a> now offers the ability to embed the map that you're viewing into your website or blog, without any programming or use of the Google Maps Platform. More information is available <a href="https://support.google.com/maps/answer/3544418" class="external"> here</a>. </p> </dd> <dt id="mapsformobile"> How do I deliver Maps applications on mobile devices? </dt> <dd> <p> To incorporate maps in an Android application, use the <a href="/maps/documentation/android-sdk">Maps SDK for Android</a>. </p> <p> To incorporate maps in an iOS application, use the <a href="/maps/documentation/ios-sdk">Maps SDK for iOS</a>. </p> <p> The <a href="/maps/documentation/javascript"> Maps JavaScript API</a> has been developed to cater to mobile devices, and is suitable for browser applications targeted at both the desktop and devices that include a web browser with a full JavaScript implementation, such as the Apple iPhone. </p> <p> For applications targeted at devices not suitable for using the Maps JavaScript API, the <a href="/maps/documentation/maps-static">Maps Static API</a> delivers map images in GIF, JPG, and PNG formats, including markers and polylines. Note that use of the Maps Static API outside of browser based applications requires that the map image be linked to Google Maps. </p> </dd> <dt id="browsersupport"> Which web browsers do the Maps JavaScript API and Maps Embed API support? </dt> <dd> <p> The Maps JavaScript API and Maps Embed API support the following web browsers: </p> <strong>Desktop</strong> <ul> <li>The current version of Microsoft Edge (Windows), <strong>excluding</strong> IE mode.</li> <li>The two latest major stable versions of Firefox (Windows, macOS, Linux).</li> <li>The two latest major stable versions of Chrome (Windows, macOS, Linux).</li> <li>The two latest major stable versions of Safari (macOS).</li> </ul> <strong>Android</strong> <ul> <li>The current version of Chrome on Android 4.1+.</li> <li>Chrome WebView on Android 4.4+.</li> </ul> <strong>iOS</strong> <ul> <li>Mobile Safari on the current and previous major versions of iOS.</li> <li> UIWebView and WKWebView on the current and previous major versions of iOS. </li> <li>The current version of Chrome for iOS.</li> </ul> </dd> <dt id="print"> Can I print maps from the Maps JavaScript API? </dt> <dd> <p> Printing from the Maps JavaScript API is not supported. This is because printing support is inconsistent across commonly used browsers. </p> </dd> <dt id="notify"> How can I be notified when there are changes to Google Maps Platform products? </dt> <dd> <p>You should subscribe to the <a href="https://mapsplatform.google.com/resources/blog" class="external">Google Maps Platform Blog</a> for news updates across the various Google Geo developer offerings. </p> </dd> <dt id="support"> How do I contact technical support? </dt> <dd> <p> See <a href="/maps/support">Google Maps Platform Support and Resources</a> for information about available support options. </p> </dd> <dt id="support_available"> When is technical support available? </dt> <dd> The support team is available 24x5 (weekdays from Monday 9 AM Tokyo time to Friday 5 PM Pacific time) excluding <a href="https://support.google.com/googlecloud/answer/6047804" class="external">regional holidays</a> for "service unusable" issues. </dd> <dt id="recover-gaccount-access"> How can I recover access to my Google Account? </dt> <dd> <p>If you lost access to your Google Account (e.g. joe@mycompany.com or joe@gmail.com), you can try restoring the account access by retrieving or resetting your password. Visit the <a href="https://support.google.com/accounts/answer/7682439" class="external">How to recover your Google Account or Gmail</a> article in Google Account Help.</p> <ul> <li>Note: To restore access to a G Suite account, ask your <a href="https://support.google.com/a/answer/1397578" class="external">Organization</a> administrator to <a href="https://support.google.com/a/answer/1397578" class="external">undelete the account</a>.</li> </ul> </dd> <dt id="recover-project-access"> How can I recover access to a specific project? </dt> <dd> <p>If you lost access to the project where you manage your Google Maps Platform implementation, you can try to recover it.</p> <p>If you have access to your project-associated Google Account:</p> <ul> <li><strong>If you know the Project Owner and have access to your Google Account:</strong> Ask the Project Owner to <a href="https://cloud.google.com/iam/docs/granting-changing-revoking-access#granting-console" class="external">add you as a Project Owner or Project Editor</a>. <ul> <li><strong>If your project is part of an Organization:</strong> Contact your <a href="https://cloud.google.com/resource-manager/docs/cloud-platform-resource-hierarchy" class="external">Organization</a> admins and ask them to <a href="https://cloud.google.com/iam/docs/granting-changing-revoking-access#granting-console" class="external">add you as a Project Owner</a>.</li> </ul> </li> <li><strong>If you don't know any of the current Project Owners:</strong> If you don't know who the Project Owner is, or the Project Owner is unavailable, <a href="/maps/support?utm_source=faq&utm_medium=contact_support" class="gc-analytics-event" data-category="GMPsupport" data-action="linkClick: body" data-label="contact-support-team">contact the support team</a> to explore additional options to recover the project.</li> </ul> <p>If you <strong> don't</strong> have access to your project-associated Google Account:</p> <ul> <li><strong>If you lost access to your Google Account:</strong> <a href="#recover-gaccount-access">try to recover your username or password</a> for your account.</li> <li><strong>If you cannot recover access to your Google Account:</strong> Create a new Google Account, then contact an existing project owner and ask them to <a href="https://cloud.google.com/iam/docs/granting-changing-revoking-access#granting-console" class="external">add your new Google Account to the project</a>.</li> </ul> </dd> <dt id="arm-based-macs"> Can I use the Maps and Places SDK for iOS on Arm-based Macs? </dt> <dd> <p>Developing on the new Arm-based Macs is possible, however, it requires building and running on a physical iOS device. This is a temporary limitation while we look into adding more support for developing on simulators.</p> </dd> </dl> <h2 id="understanding-terms-of-service" data-text="Understand the terms of service" tabindex="-1">Understand the terms of service</h2> <dl> <dt id="tos"> What are the terms of service for Google Maps Platform products? </dt> <dd> <p> The Google Maps Platform Terms of Service are available at: </p> <p> <a href="https://cloud.google.com/maps-platform/terms" class="external"> https://cloud.google.com/maps-platform/terms</a> </p> </dd> <dt id="tos_mysite"> Does my site meet the Google Maps Platform Terms of Service? </dt> <dd> <p> You can use the Google Maps Platform within your applications as long as your site meets the <a href="https://cloud.google.com/maps-platform/terms" class="external">Google Maps Platform Terms of Service</a>. </p> <p> However, there are some uses of the Google Maps Platform that we just don't want to see. For example, maps that identify the places to buy illegal drugs in a city or any other illegal activity. We also respect people's privacy, so the Google Maps Platform shouldn't be used to identify private information about individuals. </p> <p> You should use your own counsel to determine whether your application complies with the <a href="https://cloud.google.com/maps-platform/terms" class="external">Google Maps Platform Terms of Service</a> before you develop and launch it. Google engineers can only offer technical assistance and are not qualified to offer legal advice. Google reserves the right to suspend or terminate your use of the service at any time, so read the <a href="https://cloud.google.com/maps-platform/terms" class="external">Maps APIs Terms</a> carefully. </p> </dd> <dt id="tos_tiles"> Can I directly access map tiles and satellite imagery? </dt> <dd> <p> You may not access map tiles or satellite imagery through any mechanism besides the Google Maps Platform (such as the creation of your own mapping API or the use of a bulk tile download script). Your application's access to the tiles will be blocked if it accesses them outside of the Google Maps Platform. See the <a href="https://cloud.google.com/maps-platform/terms#3-license" class="external">Google Maps Platform Terms of Service</a> for more details. </p> </dd> <dt id="tos_tracking"> Can I use Google Maps Platform products for tracking applications? </dt> <dd> <p> There is no restriction on displaying real-time data (tracking) with Google Maps Platform products provided that the application complies with the Google Maps Platform Terms of Service. </p> </dd> <dt id="tos_nonweb"> Can I use Google Maps in my non-Web application? </dt> <dd> <p> Yes, Google Maps Platform products can now be used in non-Web applications, provided that they adhere to the other restrictions of the Google Maps Platform Terms of Service. </p> <p> The Maps JavaScript API is only supported when run in one of the <a href="/maps/documentation/javascript/browsersupport"> supported browsers</a>.</p> </dd> <dt id="tos_password"> Can I use Google Maps Platform products on a site that is password protected? </dt> <dd> <p> Yes, Google Maps, Routes, Places, and Environment services can be used with private-access applications. See the <a href="https://cloud.google.com/maps-platform/terms" class="external">Google Maps Platform Terms of Service</a> for more details. </p> </dd> <dt id="tos_export"> Can I create an application that includes Google Maps Platform data in a document? </dt> <dd> <p> If your application generates a document, either in electronic or printed form, no data from Google Maps Platform, including images, may be included in the document. See the <a href="https://cloud.google.com/maps-platform/terms#3.-license." class="external">Google Maps Platform Terms of Service</a> "No Scraping" section for more details. </p> </dd> <dt id="tos_optout"> How can I opt out of including my content in Google Search results? </dt> <dd> <p>We are no longer collecting this data. The use of the <code translate="no" dir="ltr">indexing</code> parameter has been deprecated and has no effect. You no longer need to opt out explicitly, but we encourage you to remove this parameter at your earliest convenience.</p> <p> To remove your page or site from search results, follow the <a href="http://www.google.com/support/webmasters/bin/topic.py?topic=8459" class="external"> instructions</a> provided in our help center. </p> </dd> <dt id="tos_staticmaps_reuse"> Can I generate a map image using the Maps Static API which I store and serve from my website? </dt> <dd> <p> You may not store and serve copies of images generated using the Maps Static API from your website. All web pages that require static images must link the <code translate="no" dir="ltr">src</code> attribute of an HTML <code translate="no" dir="ltr">img</code> tag or the CSS <code translate="no" dir="ltr">background-image</code> attribute of an HTML <code translate="no" dir="ltr">div</code> tag directly to the Maps Static API so that all map images are displayed within the HTML content of the web page and served directly to end users by Google. </p> </dd> </dl> <h2 id="usage-limits" data-text="Usage limits and billing" tabindex="-1">Usage limits and billing</h2> <dl> <dt id="setup_billing"> How do I set up billing for my project? </dt> <dd> See <a href="/maps/get-started">Get Started with Google Maps Platform</a>. </dd> <dt id="GCP_paid_account"> How do Google Cloud No Charge Tier customers upgrade to a paid account? </dt> <dd> The <a href="https://cloud.google.com/free/docs/gcp-free-tier" class="external">Google Cloud No Charge Tier</a> program provides customers a no-charge trial with a $300 credit to use with any Google Cloud service, including the Google Maps Platform (GMP) APIs. When the no-charge trial period ends, you must <a href="https://cloud.google.com/free/docs/gcp-free-tier#how-to-upgrade" class="external">upgrade to a paid account</a> to continue using these services. To upgrade to a paid account, visit the <a href="https://console.cloud.google.com/project/_/billing/enable?utm_source=Docs_BillingNudge" target="console" class="gc-analytics-event external" data-category="GMPFAQ" data-action="linkClick: link" data-label="GCPPaidAccount">Cloud console</a>. </dd> <dt id="usage_apis"> Does the Google Maps Platform have usage limits? </dt> <dd> <p> There are no maximum daily limits on the number of requests you can make to Google Maps Platform products, and the only usage limits are related to the maximum number of queries per minute (QPM).</p> <p>For Distance Matrix, the limit is set in events per minute (EPM) calculated as the sum of client-side and server-side queries.</p> <p>For Routes:Compute Route Matrix, the limit is in elements per minute (EPM), where the number of elements in a request is equal to: (number of origins times number of destinations).</p> <p> For the Navigation SDKs, each destination in a request is counted as a separate query. </p> <p>The following table shows the usage limit for each API.</p> <table> <tbody> <thead> <tr> <th>API</th> <th colspan="2">Usage limit</th> </tr> </thead> <tr> <td>Address Validation</td> <td><a href="/maps/documentation/address-validation/usage-and-billing#other-usage-limits">6,000 QPM</a></td> </tr> <tr> <td>Aerial View: Lookup Video</td> <td><a href="/maps/documentation/aerial-view/usage-and-billing#other-usage-limits">180 QPM and 100,000 QPD</a></td> </tr> <tr> <td>Aerial View: Render Video</td> <td><a href="/maps/documentation/aerial-view/usage-and-billing#other-usage-limits">100 QPM and 100 QPD</a></td> </tr> <tr> <td>Air Quality</td> <td><a href="/maps/documentation/air-quality/usage-and-billing#other-usage-limits">6,000 QPM</a></td> </tr> <tr> <td>Directions</td> <td><a href="/maps/documentation/directions/usage-and-billing#other-usage-limits">3,000 QPM</a></td> </tr> <tr> <td>Distance Matrix</td> <td><a href="/maps/documentation/distance-matrix/usage-and-billing#other-usage-limits">60,000 EPM</a></td> </tr> <tr> <td>Dynamic Maps</td> <td>30,000 QPM</td> </tr> <tr> <td>Elevation</td> <td><a href="/maps/documentation/elevation/usage-and-billing#other-usage-limits">6,000 QPM</a></td> </tr> <tr> <td>Geocoding</td> <td><a href="/maps/documentation/geocoding/usage-and-billing#other-usage-limits">3,000 QPM</a></td> </tr> <tr> <td>Geolocation</td> <td><a href="/maps/documentation/geolocation/usage-and-billing#other-usage-limits">6,000 QPM</a></td> </tr> <tr> <td>Map Tiles API: 2D Tiles and Street View Tiles</td> <td><a href="/maps/documentation/tile/usage-and-billing#other-usage-limits">6,000 QPM and 15,000 QPD</a></td> </tr> <tr> <td>Map Tiles API: Photorealistic 3D Tiles</td> <td><a href="/maps/documentation/tile/usage-and-billing#other-usage-limits">10000 QPD</a></td> </tr> <tr> <td>Map Tiles API: Photorealistic 3D Tiles: Renderer</td> <td><a href="/maps/documentation/tile/usage-and-billing#other-usage-limits">12,000 QPM</a></td> </tr> <tr> <td>Navigation: Set destination requests</td> <td><a href="/maps/documentation/navigation/android-sdk/pricing#other-usage-limits">30,000 QPM</a> </td> </tr> <tr> <td>Places</td> <td><a href="/maps/documentation/places/web-service/usage-and-billing#other-usage-limits">6,000 QPM</a></td> </tr> <tr> <td>Pollen</td> <td><a href="/maps/documentation/pollen/usage-and-billing#other-usage-limits">6,000 QPM </a></td> </tr> <tr> <td>Roads</td> <td><a href="/maps/documentation/roads/usage-and-billing#other-usage-limits">30,000 QPM</a></td> </tr> <tr> <td>Routes: Compute Routes</td> <td><a href="/maps/documentation/routes/usage-and-billing#other-usage-limits">3,000 QPM</a></td> </tr> <tr> <td>Routes: Compute Route Matrix</td> <td><a href="/maps/documentation/routes/usage-and-billing#other-usage-limits">3,000 EPM</a></td> </tr> <tr> <td>Solar</td> <td><a href="/maps/documentation/solar/usage-and-billing#other-usage-limits">600 QPM</a></td> </tr> <tr> <td>Static Maps</td> <td><a href="/maps/documentation/maps-static/usage-and-billing#other-usage-limits">30,000 QPM</a></td> </tr> <tr> <td>Street View Image API</td> <td><a href="/maps/documentation/streetview/usage-and-billing#other-usage-limits">30,000 QPM</a></td> </tr> <tr> <td>Time Zone</td> <td><a href="/maps/documentation/timezone/usage-and-billing#other-usage-limits">30,000 QPM</a></td> </tr> </tbody> </table> <p>In order to govern expenditures, you can <a href="#usage-monitor">monitor your API usage</a>, and <a href="#usage_cap">set daily limits</a> to all requests to any billable API.</p> <p>Google Maps Platform products must be deployed in compliance with the standard <a href="#understanding-terms-of-service">Google Maps Platform Terms of Service</a>.</p> </dd> <dt id="usage_quotacalc"> How is usage cost calculated? </dt> <dd> <p> For an overview of pricing for the Google Maps Platform products, see the <a href="https://mapsplatform.google.com/pricing/" class="external">Pricing Sheet</a>. </p> <p>To learn more about how Google Maps Platform APIs are billed, see <a href="/maps/billing/understanding-cost-of-use">Understanding billing for Maps, Routes, Places, and Environment</a>.</p> </dd> <dt id="usage_mapload"> How are map loads counted on the Google Maps Platform? </dt> <dd> <p>A single map load is charged when any of the following occur: </p> <ul> <li>A web page or application displays a map using the Maps JavaScript API. </li> <li>An application requests a single map image from the Maps Static API. </li> </ul> <p>Street View panoramas are charged separately from map loads:</p> <ul> <li>A static Street View panorama is charged for each request to the Street View Static API to embed a static (non-interactive) Street View panorama. </li> <li>A dynamic Street View panorama is charged for each instantiation of a panorama object in a Maps JavaScript API, Maps SDK for Android, or Maps SDK for iOS application. </li> </ul> <p>After a web page or application loads a map, or a static map image, or a Street View panorama, any user interactions with it, such as panning, zooming, or switching map layers, don't generate additional map loads or affect usage limits.</p> <p>Adding a marker won't generate additional map loads, but may generate charges around how the pin location was determined (such as loading or reloading the `google.maps.Map()` class.)</p> </dd> <dt id="usage-monitor"> How do I monitor my usage? </dt> <dd> <p> You can monitor the usage of individual APIs in the <a href="https://console.cloud.google.com/project/_/apiui/apis/enabled?utm_source=Docs_EnabledAPIsView" target="console" class="gc-analytics-event external" data-category="GMPFAQ" data-action="linkClick: link" data-label="usageMonitor">Google Cloud console</a>.</p> <ol> <li>Select the project that contains the API you want to review.</li> <li>From the list of APIs on the Dashboard, click the name of the API.</li> <li>Near the top of the page, click <strong>Metrics</strong> or <strong>Quotas</strong>.</li> </ol> <p> To see a traffic report and billing information for an entire project, follow these steps: </p> <ol> <li>If you haven't already done so, <a href="#setup_billing">set up billing</a>.</li> <li>Go to the Cloud console <a href="https://console.cloud.google.com/project/_/billing" target="console" class="gc-analytics-event external" data-category="GMPFAQ" data-action="linkClick: link" data-label="setupReportBilling">billing page</a>.</li> <li>Select a project.</li> <li>In the left sidebar, click <strong>Reports</strong>. Use the filters on the right sidebar to view reports on your billing account.</li> </ol> <p>To learn more, see <a href="/maps/reporting-and-monitoring/reporting">Google Maps Platform Reporting</a> as well as <a href="https://cloud.google.com/apis/docs/monitoring" target="_blank" class="external">Monitoring your API Usage</a> and <a href="https://cloud.google.com/apis/docs/capping-api-usage" target="_blank" class="external">Capping API Usage</a>. </p> </dd> <dt id="usage_exceed"> What happens if I exceed the request rate (QPM) limits? </dt> <dd> <p>If you exceed the <a href="#usage_apis">QPM limits</a> of a given Google Maps Platform product, the API will return an error message. If you repeatedly exceed the limits, your access to the API may be temporarily blocked.</p> <p>If you exceed the request <a href="#usage_apis">QPM limits</a> or otherwise abuse the service, requests will return a specific error message. If you continue to exceed limits, your access to the Google Maps Platform may be blocked.</p> <p><strong>Note:</strong> Four of the web service APIs have an equivalent client-side service available in the Maps JavaScript API: <a href="/maps/documentation/javascript/directions">Directions</a>, <a href="/maps/documentation/javascript/distancematrix">Distance Matrix</a>, <a href="/maps/documentation/javascript/elevation">Elevation</a>, and <a href="/maps/documentation/javascript/geocoding">Geocoding</a>.</p> <p><strong>Usage limits exceeded</strong></p> <p>If you exceed the usage limits you get an <code translate="no" dir="ltr">OVER_QUERY_LIMIT</code> status code as a response.</p> <p>This message means that the web service has stopped providing normal responses and has switched to returning only status code <code translate="no" dir="ltr">OVER_QUERY_LIMIT</code> until more usage is allowed again. This scenario can happen within a few seconds, if the error was received because your application sent too many requests per minute.</p> <p>If you regularly exceed your QPM usage limits, consider lowering usage by optimizing applications to use Google Maps Platform products more efficiently, or request to increase your quota. See the <a href="/maps/optimization-guide">Optimization Guide</a> for more information.</p> </dd> <dt id="hightrafficsite"> My site gets a lot of traffic. Can I use Google Maps Platform products? </dt> <dd> <p> Yes. However we recommend that you familiarize yourself with the <a href="#usage_apis">usage limits</a> for any of the Google Maps Platform that your application relies on. </p> </dd> <dt id="usage_popular"> If my website or application becomes suddenly popular, will my maps stop working? </dt> <dd> <p>Once you have a billing account, if you exceed the no-charge, $200-monthly usage limit and you don't have a valid payment method on your billing account (credit card, bank transfer, ...), the API ceases to function until you add a valid payment method.</p> </dd> <dt id="usage_calculated"> How will usage be calculated and billed? </dt> <dd> <p>Usage is calculated at the end of each day, and priced as shown in the <a href="https://cloud.google.com/maps-platform/pricing/sheet/" class="external">Pricing Sheet</a>. At the end of every month, the total usage is charged to the payment method associated with your billing account. For more information, see <a href="/maps/billing/understanding-cost-of-use">Google Maps Platform Billing</a>.</p> </dd> <dt id="usage_pricing"> How much does it cost to use the Google Maps Platform? </dt> <dd> <p>See the <a href="https://cloud.google.com/maps-platform/pricing/sheet/" class="external"> Pricing Sheet</a> for an overview of cost per API. If your application generates requests or map load volumes up to $200 per month usage, your usage is not charged. Usage that exceeds the $200 monthly credit will be charged to your billing account. For more details, see our <a href="/maps/billing/understanding-cost-of-use">guide to understanding Google Maps Platform billing</a>.</p> </dd> <dt id="usage_currencies"> Is pricing available in other currencies? </dt> <dd> <p> <a href="https://cloud.google.com/billing/docs/resources/currency" class="external">Additional currencies</a> may be available within the console. When you select a different currency, rates will convert from the USD equivalent listed on our <a href="https://cloud.google.com/maps-platform/pricing/sheet/" class="external">Pricing Sheet</a>. </p> </dd> <dt id="usage_viewbill"> I've set up billing. How do I view my bill? </dt> <dd> <p>Google charges you at the beginning of each month for the previous month's activity, using your <a href="https://support.google.com/cloud/answer/6158867" class="external"> specified payment method</a>. For details about your bill, see our <a href="/maps/billing/understanding-cost-of-use">guide to understanding Google Maps Platform billing</a>. </p> <p>Additional resources:</p> <ul> <li>Learn how to <a href="https://cloud.google.com/billing/docs/how-to/view-history" class="external"> view your cost and payment history</a>.</li> <li>Learn how to <a href="https://cloud.google.com/billing/docs/how-to/get-invoice" class="external"> get an invoice or payment receipt</a>.</li> <li>Learn how to <a href="https://cloud.google.com/billing/docs/how-to/budgets" class="external"> set and manage billing alerts</a>.</li> </ul> </dd> <a id="usage_cap_web"></a> <dt id="usage_cap"> How do I avoid a large bill if my usage unexpectedly increases? </dt> <dd> <p>The Google Maps Platform provides ways to set daily request limits and set maximum daily billable limits. You can cap the maximum daily limit on usage to protect against unexpected increases. You can also set budget alerts to receive email notifications when the charges on the billing account reach a threshold you set.</p> <p><strong>Capping the maximum daily billable limit:</strong></p> <p>To avoid a large bill, you can set a daily cap on usage to protect against unexpected increases in use. You can <a href="https://cloud.google.com/apis/docs/capping-api-usage" class="external">change this limit</a> in the Cloud console by taking the following steps:</p> <ol> <li>Go to the <a href="https://console.cloud.google.com/project/_/apiui/apis/enabled?utm_source=Docs_EnabledAPIsView" target="console" class="gc-analytics-event external" data-category="GMPMapsFAQ" data-action="linkClick: link" data-label="apiKeyRestrictions"> <strong>APIs &amp; Services Dashboard</strong></a>.</li> <li>Select a project if prompted.</li> <li>Select an API from the list, then click the <strong>Quotas</strong> tab.</li> <li>Click the <strong>edit icon</strong> next to the <strong>"requests per day"</strong> quota.</li> </ol> <p>Alternatively, you can edit multiple quotas for multiple APIs using the <a href="https://cloud.google.com/apis/docs/capping-api-usage#view_and_edit_all_quotas_for_apis_in_a_project" class="external"> IAM &amp; administrator Quotas dashboard</a>.</p> <aside class="key-point"><b>Tip:</b> Use an equation to determine your daily cap depending on how much you want to spend. For example: (Monthly spend / <a href="/maps/billing/understanding-cost-of-use#detailed-pricing-information-per-product-sku"> price per each</a>)/30 = requests per day cap (for one API). For example, on the Maps JavaScript API, 28,000 calls can be made per month within the no-charge tier. If you cap your Maps JavaScript API daily quota to 903 (ie 28,000 / 31), you won't be charged. Note that your implementation may use multiple billable APIs, so adjust your equation as needed. Remember, a <a href="/maps/billing/understanding-cost-of-use#billing-overview"> $200 USD Google Maps Platform credit</a> is available each month, so be sure to factor that into your calculation.</aside> <p><strong>Setting and managing budget alerts:</strong></p> <p><a href="https://cloud.google.com/billing/docs/how-to/budgets" class="external">Set up budget alerts</a> to send email notifications to billing administrators when the charges on the billing account reach a threshold you set. Billing administrators will be sent email notifications when the estimated charges on the billing account exceed 50%, 90%, and 100% of the threshold.</p> <aside class="key-point"><b>Key Point:</b> Setting a budget does <i>not</i> cap API usage. The purpose of budgets is to let you create alerts so that you know how your spending is trending over time. Alerts prompt you to take action to control your costs, but don't prevent the use of your services when the budget is met or exceeded. If you prefer to set a hard cap on API usage to prevent accruing costs, see <a href="https://cloud.google.com/apis/docs/capping-api-usage" class="external">Capping API Usage</a>.</aside> </dd> <a id="transition_account"></a> <dt>I got a message saying that my project is linked to the "Google Maps Platform Transition Account", but I don't have access to that account. What do I do?</dt> <dd> <p>The "Google Maps Platform Transition Account" was created to help certain customers transition to our new pay-as-you-go pricing plan. This transition account enabled Google to provide these customers with a one-time credit, so that they could continue using Google Maps Platform up to the limit of the $200 no-charge tier. Once this limit is exceeded, the billing account will shut down and you will lose access to the service. To avoid service interruptions, we urge you to set your own billing account, and continue to enjoy the $200 monthly no-charge tier. To change the billing account for your project:</p> <ol> <li><a href="https://cloud.google.com/billing/docs/how-to/manage-billing-account#create_a_new_billing_account" class="external"> Create a new billing account</a> (if you already have a billing account, you can skip this step).</li> <li><a href="https://cloud.google.com/billing/docs/how-to/modify-project#change_the_billing_account_for_a_project" class="external"> Associate the billing account with your project</a>.</li> </ol> </dd> <a id="limit_1"></a> <dt>Why is my quota limit set to 1 request per day? How can I raise this limit?</dt> <dd> <p>If you have not created and attached a billing account to your project, your Maps Platform APIs will be limited to 1 request per day. You can get higher quota by creating and attaching a billing account. To do this, see <a href="/maps/get-started">Get Started with Google Maps Platform</a>.</p> <p>Once you have created and attached a billing account, your daily quota limit will be removed. You can decide to <a href="/maps/faq#usage_cap">set a limit to prevent unexpected spend, in the Cloud console</a>.</p> </dd> <a id="billing-violation-notice"></a> <dt>I received a billing violation notice. How do I resolve this?</dt> <dd> <p>You have received this notice because Google has determined that your account has been using multiple billing accounts. This is a violation of Google's terms, as defined in <a href="/maps-platform/terms#3.-license-.">section 3.2.4 of the Google Maps Platform Terms of Service</a>. Under these terms, it is forbidden to create multiple billing accounts. To learn more, see the <a href="/maps/billing-account-violation">Billing Account Violation FAQ</a>.</p> </dd> </dl> <h2 id="using-google-maps-apis" data-text="Use the Google Maps Platform" tabindex="-1">Use the Google Maps Platform</h2> <dl> <dt id="keysystem">Which keys or credentials should I use for different Maps products?</dt> <dd> <p>Each time you use Google Maps Platform products, you must include an API key to validate your request. The Google Maps Platform is available for Android, iOS or Web apps, and for HTTP web services.</p> <p><strong>API Key:</strong></p> <ul> <li>An API key is a unique identifier that you generate using the <a href="https://cloud.google.com/docs/authentication/api-keys" class="external"> Cloud console</a>.</li> <li>Example of loading an API with a key: <code translate="no" dir="ltr">&amp;key=AIzaSyBjsINSH5x39Ks6c0_CoS1yr1Mb3cB3cVo</code></li> </ul> <p><strong>Digital Signature:</strong></p> <ul> <li> A digital signature is generated using a URL signing secret provided to you by Google. Digital signatures are used with the Maps Static API and Street View Static API.</li> </ul> <p><strong>Restrictions:</strong></p> <ul> <li>API key restrictions are optional, but we strongly recommend you restrict all API keys for greater security. See <a href="/maps/api-security-best-practices">API security best practices</a> for more details.</li> <li>You can add an application restriction to the API key. Once restricted, a key will only work on platforms that support that type of restriction. Four types of application restrictions are available. APIs enforcing the same restriction type can use the same restricted key. <ul> <li>IP addresses (individual servers) - for use with the <a href="/maps/apis-by-platform#web_service_apis">web service APIs</a>.</li> <li>HTTP referrers (websites) - for use with the <a href="/maps/apis-by-platform#web_apis/">web APIs</a>.</li> <li>Android app restriction (by package name and fingerprint) - for use with the <a href="/maps/documentation/android-sdk">Maps SDK for Android</a>.</li> <li>iOS app restriction (by iOS bundle identifier) - for use with the <a href="/maps/documentation/ios-sdk">Maps SDK for iOS</a>.</li> </ul> </li> <li>You can also add an API restriction to the API key. For more information, see <a href="/maps/get-started#api-key">Get, add, and restrict an API key</a>.</li> </ul> <p id="api-key-restrictions">The table below indicates the key/credential and application restriction for each Google Maps Platform API/SDK.</p> <table id="key-maps" class="maps-keys"> <tr> <th width="30%">API/SDK</th> <th width="40%">Credential & Application Restriction</th> </tr> <tr> <td><strong><a href="/maps/documentation/android-sdk"> Maps SDK for Android</a></strong></td> <td>API key with Android restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/places/android-sdk"> Places SDK for Android</a></strong></td> <td>API key with Android restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/navigation/android-sdk"> Navigation SDK for Android</a></strong></td> <td>API key with Android restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/ios-sdk"> Maps SDK for iOS</a></strong></td> <td>API key with iOS restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/places/ios-sdk"> Places SDK for iOS</a></strong></td> <td>API key with iOS restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/navigation/ios-sdk"> Navigation SDK for iOS</a></strong></td> <td>API key with iOS restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/javascript"> Maps JavaScript API</a></strong></td> <td>API key with HTTP referer restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/tile"> Map Tiles API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/datasets"> Maps Datasets API</a></strong></td> <td>OAuth token</td> </tr> <tr> <td><strong><a href="/maps/documentation/aerial-view"> Aerial View API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/maps-static"> Maps Static API</a></strong></td> <td>API key with HTTP referer restriction<a href="#restriction"><sup>1</sup></a> + Digital Signature<a href="#digsig"><sup>2</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/streetview"> Street View Static API</a></strong></td> <td>API key with HTTP referer restriction<a href="#restriction"><sup>1</sup></a> + Digital Signature<a href="#digsig"><sup>2</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/embed"> Maps Embed API</a></strong></td> <td>API key with HTTP referer restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/address-validation"> Address Validation API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/directions"> Directions API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/distance-matrix"> Distance Matrix API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/elevation"> Elevation API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/geocoding"> Geocoding API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/geolocation"> Geolocation API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/places/web-service"> Places API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/roads"> Roads API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/routes"> Routes API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/timezone"> Time Zone API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/air-quality"> Air Quality API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/pollen"> Pollen API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> <tr> <td><strong><a href="/maps/documentation/solar"> Solar API</a></strong></td> <td>API key with IP address restriction<a href="#restriction"><sup>1</sup></a></td> </tr> </table> <div style="font-size: 80%; margin-top: 1.2em;" id="restriction"><sup>1</sup> API key restrictions are optional, but we strongly recommend you restrict all API keys for greater security. </div> <div style="font-size: 80%; margin-top: 1.2em;" id="digsig"><sup>2</sup> Depending on usage, a digital signature may be required for the <a href="/maps/documentation/maps-static/digital-signature">Maps Static API</a> and <a href="/maps/documentation/streetview/digital-signature">Street View Static API</a>. Regardless of usage, we strongly recommend that you use both an API key and a digital signature to authenticate your requests. </div> </dd> <dt id="switch-key-type"> How do I switch my key restriction type from an HTTP referer to an IP address restriction? </dt> <dd> <p class="note"><strong>Important:</strong> If you are using any of the <a href="/maps/apis-by-platform#web_service_apis">web service APIs</a> with an API key that has referer restrictions, your requests will fail with the error message: "API keys cannot have referer restrictions when used with this API." You should switch to using an API key with IP address restrictions.</p> <p>Before you switch the API key restriction type from HTTP referer to IP address, ensure that all the APIs that use the API key support the IP restriction type. APIs of the same restriction type can use the same restricted key. If you need to enforce more than one restriction, add a separate key with the required restriction. See how to <a href="/maps/faq#new-key">add a new API key</a>.</p> <p>Learn more about <a href="#api-key-restrictions">API key restrictions associated with Google Maps Platform products</a>.</p> <p>To switch an API key with HTTP referer restriction to IP address restriction, do the following:</p> <ol> <li>Go to the <a href="https://console.cloud.google.com/project/_/google/maps-apis/credentials?utm_source=Docs_Credentials" target="console" class="gc-analytics-event external" data-category="GMPMapsFAQ" data-action="linkClick: link" data-label="apiKeyRestrictions">Credentials page</a> of the Cloud console.</li> <li>Select the project that contains the API key you want to edit.</li> <li>On the <strong>Credentials</strong> page, from the list of API keys, select the name of the API key to edit the details of the key.</li> <li>In the <strong>Key restriction</strong> section of the page, select "IP addresses (web servers, cron jobs, etc.)" and insert the appropriate server IP addresses, then click Save.</li> </ol> </dd> <dt id="new-key"> How do I get a new API key? </dt> <dd> See <a href="/maps/get-started">Get Started with Google Maps Platform</a>. </dd> <dt id="versionchanges"> How can I find the changes introduced in each version of the Google Maps APIs? </dt> <dd> <p> Version change information for many of the Maps APIs are available at the following links: </p> <ul> <li><a href="/maps/documentation/javascript/releases">Maps JavaScript API</a> </li> <li><a href="/maps/documentation/routes/release-notes">Routes API</a> </li> <li><a href="/maps/documentation/directions/releases">Directions API</a> </li> <li><a href="/maps/documentation/distance-matrix/releases">Distance Matrix API</a> </li> <li><a href="/maps/documentation/android-sdk/releases">Maps SDK for Android</a> </li> <li><a href="/maps/documentation/places/android-sdk/releases">Places SDK for Android</a> </li> <li><a href="/maps/documentation/navigation/android-sdk/release-notes">Navigation SDK for Android</a> </li> <li><a href="/maps/documentation/ios-sdk/releases">Maps SDK for iOS</a> </li> <li><a href="/maps/documentation/places/ios-sdk/releases">Places SDK for iOS</a> </li> <li><a href="/maps/documentation/navigation/ios-sdk/release-notes">Navigation SDK for iOS</a> </li> <li><a href="/maps/documentation/address-validation/release-notes">Address Validation API</a> </li> <li><a href="/maps/documentation/aerial-view/release-notes">Aerial View API</a> </li> <li><a href="/maps/documentation/air-quality/release-notes">Air Quality API</a> </li> <li><a href="/maps/documentation/pollen/release-notes">Pollen API</a> </li> <li><a href="/maps/documentation/solar/release-notes">Solar API</a> </li> <li><a href="/maps/documentation/tile/release-notes">Map Tiles API</a> </li> <li><a href="/maps/documentation/datasets/release-notes">Maps Datasets API</a> </li> </ul> <p> You can also check which version of the Google Maps Platform a particular bug was introduced and fixed in using the Google Maps Platform Issue Tracker at: </p> <p> <a href="https://issuetracker.google.com/bookmark-groups/76561" class="external"> https://issuetracker.google.com/bookmark-groups/76561</a> </p> </dd> <dt id="loadasync"> How can I load the API into a page asynchronously after the page has loaded? </dt> <dd> <p> Just specify the callback parameter when loading the API. More information and sample code can be found in the <a href="/maps/documentation/javascript/tutorial#Loading_the_Maps_API">Getting Started</a> chapter of the Maps JavaScript API documentation. </p> </dd> <dt id="languagesupport"> How can I get Google Maps Platform products to display in a language other than English? </dt> <dd> <p>By default the API will attempt to load the most appropriate language based on the users location or browser settings. Some APIs allow you to explicitly set a language when you make a request. More information on how to set the language is available in the documentation for each API:</p> <ul> <li><a href="/maps/documentation/javascript/localization">Maps JavaScript API</a></li> <li><a href="/maps/documentation/geocoding/requests-geocoding#language-param">Geocoding API</a></li> <li><a href="/maps/documentation/routes/understand-route-response#specifying_the_language_of_the_step_instructions">Routes API</a></li> <li><a href="/maps/documentation/directions/get-directions#language-param">Directions API</a></li> <li><a href="/maps/documentation/distance-matrix/distance-matrix#language-param">Distance Matrix API</a></li> <li><a href="/maps/documentation/places/web-service/search#language-param">Places API</a></li> <li><a href="/maps/documentation/maps-static/start#map-parameters">Maps Static API</a></li> </ul> <strong>Supported Languages:</strong> <p>Google often updates supported languages. This list may not be exhaustive and is subject to change.</p> <table> <thead> <th>Language Code</th> <th>Language</th> <th>Language Code</th> <th>Language</th> </thead> <tbody> <tr> <td>af</td> <td>Afrikaans</td> <td>ja</td> <td>Japanese</td> </tr> <tr> <td>sq</td> <td>Albanian</td> <td>kn</td> <td>Kannada</td> </tr> <tr> <td>am</td> <td>Amharic</td> <td>kk</td> <td>Kazakh</td> </tr> <tr> <td>ar</td> <td>Arabic</td> <td>km</td> <td>Khmer</td> </tr> <tr> <td>hy</td> <td>Armenian</td> <td>ko</td> <td>Korean</td> </tr> <tr> <td>az</td> <td>Azerbaijani</td> <td>ky</td> <td>Kyrgyz</td> </tr> <tr> <td>eu</td> <td>Basque</td> <td>lo</td> <td>Lao</td> </tr> <tr> <td>be</td> <td>Belarusian</td> <td>lv</td> <td>Latvian</td> </tr> <tr> <td>bn</td> <td>Bengali</td> <td>lt</td> <td>Lithuanian</td> </tr> <tr> <td>bs</td> <td>Bosnian</td> <td>mk</td> <td>Macedonian</td> </tr> <tr> <td>bg</td> <td>Bulgarian</td> <td>ms</td> <td>Malay</td> </tr> <tr> <td>my</td> <td>Burmese</td> <td>ml</td> <td>Malayalam</td> </tr> <tr> <td>ca</td> <td>Catalan</td> <td>mr</td> <td>Marathi</td> </tr> <tr> <td>zh</td> <td>Chinese</td> <td>mn</td> <td>Mongolian</td> </tr> <tr> <td>zh-CN</td> <td>Chinese (Simplified)</td> <td>ne</td> <td>Nepali</td> </tr> <tr> <td>zh-HK</td> <td>Chinese (Hong Kong)</td> <td>no</td> <td>Norwegian</td> </tr> <tr> <td>zh-TW</td> <td>Chinese (Traditional)</td> <td>pl</td> <td>Polish</td> </tr> <tr> <td>hr</td> <td>Croatian</td> <td>pt</td> <td>Portuguese</td> </tr> <tr> <td>cs</td> <td>Czech</td> <td>pt-BR</td> <td>Portuguese (Brazil)</td> </tr> <tr> <td>da</td> <td>Danish</td> <td>pt-PT</td> <td>Portuguese (Portugal)</td> </tr> <tr> <td>nl</td> <td>Dutch</td> <td>pa</td> <td>Punjabi</td> </tr> <tr> <td>en</td> <td>English</td> <td>ro</td> <td>Romanian</td> </tr> <tr> <td>en-AU</td> <td>English (Australian)</td> <td>ru</td> <td>Russian</td> </tr> <tr> <td>en-GB</td> <td>English (Great Britain)</td> <td>sr</td> <td>Serbian</td> </tr> <tr> <td>et</td> <td>Estonian</td> <td>si</td> <td>Sinhalese</td> </tr> <tr> <td>fa</td> <td>Farsi</td> <td>sk</td> <td>Slovak</td> </tr> <tr> <td>fi</td> <td>Finnish</td> <td>sl</td> <td>Slovenian</td> </tr> <tr> <td>fil</td> <td>Filipino</td> <td>es</td> <td>Spanish</td> </tr> <tr> <td>fr</td> <td>French</td> <td>es-419</td> <td>Spanish (Latin America)</td> </tr> <tr> <td>fr-CA</td> <td>French (Canada)</td> <td>sw</td> <td>Swahili</td> </tr> <tr> <td>gl</td> <td>Galician</td> <td>sv</td> <td>Swedish</td> </tr> <tr> <td>ka</td> <td>Georgian</td> <td>ta</td> <td>Tamil</td> </tr> <tr> <td>de</td> <td>German</td> <td>te</td> <td>Telugu</td> </tr> <tr> <td>el</td> <td>Greek</td> <td>th</td> <td>Thai</td> </tr> <tr> <td>gu</td> <td>Gujarati</td> <td>tr</td> <td>Turkish</td> </tr> <tr> <td>iw</td> <td>Hebrew</td> <td>uk</td> <td>Ukrainian</td> </tr> <tr> <td>hi</td> <td>Hindi</td> <td>ur</td> <td>Urdu</td> </tr> <tr> <td>hu</td> <td>Hungarian</td> <td>uz</td> <td>Uzbek</td> </tr> <tr> <td>is</td> <td>Icelandic</td> <td>vi</td> <td>Vietnamese</td> </tr> <tr> <td>id</td> <td>Indonesian</td> <td>zu</td> <td>Zulu</td> </tr> <tr> <td>it</td> <td>Italian</td> <td></td> <td></td> </tr> </tbody> </table> <p>You can see what the map will look like in any of the languages listed above in this <a href="/maps/documentation/javascript/demos/localization">sample application</a>. </p> </dd> <dt id="ssl"> Can the Google Maps Platform be accessed over SSL (HTTPS)? </dt> <dd> <p> The Maps JavaScript API, Maps Static API, and <a href="/maps/apis-by-platform#web_service_apis">Web Service APIs</a> can be accessed over secure (HTTPS) connections. See the documentation for the API concerned for information on how to access the API over SSL. </p> <p> Note that the Maps Static API does not support custom icon URLs that use HTTPS; the default icon will be displayed. </p> </dd> <dt id="reportissue"> How do I report a bug or request a new feature in the Google Maps Platform? </dt> <dd> <p> If you experience behavior that you believe may be a bug, begin by raising it in the <a href="/maps/support">relevant forum</a>. This will allow other developers to validate the bug, and rule out any potential issues with your code. </p> <p> If you wish to request a feature, also first raise it in the <a href="/maps/support">relevant forum</a> to confirm that a solution that meets your requirements is not already available. </p> <p> Once you have confirmed that you have identified a new bug, or that your requirements cannot be met by the existing functionality of the Google Maps Platform products, report your bug or feature request using the <a href="https://issuetracker.google.com/dashboard/76561" class="external">Google Maps Platform Issue Tracker</a>. </p> <p> Before adding a bug or feature request to the Issue Tracker ,be sure to check that the bug or feature concerned has not already been added. If it has, you can star the issue to register your interest and be notified of updates. </p> </dd> <dt id="api_cookies"> How do Google Maps Platform APIs use site cookies? </dt> <dd> <p>Maps SDK for Android and Maps SDK for iOS use cookies subject to Google's <a href="https://policies.google.com/privacy">Privacy Policy</a>, such as calculating daily and 7-day active users and service abuse prevention. These cookies are not associated with any signed-in Google Account and are not logged with the rest of the information collected from the API calls. </p> </dd> <dt id="morehelp"> I can't find the answer to my question. Who should I contact? </dt> <dd> <p>Google's Developer Relations team maintains a presence on <a href="http://stackoverflow.com/" class="external">Stack Overflow</a> &mdash; a collaboratively-edited question and answer site for programmers. It's a great place to ask technical questions about developing and maintaining Google Maps applications. More information about asking questions on Stack Overflow is available on the <a href="/maps/support">Support</a> page.</p> <p> For best results when requesting help, keep the following in mind: </p> <ul> <li> Search the current discussions. Chances are someone else has experienced a similar issue and found a fix. </li> <li> Submit a link to your site if possible. Only post code snippets if the code is not viewable online. </li> <li> Provide all relevant information including browser versions, errors, and all other facts that may be useful in troubleshooting this problem. </li> </ul> </dd> </dl> <h2 id="troubleshooting" data-text="Errors and troubleshooting" tabindex="-1">Errors and troubleshooting</h2> <dl> <dt id="errorcodes"> What does this error mean? </dt> <dd> <p> If you encounter an error while loading or running the Google Maps APIs, see the following links to find explanations for the error codes: </p> <ul> <li><a href="/maps/documentation/javascript/error-messages">Maps JavaScript API</a></li> <li><a href="/maps/documentation/maps-static/error-messages">Maps Static API</a></li> <li><a href="/maps/documentation/datasets/handle-errors">Maps Datasets API</a></li> <li><a href="/maps/documentation/streetview/error-messages">Street View Static API</a></li> <li><a href="/maps/documentation/embed/error-messages">Maps Embed API</a></li> <li><a href="/maps/documentation/javascript/elevation#ElevationStatus">Elevation API</a></li> <li><a href="/maps/documentation/geocoding/requests-geocoding#StatusCodes">Geocoding API</a></li> <li><a href="/maps/documentation/geolocation/overview#errors">Geolocation API</a></li> <li><a href="/maps/documentation/routes/handle-errors">Routes API</a></li> <li><a href="/maps/documentation/directions/get-directions#DirectionsResponses">Directions API</a></li> <li><a href="/maps/documentation/distance-matrix/distance-matrix#DistanceMatrixStatus">Distance Matrix API</a></li> <li><a href="/maps/documentation/roads/errors">Roads API</a></li> <li><a href="/maps/documentation/timezone/requests-timezone#TimeZoneResponse">Time Zone API</a></li> <li><a href="/maps/documentation/places/web-service/search#PlaceSearchStatusCodes">Places API</a></li> <li><a href="/maps/documentation/address-validation/requests-validate-address#error_handling">Address Validation API</a></li> </ul> </dd> <dt id="api-key-billing-errors"> My maps appear darker than usual. What's happening? </dt> <dd> <p>Under certain circumstances, a darkened map, or 'negative' Street View image, watermarked with the text "for development purposes only", may be displayed. This behavior typically indicates issues with either an API key or billing. To use Google Maps Platform products, you must have a billing account and all requests must include a valid API key. The following flow will help troubleshoot this:</p> <style> /* Make inner expandables indent in a cascade manner. */ .expandable-inner { margin-left: 2em; } </style> <section class="expandable"> <h4 class="showalways" id="are-you-using-an-api-key" data-text="Are you using an API key?" tabindex="-1">Are you using an API key?</h4> <section class="expandable expandable-inner"> <h4 class="showalways" id="im-not-sure.-how-can-i-check-if-i-am-using-an-api-key" data-text="I'm not sure. How can I check if I am using an API key?" tabindex="-1">I'm not sure. How can I check if I am using an API key?</h4> <p>An API key is passed as the <code translate="no" dir="ltr">key</code> parameter in the URL that is used to load the Maps JavaScript API. Here are a few options to check if you are using an API key:</p> <ul> <li> Use the <a href="https://chrome.google.com/webstore/detail/google-maps-platform-api/mlikepnkghhlnkgeejmlkfeheihlehne" class="external"> Google Maps Platform API Checker</a> Chrome extension. This allows you to determine if your website is properly implementing Google’s licensed Maps APIs. </li> <li>If you are using a library or plugin to load the Maps JavaScript API, check the settings for that library and look for an API key option.</li> <li>Check <a href="/maps/documentation/javascript/error-messages#checking-errors">errors in your browser</a>. If you see the following messages, you are not using your API key correctly:</li> <ul> <li>Google Maps JavaScript API warning: <a href="/maps/documentation/javascript/error-messages#no-api-keys">NoApiKeys</a></li> <li>Google Maps JavaScript API error: <a href="/maps/documentation/javascript/error-messages#missing-key-map-error">MissingKeyMapError</a></li> </ul> </ul> <h4 id="for-web-developers:" data-text="For web developers:" tabindex="-1">For web developers:</h4> <ul> <li> If you have access to the source code of your application, look for the <code translate="no" dir="ltr">&lt;script&gt;</code> tag which is used to load the Maps JavaScript API. When loading the Maps JavaScript API, substitute <code translate="no" dir="ltr">YOUR_API_KEY</code> in the code below with your API key. <!-- Don't indent here to avoid actual content indenting. --> <div></div><devsite-code><pre class="devsite-click-to-copy notranslate" id="api-code" dir="ltr" is-upgraded syntax="HTML"> &lt;script async defer src="https://maps.googleapis.com/maps/api/js?key=<span data-devsite-credential-type="api_key" class="replaceable-credential">YOUR_API_KEY</span>&amp;callback=initMap"&gt; &lt;/script&gt;</pre></devsite-code> </li> <li> Check the network traffic generated by your website in the browser. In Chrome, this can be viewed using the <a href="/web/tools/chrome-devtools" class="external">DevTools</a> <strong>Network</strong> tab. Here you will see the network requests made by your website. Requests made using the Maps JavaScript API will be under the path <code translate="no" dir="ltr">maps/api/js</code>. Here you can confirm if the requests are using the <code translate="no" dir="ltr">key</code> parameter. It may be helpful to <a href="/web/tools/chrome-devtools/console#filtering_the_console_output"> filter your network traffic</a> by <code translate="no" dir="ltr">maps/api/js</code> when viewing the <strong>Network</strong> tab. </li> </ul> </section> <section class="expandable expandable-inner"> <h4 class="showalways" id="no,-i-am-not-using-an-api-key." data-text="No, I am not using an API key." tabindex="-1">No, I am not using an API key.</h4> <p>To get an API key, click the button below. If you do not see a guided setup, follow the full instructions at <a href="/maps/get-started#procedures">Get Started with Google Maps Platform</a>. <br /> <a href="/maps/get-started" class="gc-analytics-event button button-blue" data-category="GMPgetStartedPage" data-label="api-key-and-billing-errors-no-key" data-action="buttonClick: get-started" target="_blank">Get Started</a> </p> </section> <section class="expandable expandable-inner"> <h4 class="showalways" id="yes,-i-am-using-an-api-key." data-text="Yes, I am using an API key." tabindex="-1">Yes, I am using an API key.</h4> <p>Great! Let’s move on and check if a billing account is attached to your project.</p> </section> </section> <section class="expandable"> <h4 class="showalways" id="is-a-billing-account-attached-to-your-project" data-text="Is a billing account attached to your project?" tabindex="-1">Is a billing account attached to your project?</h4> <section class="expandable expandable-inner"> <h4 class="showalways" id="im-not-sure.-how-can-i-check-if-billing-account-is-attached-to-my-project" data-text="I'm not sure. How can I check if billing account is attached to my project?" tabindex="-1">I'm not sure. How can I check if billing account is attached to my project?</h4> <p>Go to the <a href="https://console.cloud.google.com/project/_/billing/enable?utm_source=Docs_BillingNudge" class="gc-analytics-event external" data-category="GMPBillingTroubleshoot" data-action="linkClick: link" data-label="isBillingAttachedToProject"> Billing page</a> in the Google Cloud console and select the project under which your API key was created. To confirm the key is associated with the project:</p> <ol> <li>Go to the <strong>Credentials</strong> section, which can be accessed from the left side bar under <strong>Google Maps Platform &gt; Credentials</strong>.</li> <li>Check that the API key you currently use on your website is listed. If that's not the case, switch to a different project, and check the credentials there.</li> <li>If you cannot locate the project for your API key, you may have lost access to this project. Ask others in your organization for help. If the original project cannot be located, you should: <ol> <li> Create a new project. This can be done by selecting <strong>New Project</strong> from the projects list, or by selecting <strong>Create Project</strong> via the <a href="https://console.cloud.google.com/cloud-resource-manager" class="gc-analytics-event external" data-category="GMPBillingTroubleshoot" data-action="linkClick: link" data-label="ResourceManagerPg">Resource Manager page</a>. </li> <li>Create a new API key. This can be done on the <strong>Credentials</strong> page. Once there click <strong>Create credentials</strong> and then select <strong>API key</strong>.</li> </ol> </ol> <p> Once you have located your project in the Cloud console, check if a billing account is attached by navigating to the <a href="https://console.cloud.google.com/project/_/billing" class="gc-analytics-event external" data-category="GMPBillingTroubleshoot" data-action="linkClick: link" data-label="isBillingAttachedToProject2">Billing</a> section in the left side menu. </p> </section> <section class="expandable expandable-inner"> <h4 class="showalways" id="no,-a-billing-account-is-not-attached-to-my-project." data-text="No, a billing account is not attached to my project." tabindex="-1">No, a billing account is not attached to my project.</h4> <p>Go to the <a href="https://console.cloud.google.com/project/_/billing/enable?utm_source=Docs_BillingNudge" class="gc-analytics-event external" data-category="GMPBillingTroubleshoot" data-action="linkClick: link" data-label="noBillingAcctOnProject">Enable Billing</a> page in the Cloud console and add a billing account to your project. For additional information, see <a href="/maps/get-started">Get Started with Google Maps Platform</a>.</p> </section> <section class="expandable expandable-inner"> <h4 class="showalways" id="yes,-a-billing-account-is-attached-to-my-project." data-text="Yes, a billing account is attached to my project." tabindex="-1">Yes, a billing account is attached to my project.</h4> <p>Great! Let’s make sure the provided billing method is valid.</p> </section> </section> <section class="expandable"> <h4 class="showalways" id="is-the-provided-billing-method-no-longer-valid-for-example-an-expired-credit-card" data-text="Is the provided billing method no longer valid (for example an expired credit card)?" tabindex="-1">Is the provided billing method no longer valid (for example an expired credit card)?</h4> <p>You <a href="https://cloud.google.com/billing/docs/how-to/payment-methods" class="external"> can add, remove, or update a payment method</a> in the Cloud console.</p> </section> <section class="expandable"> <h4 class="showalways" id="is-there-an-exceeded-self-imposed-daily-limit-on-the-api" data-text="Is there an exceeded self-imposed daily limit on the API?" tabindex="-1">Is there an exceeded self-imposed daily limit on the API?</h4> <p>If you have set a daily limit on any of your APIs, which is common to prevent unexpected increases, you can resolve this by <a href="/maps/faq#usage_cap">increasing your daily limit</a>.</p> <p>You can check your daily limits by going to the <a href="https://console.cloud.google.com/project/_/apiui/apis/enabled?utm_source=Docs_EnabledAPIsView" class="gc-analytics-event external" data-category="GMPBillingTroubleshoot" data-action="linkClick: link" data-label="dailyLimit">APIs &amp; Services Dashboard</a> in the Cloud console. Once there:</p> <ol> <li>Select a project if prompted.</li> <li>Select an API from the list, then click the <strong>Quotas</strong> tab.</li> </ol> </section> <section class="expandable"> <h4 class="showalways" id="does-your-api-key-have-an-ip-addresses-restriction" data-text="Does your API key have an IP addresses restriction?" tabindex="-1">Does your API key have an IP addresses restriction?</h4> <p>API keys with an <strong>IP addresses</strong> restriction can only be used with web services that are intended for use from the server side (such as the <a href="/maps/documentation/geocoding/start">Geocoding API</a> and other <a href="/maps/apis-by-platform">Web Service APIs</a>). Most of these web services have equivalent services within the Maps JavaScript API (for example, see the <a href="/maps/documentation/javascript/geocoding">Geocoding Service</a>). To use the Maps JavaScript API client side services, you will need to create a separate API key which can be secured with an <strong>HTTP referrers</strong> restriction (see <a href="/maps/get-started#api-key" class="gc-analytics-event" data-category="maps-apis" data-label="api-key-and-billing-errors-restrictions" data-action="linkClick">Get, add, and restrict an API key</a>). </p> </section> <br/> </dd> <dt id="over-limit-key-error"> How do I resolve the error codes: <code translate="no" dir="ltr">OVER_DAILY_LIMIT</code> or <code translate="no" dir="ltr">OVER_QUERY_LIMIT</code>? </dt> <dd> These error codes can be returned for any of the following reasons: <ul> <li>An API key is missing from the request.</li> <li>The provided API key is invalid.</li> <li>The project does not have a billing account attached.</li> <li>A self-imposed <a href="#usage_cap">usage cap</a> has been exceeded.</li> <li>The provided method of payment is no longer valid (for example, a credit card has expired).</li> <li>You have <a href="#usage_exceed">exceeded the quota limits</a> for a given API.</li> </ul> <p>To use Google Maps Platform products, you must have a billing account, and all requests must include a valid API key. To fix this, take the following steps:</p> <ul> <li><a href="#setup_billing">Set up a billing account</a>.</li> <li><a href="#new-key">Get a new API key</a>.</li> <li><a href="https://cloud.google.com/apis/docs/capping-api-usage" class="external">Adjust your usage cap</a> to increase your daily limit (if applicable).</li> </ul> </dd> <dt id="rate-limit-exceeded-error"> How do I resolve the error codes: <code translate="no" dir="ltr">kGMSPlacesRateLimitExceeded</code> or <code translate="no" dir="ltr">9005 PLACES_API_RATE_LIMIT_EXCEEDED</code>? </dt> <dd> If you are seeing <code translate="no" dir="ltr">kGMSPlacesRateLimitExceeded</code> or <code translate="no" dir="ltr">9005 PLACES_API_RATE_LIMIT_EXCEEDED</code>, you may be using a deprecated version of the Places SDK for Android or Places SDK for iOS. Learn more and find the new SDKs at <a href="https://goo.gle/places-sdk-deprecation" class="external">https://goo.gle/places-sdk-deprecation</a>. </dd> <dt id="api-key-error"> How do I resolve the error: "This IP, site or mobile application is not authorized to use this API key."? </dt> <dd> <p>There are various scenarios which may cause this error:</p> <ul> <li>You've enabled IP address (server) restrictions on your API key, and an unauthorized IP address is attempting a request.</li> <li>You've enabled HTTP referrer (website) restrictions on your API key, and an unauthorized referrer is attempting a request.</li> <li>You've restricted usage to your Android apps by setting a package name and fingerprint, and an unauthorized Android app is attempting a request.</li> <li>You've restricted requests from iOS apps by specifying bundle identifiers and an unrecognized iOS app is attemting to send a request.</li> <li>It used to be possible to get this error if you used any of the <a href="/maps/apis-by-platform#web_service_apis">web service APIs</a>, with an API key with HTTP referer restrictions. Requests to those APIs should be identified with an API key with <strong>IP address</strong> restrictions. <a href="#switch-key-type">Switch your key restriction type from an HTTP referer restriction to an IP address restriction</a>. For more information about restricting API keys, see <a href="/maps/api-key-best-practices">API Key Best Practices</a>.</li> </ul> <p><strong>View and Edit your API Key Credentials</strong></p> <p>To view your API keys and manage any restrictions, do the following:</p> <ol> <li>Go to the <a href="https://console.cloud.google.com/project/_/google/maps-apis/credentials?utm_source=Docs_Credentials" target="console" class="gc-analytics-event external" data-category="GMPMapsFAQ" data-action="linkClick: link" data-label="viewEditAPICredentials">Credentials page</a> of the Cloud console.</li> <li>Select the project that contains the API key you want to review.</li> <li>To view credential details, including any restrictions set for the key, from the list of API keys, click the name of the key.</li> <li>The full credentials of the selected API key are displayed, including any restrictions set up for the key. From here, the restrictions can be changed, deleted, or updated as needed.</li> </ol> </dd> <dt id="browser-keys-blocked-error"> How do I resolve the error: "API keys with referer restrictions cannot be used with this API."? </dt> <dd> <p>You are using any of the <a href="/maps/apis-by-platform#web_service_apis">web service APIs</a> with an API key restricted to an HTTP referer. For security reasons, web service APIs need to use API keys restricted to <strong>IP addresses</strong>. <a href="#switch-key-type">Switch your key restriction type from an HTTP referer restriction to an IP address restriction</a>, or create a new API key if your key is already used with the Maps JavaScript API.</p> </dd> </dl> <h2 id="google-maps-api-services" data-text="Google Maps Platform Services" tabindex="-1">Google Maps Platform Services</h2> <dl> <dt id="geocoder_exists"> I need to convert addresses to latitude/longitude pairs. Can I do that with the Google Maps Platform? </dt> <dd> <p> Yes, this process is called "geocoding." The Maps JavaScript API includes a class for performing a geocoding service. The class is: <a href="/maps/documentation/javascript/geocoding">google.maps.Geocoder</a>. </p> <p> Alternatively, Google also provides the <a href="/maps/documentation/geocoding"> Geocoding API</a>, which offers a REST interface that can respond in JSON and XML formats. </p> </dd> <dt id="geocoder_countries"> Which countries is geocoding available in? </dt> <dd> <p> To see countries currently supported by the Google Maps Platform geocoders, please consult the <a href="/maps/coverage">Google Maps coverage data</a>. </p> <p> The accuracy of geocoded locations may vary per country, so you should consider using the returned <a href="/maps/documentation/javascript/reference#GeocoderGeometry"> location_type</a> field to determine if a good enough match has been found for the purposes of your application. The availability of geocoding data depends on our contracts with data providers, so it is subject to change. </p> </dd> <dt id="geocoder_differences"> Why do the Google Maps Platform Geocoders provide different locations than Google Maps? </dt> <dd> <p> The API geocoder and Google Maps geocoder sometimes use different data sets (depending on the country). The API geocoder occasionally gets updated with new data, so you can expect to see results changing or improving over time. </p> </dd> <dt id="geocoder_queryformat"> How should I format my geocoder queries to maximise the number of successful requests? </dt> <dd> <p> The geocoder is designed to map street addresses to geographical coordinates. We therefore recommend that you format geocoder requests in accordance with the following guidelines to maximize the likelihood of a successful query: </p> <ul> <li> Specify addresses in accordance with the format used by the national postal service of the country concerned. </li> <li> don't specify additional address elements such as business names, unit numbers, floor numbers, or suite numbers that are not included in the address as defined by the postal service of the country concerned. Doing so may result in responses with <code translate="no" dir="ltr">ZERO_RESULTS</code>. </li> <li> Format plus codes as shown here (plus signs are url-escaped to <code translate="no" dir="ltr">%2B</code> and spaces are url-escaped to <code translate="no" dir="ltr">%20</code>): <ul> <li><b>global code</b> is a 4 character area code and 6 character or longer local code (849VCWC8+R9 is <code translate="no" dir="ltr">849VCWC8%2BR9</code>).</li> <li><b>compound code</b> is a 6 character or longer local code with an explicit location (CWC8+R9 Mountain View, CA, USA is <code translate="no" dir="ltr">CWC8%2BR9%20Mountain%20View%20CA%20USA</code>).</li> </ul> </li> <li> Use the street number of a premise in preference to the building name where possible. </li> <li> Use street number addressing in preference to specifying cross streets where possible. </li> <li> don't provide 'hints' such as nearby landmarks. </li> </ul> </dd> <dt id="geocoder_highways"> How should I format a US address on a numbered highway for geocoding? </dt> <dd> <p> The Google Maps Platform geocoder requires that US numbered highways be specified in addresses as follows:</p> <ul> <li> <b>County Roads:</b> <code translate="no" dir="ltr">"Co Road <i>NNN</i>"</code> where <i>NNN</i> is the road number. eg. <code translate="no" dir="ltr">"Co Road 82"</code> </li> <li> <b>State Highways:</b> <code translate="no" dir="ltr">"<i>State NNN</i>"</code> where <i>State</i> is the full name of the state and <i>NNN</i> is the highway number. eg. <code translate="no" dir="ltr">"California 82"</code> </li> <li> <b>US Highways:</b> <code translate="no" dir="ltr">"US <i>NNN</i>"</code> where <i>NNN</i> is the highway number. eg. <code translate="no" dir="ltr">"US 101"</code> </li> <li> <b>US Interstates:</b> <code translate="no" dir="ltr">"Interstate <i>NNN</i>"</code> where <i>NNN</i> is the interstate number. eg. <code translate="no" dir="ltr">"Interstate 280"</code> </li> </ul> </dd> <dt id="geocoder_classorhttp"> When should I use an API geocoder class and when should I use the HTTP Geocoding Service? </dt> <dd> <p> See the document: <a href="/maps/documentation/geocoding/geocoding-strategies">Geocoding Strategies</a>, which details the advantages and limitations of different geocoding strategies. </p> </dd> <dt id="directions_exists"> How do I provide driving directions with the Google Maps Platform? </dt> <dd> <p>The <a href="/maps/documentation/routes/compute_route_directions">Compute Routes service</a> of the <a href="/maps/documentation/routes">Routes API</a> and the <a href="/maps/documentation/directions">Directions API</a> let you provide driving directions for single and multi-leg journeys. Routing options help you shape directions with a travel mode (driving), a single or a set of routes, and restrictions (no toll roads). These services are available in the following forms:</p> <ul> <li><strong>HTTP request/response interface</strong> (used in mobile and other applications) is compatible with Maps SDK for Android and with other Google Maps web services. </li> <li><strong>JavaScript API</strong>, for client-side applications, lets you provide driving directions using the <a href="/maps/documentation/javascript/reference#DirectionsService"> google.maps.DirectionsService</a> class. The <a href="/maps/documentation/javascript/reference#DirectionsRenderer">DirectionsRenderer</a> class can automatically create the overlays and directions panel for you. <a href="/maps/documentation/javascript/directions"> Additional examples</a> are provided in the documentation. </li> <li><strong>Java, Python, go, and Node.js client interfaces</strong>, for server-side applications, provide the same functionality. For more information on client libraries, see <a href="/maps/documentation/directions/client-library">Directions API client libraries</a>.</li> </ul> </dd> <dt id="directions_countries"> In which countries are driving directions available? </dt> <dd> <p> To see countries supported by driving directions in the Google Maps Platform products, consult the <a href="/maps/coverage">Google Maps coverage data</a>. The availability of driving directions data depends on our contracts with data providers, and is subject to change. </p> </dd> <dt id="transit_directions_countries"> In which countries are transit directions available? </dt> <dd> <p>The <a href="/maps/documentation/routes">Routes API</a>, <a href="/maps/documentation/directions">Directions API</a> and <a href="/maps/documentation/distance-matrix">Distance Matrix API</a> support all <a href="https://developers.google.com/transit" class="external">Google Transit partners</a>, except the Indian Railway Catering and Tourism Corporation and those in Japan. </p> </dd> <dt id="geoxmlsupport"> Which KML and GeoRSS features are supported in the Maps JavaScript API? </dt> <dd> <p>The <a href="/maps/documentation/javascript/reference#KmlLayer">KmlLayer</a> class in the Maps JavaScript API enables developers to overlay KML/KMZ and GeoRSS files on top of the map. For documentation and examples, see <a href="/maps/documentation/javascript/kmllayer">KmlLayer class</a>. </p> </dd> <dt id="geoxmllimits"> What are the limits on the size and complexity of KML that can be displayed using the KmlLayer class of the Maps JavaScript API? </dt> <dd> <p> The size and complexity limits on the display of KML using the <code translate="no" dir="ltr">KmlLayer</code> class are documented <a href="/maps/documentation/javascript/kmllayer#overview">KmlLayer overview</a>. </p> </dd> <dl> <dt id="intranet_kml">How do I render KML files that are hosted on intranet sites on a map?</dt> <dd> <p>The <a href="/maps/documentation/javascript/reference#KmlLayer"> <code translate="no" dir="ltr">KmlLayer</code></a> class that generates KML overlays in the Maps JavaScript API uses a Google hosted service to retrieve and parse KML files for rendering. Consequently it is not possible to display KML files that are not hosted at a URL that is available publicly accessible, or that require authentication to access.</p> <p>If you need to develop applications that use KML files hosted on intranet sites we recommend that you render the KML on the client side by using third-party JavaScript libraries. As the KML file is analyzed by the browser, performance may be lower than by using the <code translate="no" dir="ltr">KmlLayer</code> class.</p> </dd> </dl> <dt id="staticmap_limits">What is the maximum number of markers or path vertices supported by the Maps Static API? </dt> <dd> <p>There is no limit to the number of markers or path vertices supported by the Maps Static API. When using custom icons, up to five unique icons can be specified per request, but each can be used multiple times within the map.</p> <p>Note that Maps Static API URLs can contain a maximum of approximately 8,192 characters which constrains the number of markers and path vertices that can be specified based on the number of decimal places used when specifying each latitude/longitude pair. For information on how the number of decimal places used relates to the accuracy on the Earth see the Wikipedia article on <a href="http://en.wikipedia.org/wiki/Decimal_degrees" class="external"> Decimal Degrees</a>.</p> </dd> <dt id="prohibited_territories_ws_access">Why can't I access Google Maps Platform products for certain countries?</dt> <dd> <p>Maps APIs may not be used in <a href="https://cloud.google.com/maps-platform/terms/maps-prohibited-territories" class="external">Prohibited Territories</a>. Refer also to the <a href="https://cloud.google.com/maps-platform/terms#3.-license." class="external">Terms of Service</a>.</p> </dd> <dt id="data-issues">How do I report a problem on the Google basemap?</dt> <dd> <a href="https://support.google.com/maps/answer/3094045" class="external">Send feedback</a> through Google Maps for wrong or missing map information such as: <ul> <li>Wrong addresses or marker locations</li> <li>Incorrect road names</li> <li>Wrong information about one-way and two-way roads</li> <li>Incorrectly drawn road</li> <li>Closed roads</li> <li>Roads that don't exist</li> </ul> <p>For correction of a place or business listing, <a href="https://support.google.com/maps/answer/7084895" class="external">suggest an edit</a>.</p> <p>If Maps content needs to be removed for legal reasons, submit a <a href="https://support.google.com/legal/troubleshooter/1114905#ts=9723198" class="external">legal request.</a></p> <p class="note">For critical or time-sensitive requests, file a <a href="/maps/support#creating-a-support-case">support case</a> with specific details on what needs to be fixed.</p> </dd> </dl> <dt id="uptime_slo">How is performance monitored for the services used with Maps JavaScript API?</dt> <dd> <p>Some client-side features are instrumented to report success or failure for the purpose of calculating the SLO (Service Level Objective). This information is sent to Google at <code translate="no" dir="ltr">maps.googleapis.com/maps_api_js_slo/log</code> in calls that log SLO information. This information includes success status, latency, and version/channel of the Maps JavaScript API in use. The calls may be batched for performance. You may need to allow <code translate="no" dir="ltr">maps.googleapis.com</code> in your <a href="/maps/documentation/javascript/content-security-policy">Content Security Policy</a> to ensure these calls are not blocked at browser-level. For example: <code translate="no" dir="ltr">Content-Security-Policy: default-src 'self' maps.googleapis.com;</code> with HTTP headers, or <code translate="no" dir="ltr">&lt;meta http-equiv="Content-Security-Policy" content="default-src 'self' maps.googleapis.com;"&gt;</code> with HTML Meta Tags. </p> </dd> <h2 id="javascript-api" data-text="Maps JavaScript API" tabindex="-1">Maps JavaScript API</h2> <dl> <dt id="jsrefresh">How long will the Maps JavaScript API work after it has been loaded?</dt> <dd> <p>You need to refresh the page that loads the Maps JavaScript API at least once every 5 days.</p> </dd> </dl> <h2 id="maps-sdk-ios" data-text="Google Maps SDK for iOS" tabindex="-1">Google Maps SDK for iOS</h2> <dl> <dt id="rate-limit-error-ios"> How do I resolve the error: <code translate="no" dir="ltr">kGMSPlacesRateLimitExceeded</code>? </dt> <dd> If you are seeing this error, you may be using a deprecated version of the Places SDK for iOS. Version 2.7.0 of the Places SDK for iOS has been turned off, and is no longer available. Update your app to use the latest version as soon as possible. See the <a href="/maps/documentation/places/ios-sdk/client-migration">migration guide</a> for details. </dd> <dt id="ios8-debug"> I'm getting crashes when debugging with an iOS 8.x device. What should I do? </dt> <dd> <p>If you experience issues when debugging with devices running iOS 8.x, follow these steps to disable GPU frame capture in the XCode scheme you are running:</p> <ol> <li>In XCode, choose <b>Product</b>, <b>Scheme</b>, <b>Manage Schemes</b>.</li> <li>Select a scheme and choose <b>Edit...</b>.</li> <li>Set the <b>GPU Frame Capture</b> option to <b>Disabled</b>. Note that this option may not be present for all devices.</li> </ol> <img src="/static/maps/images/GPU-frame-option.png" alt="Xcode GPU Frame Capture option on the Generic iOS device page"> </dd> <dt id="iphone-x">What's the impact of rounded and wider screens on the Google Maps iOS SDK?</dt> <dd> <p>Beginning with the <a href="https://www.apple.com/iphone-x/" class="external">iPhone X</a>, iPhones have a screen shape featuring rounded corners, a notch at the top for the device's sensor housing, and an indicator at the bottom of the screen for accessing the Home screen. As of iOS 11.0 SDK, Apple added the <a href="https://developer.apple.com/documentation/uikit/uiview/positioning_content_relative_to_the_safe_area" class="external">Safe Area API</a> allowing developers to position elements in an area which is safe from being clipped by the new screen shape.</p> <p>The Google Maps iOS SDK has many visual elements and controls, such as an indoor picker and the report a problem link. With version 2.4, these visual elements and controls could be clipped by the new screen shape. In landscape mode, the indoor floor picker may be clipped by either the notch or the home button indicator. </p> <p>With the Google Maps iOS SDK 2.5 release these layout issues are fixed automatically. When your app is used on an iPhone X or later, the padding on <a href="/maps/documentation/ios- sdk/reference/interface_g_m_s_map_view">GMSMapView</a> and <a href="/maps/documentation/ios- sdk/reference/interface_g_m_s_panorama_view">GMSPanoramaView</a> are increased so that the visual elements aren't clipped.</p> <p>By default, we will always include your padding. The Google Maps iOS SDK assumes that padding is intended to pad from within the safe area. If you design your interface with the assumption that everything is positioned within the safe area, this will work without any extra effort.</p> <p>If you have designed an interface which doesn't work with our default adjustment, we have introduced a new property to GMSMapView, called <a href="/maps/documentation/ios- sdk/reference/interface_g_m_s_map_view#a426424d1b8b139a7fde2681790a657ad"> paddingAdjustmentBehavior</a>. GMSMapView now allows you to pick from one of three padding adjustments behaviors: 'Always' (default), 'Automatic', and 'Never'.</p> <p>If GMSMapView is set to use the 'Always' padding behavior, it will always add the safe area insets to the padding. This setting lets you design your interface with the assumption that all placement is from the edges of the safe area. This is the default value.</p> <p>If GMSMapView is set to use the 'Automatic' padding behavior, it will always choose the larger of padding or safe area inset. This setting lets you add padding from the screen edge while always ensuring that all elements stay within the safe area.</p> <p>If GMSMapView is set to use the 'Never' padding behavior, it will never add the safe area insets to the padding. This is the behavior prior to the 2.5 release and may be useful if your padding already takes into consideration the safe area, or if our other behaviors don't act well with your interface. It is your responsibility to ensure that the Google logo and copyright notices are always visible, as specified in the <a href="https://cloud.google.com/maps-platform/terms" class="external">Google Maps Platform Terms of Service</a>. </p> <p>In contrast, GMSPanoramaView doesn't have an optional padding property. This means that there is no padding to adjust and GMSPanoramaView will always apply any necessary padding to ensure that all visual elements are within the safe area.</p> </dd> </dl> <h2 id="maps-sdk-android" data-text="Google Maps SDK for Android" tabindex="-1">Google Maps SDK for Android</h2> <dl> <dt id="9005-error-android"> How do I resolve the error: <code translate="no" dir="ltr">9005 PLACES_API_RATE_LIMIT_EXCEEDED</code>? </dt> <dd> If you are seeing this error, you may be using a deprecated version of the Places SDK for Android. The Google Play services version of the Places SDK for Android has been turned off, and is no longer available. Update your app to use the latest version as soon as possible. See the <a href="/maps/documentation/places/android-sdk/client-migration">migration guide</a> for details. </dd> </dl> <dl> <dt id="android-grey-tiles"> My app only shows blank grey tiles instead of a map. How can I resolve this? </dt> <dd> <p> A common reason that a blank grey tiles are shown instead of a map is authentication issues. You can follow the steps below to troubleshoot those issues by using adb logcat. </p> <ol> <li>Make sure you have adb installed. If not, you can follow the guide <a href="https://developer.android.com/studio/command-line/adb">Android adb guide</a>.</li> <li>Install the app that shows the problem on a device or an Android emulator. If you use Android emulator, make sure the emulator settings has Play Store included.</li> <li>In Android Studio terminal, run <code translate="no" dir="ltr">adb logcat -e "Google Maps Android API"</code>. This will only print lines where the log message matches "Google Maps Android API" (Optionally, you can output the log to a text file by appending: > logcat.txt)</li> <li>Reproduce the issue on your device and check for common errors such as:</li> <ul> <li>The wrong/unintended API Key is being referenced in Manifest.</li> <li>Billing isn't enabled on Project.</li> <li>The SDK isn't enabled on project APIs.</li> <li>The incorrect SHA-1 fingerprint is added to the API Key restrictions.</li> <li>The <a href="https://developers.google.com/android/guides/setup#add_google_play_services_to_your_project">Google Play Service dependencies</a> is not included in the <code translate="no" dir="ltr"> build.gradle</code> file.</li> </ul> </ol> </dd> </dl> <h2 id="url_signing2" data-text="URL signing" tabindex="-1">URL signing</h2> <dl> <dt id="signature_js">Can I sign URLs using JavaScript?</dt> <dd> <p>We strongly recommend against signing URLs using JavaScript as this would expose your URL signing secret to end users. Therefore signatures should only be generated by server side components.</p> </dd> <dt id="signature_403">Why am I receiving a HTTP 403 Forbidden response to my Maps API web service requests?</dt> <dd> <p>An HTTP 403 response indicates a permission issue, likely because the signature couldn't be verified for this request. This could be because:</p> <ol style="list-style-type: lower-alpha"> <li>A signature has been specified but is incorrect for this request.</li> <li>The request specifies a Google Maps Platform Premium Plan an API key but does not specify a signature, and the service being called requires that requests made using an API key include a valid signature.</li> <li>A signature has been specified but the associated Google Maps Platform Premium Plan API key has not been specified.</li> </ol> </dd> </dl> <devsite-hats-survey class="nocontent" hats-id="XkBWMmMFw0ji3Z11gVm0WEFX1sxN" listnr-id="5133444"></devsite-hats-survey> </div> <devsite-recommendations display="in-page" hidden yield> </devsite-recommendations> <devsite-thumb-rating position="footer"> </devsite-thumb-rating> <devsite-feedback position="footer" project-name="Google Maps Platform" product-id="81777" bucket="" context="Maps API Product Family" version="t-devsite-webserver-20250211-r00-rc00.466928320959134316" data-label="Send Feedback Button" track-type="feedback" track-name="sendFeedbackLink" track-metadata-position="footer" class="nocontent" project-icon="https://developers.google.com/static/maps/images/maps-icon.svg" > <button> Send feedback </button> </devsite-feedback> <devsite-recommendations id="recommendations-link" yield></devsite-recommendations> <div class="devsite-floating-action-buttons"> </div> </article> <devsite-content-footer class="nocontent"> <p>Except as otherwise noted, the content of this page is licensed under the <a href="https://creativecommons.org/licenses/by/4.0/">Creative Commons Attribution 4.0 License</a>, and code samples are licensed under the <a href="https://www.apache.org/licenses/LICENSE-2.0">Apache 2.0 License</a>. For details, see the <a href="https://developers.google.com/site-policies">Google Developers Site Policies</a>. Java is a registered trademark of Oracle and/or its affiliates.</p> <p>Last updated 2025-02-18 UTC.</p> </devsite-content-footer> <devsite-notification > </devsite-notification> <div class="devsite-content-data"> <template class="devsite-thumb-rating-feedback"> <devsite-feedback position="thumb-rating" project-name="Google Maps Platform" product-id="81777" bucket="" context="Maps API Product Family" version="t-devsite-webserver-20250211-r00-rc00.466928320959134316" data-label="Send Feedback Button" track-type="feedback" track-name="sendFeedbackLink" track-metadata-position="thumb-rating" class="nocontent" project-icon="https://developers.google.com/static/maps/images/maps-icon.svg" > <button> Need to tell us more? </button> </devsite-feedback> </template> <template class="devsite-content-data-template"> [[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-02-18 UTC."],[[["Google Maps Platform provides APIs and SDKs for integrating maps and location-based services into your applications, covering functionalities such as mapping, routing, places, and environment data."],["Getting started requires selecting desired APIs, obtaining an API key, and setting up billing, with usage limits and costs outlined in the pricing details."],["Troubleshooting resources are available for common issues like API key errors, rate limits, authorization errors, and platform-specific problems on iOS and Android."],["Usage is subject to terms of service, including restrictions on data access, tracking applications, and prohibited usage, with support available for technical and account-related inquiries."],["The platform supports various features like geocoding, directions, transit information, and KML/GeoRSS overlays, with specific considerations for URL signing security and iOS/Android debugging."]]],[]] </template> </div> </devsite-content> </main> <devsite-footer-promos class="devsite-footer"> <nav class="devsite-footer-promos nocontent" aria-label="Promotions"> <ul class="devsite-footer-promos-list"> <li class="devsite-footer-promo"> <a href="https://status.cloud.google.com/maps-platform/" class="devsite-footer-promo-title gc-analytics-event" data-category="Site-Wide Custom Events" data-category="GMPDevsiteFooter" class="gc-analytics-event" data-label="status" data-action="linkClick" > <picture> <img class="devsite-footer-promo-icon" src="/static/maps/images/landing/warning.svg" loading="lazy" alt="Platform Status"> </picture> <span class="devsite-footer-promo-label"> Platform Status </span> </a> <div class="devsite-footer-promo-description">Find out about platform incidents and outages.</div> </li> <li class="devsite-footer-promo"> <a href="/maps/support" class="devsite-footer-promo-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="support" data-category="GMPDevsiteFooter" class="gc-analytics-event" data-action="linkClick" > <picture> <img class="devsite-footer-promo-icon" src="/static/maps/images/landing/help.svg" loading="lazy" alt="Support"> </picture> <span class="devsite-footer-promo-label"> Support </span> </a> <div class="devsite-footer-promo-description">Get help from the Support team.</div> </li> <li class="devsite-footer-promo"> <a href="https://discord.gg/f4hvx8Rp2q" class="devsite-footer-promo-title gc-analytics-event" data-category="Site-Wide Custom Events" data-category="GMPDevsiteFooter" class="gc-analytics-event" data-label="discord" data-action="linkClick" > <picture> <img class="devsite-footer-promo-icon" src="/static/maps/images/discord-color.png" loading="lazy" alt="Discord"> </picture> <span class="devsite-footer-promo-label"> Discord </span> </a> <div class="devsite-footer-promo-description">Chat with fellow developers about Google Maps Platform.</div> </li> <li class="devsite-footer-promo"> <a href="/maps/support#issue_tracker" class="devsite-footer-promo-title gc-analytics-event" data-category="Site-Wide Custom Events" data-label="issueTracker" data-action="linkClick" data-category="GMPDevsiteFooter" class="gc-analytics-event" > <picture> <img class="devsite-footer-promo-icon" src="/static/site-assets/developers_64dp.png" loading="lazy" alt="Issue Tracker"> </picture> <span class="devsite-footer-promo-label"> Issue Tracker </span> </a> <div class="devsite-footer-promo-description">Something wrong? Send us a bug report!</div> </li> </ul> </nav> </devsite-footer-promos> <devsite-footer-linkboxes class="devsite-footer"> <nav class="devsite-footer-linkboxes nocontent" aria-label="Footer links"> <ul class="devsite-footer-linkboxes-list"> <li class="devsite-footer-linkbox "> <h3 class="devsite-footer-linkbox-heading no-link">Learn More</h3> <ul class="devsite-footer-linkbox-list"> <li class="devsite-footer-linkbox-item"> <a href="/maps/faq" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 1)" > FAQ </a> </li> <li class="devsite-footer-linkbox-item"> <a href="/maps/documentation/api-picker" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 2)" > API Picker </a> </li> <li class="devsite-footer-linkbox-item"> <a href="/maps/get-started" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 3)" > Getting started </a> </li> <li class="devsite-footer-linkbox-item"> <a href="/maps/api-security-best-practices" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 4)" > API security best practices </a> </li> </ul> </li> <li class="devsite-footer-linkbox "> <h3 class="devsite-footer-linkbox-heading no-link">Platforms</h3> <ul class="devsite-footer-linkbox-list"> <li class="devsite-footer-linkbox-item"> <a href="/maps/apis-by-platform#android" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 1)" > Android </a> </li> <li class="devsite-footer-linkbox-item"> <a href="/maps/apis-by-platform#ios" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 2)" > iOS </a> </li> <li class="devsite-footer-linkbox-item"> <a href="/maps/apis-by-platform#web_apis" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 3)" > Web </a> </li> <li class="devsite-footer-linkbox-item"> <a href="/maps/apis-by-platform#web_service_apis" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 4)" > Web Services </a> </li> </ul> </li> <li class="devsite-footer-linkbox "> <h3 class="devsite-footer-linkbox-heading no-link">Product Info</h3> <ul class="devsite-footer-linkbox-list"> <li class="devsite-footer-linkbox-item"> <a href="/maps/pricing-and-plans" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-category="pricingAndPlans"data-label="footerMen"data-action="linkClick"> Pricing and Plans </a> </li> <li class="devsite-footer-linkbox-item"> <a href="https://cloud.google.com/contact-maps/" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-category="contactSales"data-label="footerMenu"data-action="linkClick"> Contact Sales </a> </li> <li class="devsite-footer-linkbox-item"> <a href="https://developers.google.com/maps/support/" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 3)" > Support </a> </li> <li class="devsite-footer-linkbox-item"> <a href="https://cloud.google.com/maps-platform/terms" class="devsite-footer-linkbox-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Link (index 4)" > Terms of Service </a> </li> </ul> </li> </ul> </nav> </devsite-footer-linkboxes> <devsite-footer-utility class="devsite-footer"> <div class="devsite-footer-utility nocontent"> <nav class="devsite-footer-sites" aria-label="Other Google Developers websites"> <a href="https://developers.google.com/" class="devsite-footer-sites-logo-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Google Developers Link"> <picture> <img class="devsite-footer-sites-logo" src="https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f/developers/images/lockup-google-for-developers.svg" loading="lazy" alt="Google Developers"> </picture> </a> <ul class="devsite-footer-sites-list"> <li class="devsite-footer-sites-item"> <a href="//developer.android.com" class="devsite-footer-sites-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Android Link" > Android </a> </li> <li class="devsite-footer-sites-item"> <a href="//developer.chrome.com/home" class="devsite-footer-sites-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Chrome Link" > Chrome </a> </li> <li class="devsite-footer-sites-item"> <a href="//firebase.google.com" class="devsite-footer-sites-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Firebase Link" > Firebase </a> </li> <li class="devsite-footer-sites-item"> <a href="//cloud.google.com" class="devsite-footer-sites-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Google Cloud Platform Link" > Google Cloud Platform </a> </li> <li class="devsite-footer-sites-item"> <a href="//ai.google.dev/" class="devsite-footer-sites-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer Google AI Link" > Google AI </a> </li> <li class="devsite-footer-sites-item"> <a href="/products" class="devsite-footer-sites-link gc-analytics-event" data-category="Site-Wide Custom Events" data-label="Footer All products Link" > All products </a> </li> </ul> </nav> <nav class="devsite-footer-utility-links" aria-label="Utility links"> <ul class="devsite-footer-utility-list"> <li class="devsite-footer-utility-item "> <a class="devsite-footer-utility-link gc-analytics-event" href="/terms/site-terms" data-category="Site-Wide Custom Events" data-label="Footer Terms link" > Terms </a> </li> <li class="devsite-footer-utility-item "> <a class="devsite-footer-utility-link gc-analytics-event" href="//policies.google.com/privacy" data-category="Site-Wide Custom Events" data-label="Footer Privacy link" > Privacy </a> </li> <li class="devsite-footer-utility-item glue-cookie-notification-bar-control"> <a class="devsite-footer-utility-link gc-analytics-event" href="#" data-category="Site-Wide Custom Events" data-label="Footer Manage cookies link" aria-hidden="true" > Manage cookies </a> </li> <li class="devsite-footer-utility-item devsite-footer-utility-button"> <span class="devsite-footer-utility-description">Sign up for the Google for Developers newsletter</span> <a class="devsite-footer-utility-link gc-analytics-event" href="/newsletter/subscribe" data-category="Site-Wide Custom Events" data-label="Footer Subscribe link" > Subscribe </a> </li> </ul> <devsite-language-selector> <ul role="presentation"> <li role="presentation"> <a role="menuitem" lang="en" >English</a> </li> <li role="presentation"> <a role="menuitem" lang="de" >Deutsch</a> </li> <li role="presentation"> <a role="menuitem" lang="es" >Español</a> </li> <li role="presentation"> <a role="menuitem" lang="es_419" >Español – América Latina</a> </li> <li role="presentation"> <a role="menuitem" lang="fr" >Français</a> </li> <li role="presentation"> <a role="menuitem" lang="id" >Indonesia</a> </li> <li role="presentation"> <a role="menuitem" lang="it" >Italiano</a> </li> <li role="presentation"> <a role="menuitem" lang="pl" >Polski</a> </li> <li role="presentation"> <a role="menuitem" lang="pt_br" >Português – Brasil</a> </li> <li role="presentation"> <a role="menuitem" lang="vi" >Tiếng Việt</a> </li> <li role="presentation"> <a role="menuitem" lang="tr" >Türkçe</a> </li> <li role="presentation"> <a role="menuitem" lang="ru" >Русский</a> </li> <li role="presentation"> <a role="menuitem" lang="he" >עברית</a> </li> <li role="presentation"> <a role="menuitem" lang="ar" >العربيّة</a> </li> <li role="presentation"> <a role="menuitem" lang="fa" >فارسی</a> </li> <li role="presentation"> <a role="menuitem" lang="hi" >हिंदी</a> </li> <li role="presentation"> <a role="menuitem" lang="bn" >বাংলা</a> </li> <li role="presentation"> <a role="menuitem" lang="th" >ภาษาไทย</a> </li> <li role="presentation"> <a role="menuitem" lang="zh_cn" >中文 – 简体</a> </li> <li role="presentation"> <a role="menuitem" lang="zh_tw" >中文 – 繁體</a> </li> <li role="presentation"> <a role="menuitem" lang="ja" >日本語</a> </li> <li role="presentation"> <a role="menuitem" lang="ko" >한국어</a> </li> </ul> </devsite-language-selector> </nav> </div> </devsite-footer-utility> <devsite-panel></devsite-panel> <devsite-concierge data-info-panel data-ai-panel data-api-explorer-panel > </devsite-concierge> </section></section> <devsite-sitemask></devsite-sitemask> <devsite-snackbar></devsite-snackbar> <devsite-tooltip ></devsite-tooltip> <devsite-heading-link></devsite-heading-link> <devsite-analytics> <script type="application/json" analytics>[{&#34;dimensions&#34;: {&#34;dimension11&#34;: false, &#34;dimension4&#34;: &#34;Google Maps Platform&#34;, &#34;dimension1&#34;: &#34;Signed out&#34;, &#34;dimension6&#34;: &#34;en&#34;, &#34;dimension5&#34;: &#34;en&#34;, &#34;dimension3&#34;: false}, &#34;gaid&#34;: &#34;UA-24532603-1&#34;, &#34;metrics&#34;: {&#34;ratings_count&#34;: &#34;metric2&#34;, &#34;ratings_value&#34;: &#34;metric1&#34;}, &#34;purpose&#34;: 1}]</script> <script type="application/json" tag-management>{&#34;at&#34;: &#34;True&#34;, &#34;ga4&#34;: [{&#34;id&#34;: &#34;G-272J68FCRF&#34;, &#34;purpose&#34;: 1}], &#34;ga4p&#34;: [{&#34;id&#34;: &#34;G-272J68FCRF&#34;, &#34;purpose&#34;: 1}], &#34;gtm&#34;: [{&#34;id&#34;: &#34;GTM-W2H69MN&#34;, &#34;purpose&#34;: 0}], &#34;parameters&#34;: {&#34;internalUser&#34;: &#34;False&#34;, &#34;language&#34;: {&#34;machineTranslated&#34;: &#34;False&#34;, &#34;requested&#34;: &#34;en&#34;, &#34;served&#34;: &#34;en&#34;}, &#34;pageType&#34;: &#34;article&#34;, &#34;projectName&#34;: &#34;Google Maps Platform&#34;, &#34;signedIn&#34;: &#34;False&#34;, &#34;tenant&#34;: &#34;developers&#34;, &#34;recommendations&#34;: {&#34;sourcePage&#34;: &#34;&#34;, &#34;sourceType&#34;: 0, &#34;sourceRank&#34;: 0, &#34;sourceIdenticalDescriptions&#34;: 0, &#34;sourceTitleWords&#34;: 0, &#34;sourceDescriptionWords&#34;: 0, &#34;experiment&#34;: &#34;&#34;}, &#34;experiment&#34;: {&#34;ids&#34;: &#34;&#34;}}}</script> </devsite-analytics> <devsite-badger></devsite-badger> <script nonce="l2rXGwHgoZ4HvZOKfXfHVfkpfISCxy"> (function(d,e,v,s,i,t,E){d['GoogleDevelopersObject']=i; t=e.createElement(v);t.async=1;t.src=s;E=e.getElementsByTagName(v)[0]; E.parentNode.insertBefore(t,E);})(window, document, 'script', 'https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f/developers/js/app_loader.js', '[1,"en",null,"/js/devsite_app_module.js","https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f","https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f/developers","https://developers-dot-devsite-v2-prod.appspot.com",null,null,["/_pwa/developers/manifest.json","https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f/images/video-placeholder.svg","https://www.gstatic.com/devrel-devsite/prod/v38a693baeb774512feb42f10aac8f755d8791ed41119b5be7a531f8e16f8279f/developers/images/favicon-new.png","https://fonts.googleapis.com/css?family=Google+Sans:400,500|Roboto:400,400italic,500,500italic,700,700italic|Roboto+Mono:400,500,700&display=swap"],1,null,[1,6,8,12,14,17,21,25,50,52,63,70,75,76,80,87,91,92,93,97,98,100,101,102,103,104,105,107,108,109,110,112,113,116,117,118,120,122,124,125,126,127,129,130,131,132,133,134,135,136,138,140,141,147,148,149,151,152,156,157,158,159,161,163,164,168,169,170,179,180,182,183,186,191,193,196],"AIzaSyAP-jjEJBzmIyKR4F-3XITp8yM9T1gEEI8","AIzaSyB6xiKGDR5O3Ak2okS4rLkauxGUG7XP0hg","developers.google.com","AIzaSyAQk0fBONSGUqCNznf6Krs82Ap1-NV6J4o","AIzaSyCCxcqdrZ_7QMeLCRY20bh_SXdAYqy70KY",null,null,null,["Search__enable_dynamic_content_confidential_banner","Cloud__enable_cloud_dlp_service","MiscFeatureFlags__enable_firebase_utm","Cloud__enable_free_trial_server_call","Concierge__enable_key_takeaways","Profiles__require_profile_eligibility_for_signin","Significatio__enable_by_tenant","Profiles__enable_join_program_group_endpoint","Analytics__enable_clearcut_logging","Experiments__reqs_query_experiments","DevPro__enable_cloud_innovators_plus","Search__enable_page_map","Cloud__enable_cloud_facet_chat","EngEduTelemetry__enable_engedu_telemetry","Concierge__enable_concierge","Concierge__enable_pushui","BookNav__enable_tenant_cache_key","Cloud__enable_cloudx_ping","Profiles__enable_developer_profiles_callout","Search__enable_ai_search_summaries_restricted","Cloud__enable_cloud_shell","Cloud__enable_legacy_calculator_redirect","TpcFeatures__enable_unmirrored_page_left_nav","Search__enable_suggestions_from_borg","Profiles__enable_profile_collections","MiscFeatureFlags__enable_explain_this_code","TpcFeatures__enable_mirror_tenant_redirects","MiscFeatureFlags__emergency_css","Profiles__enable_awarding_url","Profiles__enable_completequiz_endpoint","MiscFeatureFlags__developers_footer_image","Cloud__enable_cloudx_experiment_ids","Profiles__enable_public_developer_profiles","Concierge__enable_concierge_restricted","MiscFeatureFlags__developers_footer_dark_image","Profiles__enable_recognition_badges","Profiles__enable_stripe_subscription_management","CloudShell__cloud_code_overflow_menu","MiscFeatureFlags__enable_project_variables","Profiles__enable_complete_playlist_endpoint","Cloud__enable_cloud_shell_fte_user_flow","Profiles__enable_release_notes_notifications","Cloud__enable_llm_concierge_chat","Search__enable_ai_eligibility_checks","Profiles__enable_page_saving","Profiles__enable_dashboard_curated_recommendations","DevPro__enable_developer_subscriptions","MiscFeatureFlags__enable_variable_operator","CloudShell__cloud_shell_button","Search__enable_ai_search_summaries","Profiles__enable_completecodelab_endpoint","MiscFeatureFlags__enable_view_transitions"],null,null,"AIzaSyBLEMok-5suZ67qRPzx0qUtbnLmyT_kCVE","https://developerscontentserving-pa.clients6.google.com","AIzaSyCM4QpTRSqP5qI4Dvjt4OAScIN8sOUlO-k","https://developerscontentsearch-pa.clients6.google.com",1,4,null,"https://developerprofiles-pa.clients6.google.com",[1,"developers","Google for Developers","developers.google.com",null,"developers-dot-devsite-v2-prod.appspot.com",null,null,[1,1,[1],null,null,null,null,null,null,null,null,[1],null,null,null,null,null,null,[1],[1,null,null,[1,20],"/recommendations/information"],null,null,null,[1,1,1],[1,1,null,1,1]],null,[null,null,null,null,null,null,"/images/lockup-new.svg","/images/touchicon-180-new.png",null,null,null,null,1,null,null,null,null,null,null,null,null,1,null,null,null,"/images/lockup-dark-theme-new.svg",[]],[],null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,[6,1,14,15,20,22,23,29,32,36],null,[[null,null,null,[3,7,10,2,39,17,4,32,24,11,12,13,34,15,25],null,null,[1,[["docType","Choose a content type",[["Tutorial",null,null,null,null,null,null,null,null,"Tutorial"],["Guide",null,null,null,null,null,null,null,null,"Guide"],["Sample",null,null,null,null,null,null,null,null,"Sample"]]],["product","Choose a product",[["Android",null,null,null,null,null,null,null,null,"Android"],["ARCore",null,null,null,null,null,null,null,null,"ARCore"],["ChromeOS",null,null,null,null,null,null,null,null,"ChromeOS"],["Firebase",null,null,null,null,null,null,null,null,"Firebase"],["Flutter",null,null,null,null,null,null,null,null,"Flutter"],["Assistant",null,null,null,null,null,null,null,null,"Google Assistant"],["GoogleCloud",null,null,null,null,null,null,null,null,"Google Cloud"],["GoogleMapsPlatform",null,null,null,null,null,null,null,null,"Google Maps Platform"],["GooglePay",null,null,null,null,null,null,null,null,"Google Pay & Google Wallet"],["GooglePlay",null,null,null,null,null,null,null,null,"Google Play"],["Tensorflow",null,null,null,null,null,null,null,null,"TensorFlow"]]],["category","Choose a topic",[["AiAndMachineLearning",null,null,null,null,null,null,null,null,"AI and Machine Learning"],["Data",null,null,null,null,null,null,null,null,"Data"],["Enterprise",null,null,null,null,null,null,null,null,"Enterprise"],["Gaming",null,null,null,null,null,null,null,null,"Gaming"],["Mobile",null,null,null,null,null,null,null,null,"Mobile"],["Web",null,null,null,null,null,null,null,null,"Web"]]]]]],[1,1],null,1],[[["UA-24532603-1"],["UA-22084204-5"],null,null,["UA-24532603-5"],null,null,[["G-272J68FCRF"],null,null,[["G-272J68FCRF",2]]],[["UA-24532603-1",2]],null,[["UA-24532603-5",2]],null,1],[[3,2],[16,13],[13,10],[12,9],[11,8],[5,4],[1,1],[14,11],[6,5],[15,12],[4,3]],[[1,1],[2,2]]],null,4,null,null,null,null,null,null,null,null,null,null,null,null,null,"developers.devsite.google"],null,"pk_live_5170syrHvgGVmSx9sBrnWtA5luvk9BwnVcvIi7HizpwauFG96WedXsuXh790rtij9AmGllqPtMLfhe2RSwD6Pn38V00uBCydV4m",1]') </script> <devsite-a11y-announce></devsite-a11y-announce> </body> </html>

Pages: 1 2 3 4 5 6 7 8 9 10