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 响应的 place_id 字段中返回地点 ID。如需了解如何保存、刷新和管理地点 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.DISPLAY_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 对象。此对象包含一个 AuthorAttribution 对象的 List,每个作者归因对应一个。

// 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();

搜索结果归因

在欧洲,如果使用 Google 的纯粹排名,搜索产品必须提供不超过 1 次点击即可找到的说明文本,其中说明决定搜索结果排名的主要因素及其权重。说明文字:

标题:关于这些结果

正文:当您搜索某个地点附近的商家或场所时,Google 地图会显示本地搜索结果。并且会结合多种因素(主要是相关性、距离和知名度)帮助您找到最符合搜索条件的结果。

按钮 1:了解详情
“了解详情”文字应链接到帮助中心文章

按钮 2:确定

显示评价

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;