Power Appsにて地図アプリを作ることになったので、Tipsをメモ。
Google Maps APIのキーを取得
まずはAPIキーの取得から。
Google CloudのAPIサービスのページに移動して、[APIとサービスを有効にする]から、
data:image/s3,"s3://crabby-images/c6550/c655008387e3bf6144fb8d2bcfc6599668eb9d79" alt=""
data:image/s3,"s3://crabby-images/c6550/c655008387e3bf6144fb8d2bcfc6599668eb9d79" alt=""
「Places API」を選ぶ。※新しいバージョン「Places API(新規)」も出てるけど今回は旧バージョンを使用
data:image/s3,"s3://crabby-images/45b88/45b88bc67e244275eb839222bd1afcb1dc590a23" alt=""
data:image/s3,"s3://crabby-images/45b88/45b88bc67e244275eb839222bd1afcb1dc590a23" alt=""
[有効にする]を選んで、
data:image/s3,"s3://crabby-images/cf181/cf1813fa00258d1bdd858694d827ec6472e920f0" alt=""
data:image/s3,"s3://crabby-images/cf181/cf1813fa00258d1bdd858694d827ec6472e920f0" alt=""
「手動で有料アカウントにアップグレードするまで請求は発生しません。」を信じてクレカを登録。
※大丈夫だと思うけど請求が発生しても責任はとれないので、自己責任でお願いします。
data:image/s3,"s3://crabby-images/8601e/8601ef77418125ab7beb25737cf99598dc2ec38f" alt=""
※大丈夫だと思うけど請求が発生しても責任はとれないので、自己責任でお願いします。
data:image/s3,"s3://crabby-images/8601e/8601ef77418125ab7beb25737cf99598dc2ec38f" alt=""
無事APIキーが発行されるので、このキーをメモしておく。
※厳重に管理してください。
data:image/s3,"s3://crabby-images/29730/29730aa1421b3c5f450c259524d37d31356524a7" alt=""
※厳重に管理してください。
data:image/s3,"s3://crabby-images/29730/29730aa1421b3c5f450c259524d37d31356524a7" alt=""
カスタムコネクタの作成
続いてカスタムコネクタの作成。[一から作成]を選んで、
data:image/s3,"s3://crabby-images/fdba9/fdba9d7333b69bd647ecd020498e4e58465932b7" alt=""
data:image/s3,"s3://crabby-images/fdba9/fdba9d7333b69bd647ecd020498e4e58465932b7" alt=""
[全般]設定で[ホスト]に「maps.googleapis.com」を入力、
data:image/s3,"s3://crabby-images/c1714/c17147f1edb0e25e03f8f054d62b1c53151eb507" alt=""
data:image/s3,"s3://crabby-images/c1714/c17147f1edb0e25e03f8f054d62b1c53151eb507" alt=""
[セキュリティ]で[認証なし]を選択する。
data:image/s3,"s3://crabby-images/8b7dd/8b7dd340e1ad6c6fb495fabe8414253029518dd6" alt=""
data:image/s3,"s3://crabby-images/8b7dd/8b7dd340e1ad6c6fb495fabe8414253029518dd6" alt=""
※ほんとはAPIキーで作りたいんだけど、[クエリ]を選択してもなぜかクエリにAPIキーが含まれないので、いったん断念。
data:image/s3,"s3://crabby-images/7eacc/7eacc4b95509b9f350ffcb12c1247d83954fede1" alt=""
data:image/s3,"s3://crabby-images/7eacc/7eacc4b95509b9f350ffcb12c1247d83954fede1" alt=""
続いて[定義]の[新しいアクション]でアクションを作成し、[全般]でいい感じの名前を付ける。
data:image/s3,"s3://crabby-images/73028/7302890c43da6e5784754e695bebc4943b2e05d7" alt=""
data:image/s3,"s3://crabby-images/73028/7302890c43da6e5784754e695bebc4943b2e05d7" alt=""
[要求]の[サンプルからのインポート]で、「GET」を選んでURLに、
https://maps.googleapis.com/maps/api/place/textsearch/json?query=XXX
を入力し、インポート。
data:image/s3,"s3://crabby-images/aeb92/aeb92d9c2bf39b2438a7ef9928798f13f6a319ad" alt=""
https://maps.googleapis.com/maps/api/place/textsearch/json?query=XXX
を入力し、インポート。
data:image/s3,"s3://crabby-images/aeb92/aeb92d9c2bf39b2438a7ef9928798f13f6a319ad" alt=""
[query]パラメータの[編集]を選んで、
data:image/s3,"s3://crabby-images/d8472/d847236e4d6bdd4e2fecc16c388a50b930720c8a" alt=""
「必須」にチェックする。
data:image/s3,"s3://crabby-images/097ce/097ce608b92d7a90b97afce70242dd3e677713f1" alt=""
data:image/s3,"s3://crabby-images/097ce/097ce608b92d7a90b97afce70242dd3e677713f1" alt=""
続いて左下の方にある[新しいポリシー]を押して、
data:image/s3,"s3://crabby-images/08bcf/08bcf6e9bc38525076af2c7b3ac69e27025244a4" alt=""
data:image/s3,"s3://crabby-images/08bcf/08bcf6e9bc38525076af2c7b3ac69e27025244a4" alt=""
以下のように設定し、TextSearchが呼ばれるときにAPIキーが設定されるようにする。
data:image/s3,"s3://crabby-images/efc22/efc2254572f82aebda55976edd0202cca929ee39" alt=""
data:image/s3,"s3://crabby-images/efc22/efc2254572f82aebda55976edd0202cca929ee39" alt=""
最後に[応答]の[既定の応答を追加する]から、本文に以下の応答のサンプルを入力する。
data:image/s3,"s3://crabby-images/a4d05/a4d050e20c6f2eb732929559afdded49f220d839" alt=""
data:image/s3,"s3://crabby-images/a4d05/a4d050e20c6f2eb732929559afdded49f220d839" alt=""
// ※結果が多すぎるときは「next_page_token」が返ることもあるが、今回は考慮しない { "html_attributions": [], "results": [ { "formatted_address": "Tokyo, Japan", "geometry": { "location": { "lat": 35.6764225, "lng": 139.650027 }, "viewport": { "northeast": { "lat": 36.4408483, "lng": 141.2405144 }, "southwest": { "lat": 34.5776326, "lng": 138.2991098 } } }, "icon": "XXX", "icon_background_color": "#7B9EB0", "icon_mask_base_uri": "XXX", "name": "Tokyo", "photos": [ { "height": 3024, "html_attributions": [ "XXX" ], "photo_reference": "XXX", "width": 3024 } ], "place_id": "XXX", "reference": "XXX", "types": [ "administrative_area_level_1", "political" ] } ], "status": "OK" }
これでコネクタの作成は完了。
[テスト]から[新しい接続]を選択し、
data:image/s3,"s3://crabby-images/8177d/8177dedfe14ea103a5067018e6aca020393012f4" alt=""
data:image/s3,"s3://crabby-images/8177d/8177dedfe14ea103a5067018e6aca020393012f4" alt=""
接続を追加。
data:image/s3,"s3://crabby-images/567e3/567e3f9f6c0d708953b88c4e8796ceafcf48831f" alt=""
data:image/s3,"s3://crabby-images/567e3/567e3f9f6c0d708953b88c4e8796ceafcf48831f" alt=""
テストを実行すると無事値が返ってくる
data:image/s3,"s3://crabby-images/23327/23327ca5abccfceddb807a99e14fcb131eacd8a8" alt=""
data:image/s3,"s3://crabby-images/23327/23327ca5abccfceddb807a99e14fcb131eacd8a8" alt=""
Power Apps作成
アプリを作成し、カスタムコネクタを追加。
data:image/s3,"s3://crabby-images/04939/04939b0fb1e10906bf9404bfc2a687833aee81e5" alt=""
data:image/s3,"s3://crabby-images/04939/04939b0fb1e10906bf9404bfc2a687833aee81e5" alt=""
検索窓とボタンを用意して、OnSelectで変数に結果を代入。
data:image/s3,"s3://crabby-images/8c15b/8c15b9abb079f499d88d0b50454e4014295761c9" alt=""
data:image/s3,"s3://crabby-images/8c15b/8c15b9abb079f499d88d0b50454e4014295761c9" alt=""
ギャラリーを追加してItemsプロパティに「変数名.results」を入力、
data:image/s3,"s3://crabby-images/3ba95/3ba95c6e5dd6aa4b6eb3c6d6bd0794f782d345cd" alt=""
data:image/s3,"s3://crabby-images/3ba95/3ba95c6e5dd6aa4b6eb3c6d6bd0794f782d345cd" alt=""
名前と緯度経度を表示するように設定。
data:image/s3,"s3://crabby-images/e0d42/e0d426a53b51d8a685e19ff1af6d689dd4068b08" alt=""
data:image/s3,"s3://crabby-images/e1884/e1884f17bb571cb611de32b71126328c8f8c8db0" alt=""
data:image/s3,"s3://crabby-images/e0d42/e0d426a53b51d8a685e19ff1af6d689dd4068b08" alt=""
data:image/s3,"s3://crabby-images/e1884/e1884f17bb571cb611de32b71126328c8f8c8db0" alt=""
アプリを実行すると結果が表示される。
data:image/s3,"s3://crabby-images/070aa/070aac9fa59db3f38cd138bf07f8fde53da3276a" alt=""
data:image/s3,"s3://crabby-images/070aa/070aac9fa59db3f38cd138bf07f8fde53da3276a" alt=""
おまけ:地図コントロールへの表示
地図に表示する際はMapのItemsプロパティにこんな感じの式を入れてあげて、
data:image/s3,"s3://crabby-images/d259d/d259dcf916c82555a3ed2d58f325a620a8fd3207" alt=""
ForAll(result.results, { name:ThisRecord.name, lat:ThisRecord.geometry.location.lat, lng:ThisRecord.geometry.location.lng, address:ThisRecord.formatted_address } )
ItemsAddressとかItemsLabelsとかのプロパティに、以下のプロパティ名を指定する。
data:image/s3,"s3://crabby-images/3bc0a/3bc0aa089f89489314e5014225e35b6f20caef49" alt=""
data:image/s3,"s3://crabby-images/3bc0a/3bc0aa089f89489314e5014225e35b6f20caef49" alt=""
検索すると結果が地図に表示される。
data:image/s3,"s3://crabby-images/20efd/20efdfa994d67a6f4e3a6dedd9c9784f7eee63e1" alt=""
data:image/s3,"s3://crabby-images/20efd/20efdfa994d67a6f4e3a6dedd9c9784f7eee63e1" alt=""