如何从 google 个位置 api 获取图像?

How to get an image from google places api?

我目前一直在尝试从 Google 位置 API 获取图像,在文档中说明要获取您拥有的图像 https://maps.googleapis.com/maps/api/place/photo?maxwidth=400&photoreference=[imagereference]&key=[yourkey]

这会将您重定向到具有实际图像的 URL。当我尝试获取 base 64 图像版本以便我可以在我的 React 应用程序中使用时,如何使用 axios 或 fetch 执行此过程?

如果您想在客户端应用程序中显示地点 API 照片,您需要使用 Google 地图 JavaScript 地点库的 Places Photos

下面的代码片段显示了我如何从 getDetails 结果中获取照片 URL 并将其放入我的状态变量中的示例:

       const request = {
              placeId: "ChIJN1t_tDeuEmsRUsoyG83frY4",
              fields: [
                "name",
                "formatted_address",
                "place_id",
                "geometry",
                "photos"
              ]
            };

            const service = new google.maps.places.PlacesService(map);
            service.getDetails(request, (place, status) => {
              if (
                status === google.maps.places.PlacesServiceStatus.OK &&
                place &&
                place.geometry &&
                place.geometry.location
              ) {
                const marker = new google.maps.Marker({
                  map,
                  position: place.geometry.location
                });
              }
              this.setState({
                photos: place.photos[0].getUrl(),
                name: place.formatted_address
              });
            });

这是 sample code 要查看此作品,请将 Map.js 中脚本中的 YOUR_API_KEY 替换为您的 API 密钥。