Places SDK for Android 的政策

本主题介绍了所有应用的提供方说明要求 使用 Places SDK for Android 开发,包括地点自动补全功能 作为该 API 一部分的服务。如需详细了解 Google Maps Platform 条款,请参阅 Google Maps Platform 服务条款

提供使用条款和隐私权政策

如果您要开发 Places SDK for Android 应用,则必须 条款 隐私权 应用政策 (符合您与 Google 的协议中规定的准则):

  • 《使用条款》和《隐私权政策》必须可公开访问。
  • 您必须在应用的《使用条款》中明确说明,用户使用应用时须遵守 Google 服务条款
  • 您必须在《隐私权政策》中注明您使用的是 Google Maps API,并且以提述方式将 Google 隐私权政策纳入其中。

《使用条款》和《隐私权政策》的建议显示位置因应用平台而异。

移动应用

如果开发的是移动应用,建议在相关应用商店的应用下载页面上以及应用的设置菜单中提供指向《使用条款》和《隐私权政策》的链接。

Web 应用

如果开发的是 Web 应用,建议在网站的页脚位置提供指向《使用条款》和《隐私权政策》的链接。

预取、缓存或存储内容

使用 Places SDK for Android 的应用受 与 Google 达成的协议。根据您签订的协议条款,除了条款中规定的少数情况之外,您不得预取、存储、缓存任何内容或将其编入索引。

请注意,用于唯一标识地点的地点 ID不受缓存限制。系统会在 Places SDK for Android 响应。如需了解如何保存、刷新和管理地点 ID,请参阅地点 ID 指南。

显示 Places SDK for Android 的结果

您可以在 Google 地图上显示 Places SDK for Android 结果,也可以不使用地图。如果您想 在地图上显示 Places SDK for Android 结果,那么这些结果必须显示在 Google 地图上。 禁止在非 Google 地图的地图上使用 Places SDK for Android 数据。

如果应用在 Google 地图上显示数据,则需要包含 Google 徽标,且不得修改。如果应用显示 Google 数据时与 Google 地图在同一屏幕上,则不需要向 Google 提供详细的提供方信息。

如果应用在页面或视图上显示数据时 Google 地图并未一同显示,您必须在显示这些数据的同时显示 Google 徽标。例如,如果应用在一个标签页上显示 Google 数据,而包含这些数据的 Google 地图位于另一个标签页上,则第一个标签页上必须显示 Google 徽标。如果应用使用搜索字段(无论是否具有自动补全功能),则徽标必须在同一行内显示。

Google 徽标应放置在地图左下角,提供方信息应放置在右下角,两者都应显示在地图上,而不是位于地图下方或应用内的其他位置。在下面的地图示例中,Google 徽标位于地图左下角,提供方信息位于右下角。

政策提供方信息位置

以下 zip 文件包含不同尺寸的 Google 徽标,分别适用于桌面版、Android 版和 iOS 版应用。您不得以任何方式修改这些徽标或调整其尺寸。

下载:google_logo.zip

请勿修改提供方信息。请勿移除、裁剪掉提供方信息,或对其进行模糊处理。您不能内嵌使用 Google 徽标(例如,“这些地图来自 [Google_logo]”)。

确保提供方信息靠近内容。如果不是以直接嵌入方式使用 Google 图像屏幕截图,那么显示的标准提供方信息应与图片中的内容相同。如有必要,您可以自定义提供方信息文字的样式和位置,只需确保文字紧邻内容且清晰可辨,能够让普通观众或读者轻松阅读。您不得将提供方信息移到内容区域之外的位置,例如放在图书末尾、文件或节目的人员名单或网站的页脚中。

注明第三方数据提供方。地图产品上的一些数据和图片来自 Google 以外的提供方。如果使用此类图像,提供方信息文字中必须提及“Google”和相关数据提供方,例如“地图数据:Google、Maxar Technologies”。如果图像中提及第三方数据提供方,那么提供方信息中不应仅包含“Google”或 Google 徽标。

如果要使用 Google Maps Platform 的设备实际无法显示提供方信息,请与 Google 销售团队联系,了解您的使用情形适用的许可。

其他提供方信息要求

请按照以下说明检索第三方提供方说明,并显示 在应用中提供提供方说明。

从地点检索提供方说明

如果您的应用要显示通过调用 按 ID 获取地点, 应用还必须显示地点详情的第三方提供方说明 。

该 API 会返回一个 Place 对象。如需从 Place 对象检索提供方说明,请调用 Place.getAttributions()。 该方法返回 String 对象的 List 或 null 。

String placeId = "INSERT_PLACE_ID_HERE";
List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.NAME);
FetchPlaceRequest request = FetchPlaceRequest.newInstance(placeId, placeFields);

