- ホーム
- ブログ
- Google Places API
- 【Google Places API】google mapの写真をFlutterで表示させてみた
この記事は、【 可茂IT塾 Advent Calendar 2022 】の8日目の記事です。
FlutterでGoogle places apiを使い、google mapの特定の場所の写真を取得し表示してみました。
岐阜県美濃加茂市にコワーキングスペース「coyane〜こやぁね〜」という可茂IT塾のアジトがあるのですが、自分は福岡在住のリモート組でこやぁねには一度も行ったことがないので、今回は、せっかくなのでこやぁねの写真を取得してのぞいてみたいと思います!
Google maps platformのapiキーが必要になるので、発行しておきましょう! https://developers.google.com/maps
まず、大まかな取得の流れはこんな感じです。
ワード検索 > 場所情報取得 > 写真一覧抜き出す > URLから写真を表示
import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
class HomePage extends StatefulWidget {
const HomePage({super.key});
State<StatefulWidget> createState() {
return _HomePage();
}
}
class _HomePage extends State<HomePage> {
var urls = [];
final API_KEY = "APIキー";
final KEY_WORD = "〒505-0041 岐阜県美濃加茂市太田町2689 30 コミュニティ&コワーキングスペース co・ya^ne";
Future<void> fetchPhoto() async {
final searchRes = await http.get(Uri.parse(
'https://maps.googleapis.com/maps/api/place/textsearch/json?query=$KEY_WORD&language=ja&key=$API_KEY'));
final Map<String, dynamic> body = jsonDecode(searchRes.body);
final place_id = body['results'][0]['place_id'];
final placeRes = await http.get(Uri.parse(
'https://maps.googleapis.com/maps/api/place/details/json?place_id=$place_id&key=$API_KEY'));
final Map<String, dynamic> placeData = jsonDecode(placeRes.body);
final List photos = placeData['result']["photos"];
for (var photo in photos) {
final photo_reference = photo['photo_reference'];
final url =
"https://maps.googleapis.com/maps/api/place/photo?maxwidth=400&photoreference=$photo_reference&key=$API_KEY";
urls.add(url);
print(url);
}
setState(() {});
}
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
const SizedBox(
height: 50,
),
SizedBox(
height: 50,
child: ElevatedButton(
onPressed: () async {
await fetchPhoto();
},
child: const Text('done')),
),
Expanded(
child: urls.isEmpty
? Container()
: GridView.builder(
itemCount: urls.length,
gridDelegate:
const SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 2,
),
itemBuilder: (BuildContext context, int index) {
final image = urls[index];
return _photoItem(image);
}),
)
],
)),
);
}
Widget _photoItem(String image) {
return Image.network(
image,
fit: BoxFit.cover,
);
}
}
めちゃめちゃ雑なコードですがどうかご了承ください🙇
fetchPhoto()
でapiの取得をまとめて行なっています。
中身を細かく解説していきます。
final searchRes = await http.get(Uri.parse(
'https://maps.googleapis.com/maps/api/place/textsearch/json?query=$KEY_WORD&language=ja&key=$API_KEY'));
final Map<String, dynamic> body = jsonDecode(searchRes.body);
final place_id = body['results'][0]['place_id'];
TextSearchリクエストでは、フリー検索でヒットした場所IDを取得できます。
jsonはresults
のなかに検索ヒットしたデータが格納されています。今回は、住所と場所名で検索しているため、おそらくデータは一つしかないので0
を指定して取得しています。次のリクエストでplace_id
が必要になるのでここで抜き出します。
final placeRes = await http.get(Uri.parse(
'https://maps.googleapis.com/maps/api/place/details/json?place_id=$place_id&key=$API_KEY'));
final Map<String, dynamic> placeData = jsonDecode(placeRes.body);
final List photos = placeData['result']["photos"];
PlaceDetailリクエストではplace_id
を指定することで特定の場所情報取得できます。
jsonのresult
の中のphotos
に場所の写真情報が格納されているので抜き出します。
for (var photo in photos) {
final PHOTO_REFERENCE = photo['photo_reference'];
final url = "https://maps.googleapis.com/maps/api/place/photo?maxwidth=400&photoreference=$PHOTO_REFERENCE&key=$API_KEY";
urls.add(url);
PlacePhotosリクエストは、photo_reference
を指定することでURLとして写真を取得できます。
PlaceDetailリクエストで取得したphotos
を繰り返し処理でURLを一つずつ抽出していきます。
photo_reference
はphoto
のjson内に格納されています。
結果はこんな感じで表示されました
こやぁねめちゃめちゃ綺麗ですね!ここで作業したら生産性爆上がりしそうです。
今回は、こんな感じでFlutterでgoogle place apiを使ってこやぁねの写真を取得してみました。
他の検索リクエストを使えば、近くのラーメン屋の写真一覧みたいなのも取得できたりします。
月$200分のリクエストまで無料で使えるので、個人開発などで使う分には十分無料で使えるのではないでしょうか。
可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。
Read More可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。
Read More