placesClient.fetchPlace(request).addOnSuccessListener((response) -> {
  Place place = response.getPlace();
  textView.append("Place found: " + place.getName());
  List<String> attributions = place.getAttributions();
  if (attributions != null) {
    StringBuilder stringBuilder = new StringBuilder("Attributions: ");
    for (String attribution : attributions) {
      stringBuilder.append(attribution).append("\n");
    }
    textView.append(stringBuilder.toString());
  }}).addOnFailureListener((exception) -> {
    if (exception instanceof ApiException) {
      // Handle the error.
    }
  }
);

显示照片的提供方信息

如果您的应用显示地点照片,您必须 为具有提供方说明的每张照片显示提供方说明。 PhotoMetadata、 可包含以下两种提供方说明之一:

要获取照片的字符串提供方说明,请调用 PhotoMetadata.getAttributions()。该方法会返回 HTML 字符序列;如果没有提供方,则为空字符串 。

// Get the photo metadata from the Place object.
PhotoMetadata photoMetadata = place.getPhotoMetadatas().get(0);

// Get the attribution text.
String attributions = photoMetadata.getAttributions();

要获取照片的作者提供方说明,请调用 PhotoMetadata.getAuthorAttributions()。该方法会返回 AuthorAttributions 对象。此对象包含一个 List (共 AuthorAttribution 项) 对象,每个作者归属一个。

// Get the photo metadata from the Place object.
PhotoMetadata photoMetadata = place.getPhotoMetadatas().get(0);

// Get the author attributions object.
AuthorAttributions authorAttributions = photoMetadata.getAuthorAttributions();
List<AuthorAttribution> authorAttributionList = authorAttributions.asList();

显示评价

一个 Place 对象最多可以包含五条评价,其中每条评价 由 Review 对象。您可以选择在应用中显示这些评价。

在显示 Google 用户发表的评价时,必须将 显示有作者姓名。当作者属性字段中提供时 (针对 Review 对象),建议您添加作者的照片 并链接到他们的个人资料下图显示了 对公园的评价:

显示作者信息

Google 还建议您显示评价的排序方式, 最终用户

要查看评价,请调用 Place.getReviews():

// Specify the fields to return.
final List<Place.Field> placeFields = Arrays.asList(Place.Field.REVIEWS);

// Construct a request object, passing the place ID and fields array.
final FetchPlaceRequest request = FetchPlaceRequest.newInstance("INSERT_PLACE_ID_HERE", placeFields);

placesClient.fetchPlace(request).addOnSuccessListener((response) -> {
    Place place = response.getPlace();
    List<Review> reviews = place.getReviews();
    // For loop for iterating over the List
    for (int i = 0; i < reviews.size(); i++) {
      // For each review, get the Review object.
        Review placeReview = reviews.get(i);

      // Get any attribution and author attribution.
        String reviewAttribution = placeReview.getAttribution();
        AuthorAttribution authorAttribution = placeReview.getAuthorAttribution();

        // Display the review contents and attributions as necessary.
    }
}).addOnFailureListener((exception) -> {
    if (exception instanceof ApiException) {
        // Handle the error.
    }
});

显示第三方提供方说明

第三方提供商的提供方说明包含 HTML 格式的内容和链接 您必须保留该格式并向用户显示 它们。Google 建议您在地点详情下方显示此信息。

API 会为应用使用的所有地点生成提供方说明。 提供方说明是按 API 调用提供的,而不是按地点提供的。

显示提供方说明的一种方法是使用 TextView。 例如:

TextView attributionsText = (TextView) findViewById(R.id.attributions);
String thirdPartyAttributions = place.getAttributions();
attributionsText.setText(thirdPartyAttributions);

第三方提供方说明示例

Listings by <a href="https://www.example.com/">Example Company</a>

Google 提供方信息样式指南

如果无法使用可下载的 Google 徽标,请按照以下样式指南使用 CSS 和 HTML 添加 Google 提供方信息。

留白空间

完整标识周围的留白空间应等同或超过 Google 中“G”的高度。

提供方信息和 Google 徽标之间的间距应为“G”宽度的一半。

易读性

署名应始终清晰可辨,而且颜色应适合给定背景。务必要为所选择的徽标变体提供足够的对比度。

颜色

如果是白色或浅色背景,文字应使用 Google Material Gray 700,黑色色调最高介于 0% 到 40% 之间。

Google
#5F6368
RGB 95 99 104
HSL 213 5 39
HSB 213 9 41

如果是深色背景,而且是摄影作品或简单图案,应使用白色文字标注署名和提供方信息。

Google
#FFFFFF
RGB 255 255 255
HSL 0 0 100
HSB 0 0 100

字体

使用 Roboto 字体。

示例 CSS

将以下 CSS 代码段应用于文字“Google”后,“Google”以适当的字体、颜色和间距显示在白色或浅色背景上。

font-family: Roboto;
font-style: normal;
font-weight: 500;
font-size: 16px;
line-height: 16px;
padding: 16px;
letter-spacing: 0.0575em; /* 0.69px */
color: #5F6368;