Amazon Location Service入門ワークショップ-マップの操作
2023/02/05
目次
関連記事
- Amazon Location Service入門ワークショップの前提環境準備
- Amazon Location Service入門ワークショップ-ジオコーディング
- Amazon Location Service入門ワークショップ-ルート計算
- Amazon Location Service入門ワークショップ-トラッカー
- Amazon Location Service入門ワークショップ-ジオフェンス
マップのテスト
ワークショップ手順では新しいマップをマネジメントコンソールからマップを新規作成して、configuration.jsを変更となってますが、Cognito IDプールのResourceのARNを工夫しないとですね。
なので、後でWorkshopMapをWorkshopMap*に変更しました。
1 2 3 4 5 6 |
export const MAP = { NAME: "WorkshopMap-2", STYLE: "VectorEsriStreets", resource }; |
動的なマップの変更
「試してみよう
動的にマップのスタイルを変更できるサンプルコードはここにあります」
にチャレンジしました。
マップスタイル変更ラジオボタンを配置して変更できるようにしました。
「試してみよう」の先にあるサンプルコードを参照しました。
変更した箇所は次です。
MapControl.jsxとMapControl.module.cssを追加
サンプルコードからコピペでcomnentsディレクトリに追加しました。
configuration.jsの変更
MAPをMAPSとして配列に変更しました。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
//export const MAP = { // NAME: "WorkshopMap-2", // REQUIRED - Amazon Location Service map resource name // STYLE: "VectorEsriNavigation", // REQUIRED - String representing the style of map resource //}; export const MAPS = [ { NAME: "WorkshopMap", // REQUIRED - Amazon Location Service Map resource name STYLE: "VectorEsriStreets", // REQUIRED - String representing the style of map resource LABEL: "WorkshopMap", // REQUIRED - Text to be displayed for the map in the layer control box }, { NAME: "WorkshopMap-2", // REQUIRED - Amazon Location Service Map resource name STYLE: "VectorEsriNavigation", // REQUIRED - String representing the style of map resource LABEL: "WorkshopMap-2", // REQUIRED - Text to be displayed for the map in the layer control box }, ]; |
App.jsxに必要なモジュールとコードを追加
1 2 3 4 5 |
import React, { useState, useEffect, useMemo } from "react"; import Amplify, { Auth,Geo } from "aws-amplify"; import { IDENTITY_POOL_ID, REGION, MAPS, PLACE } from "./configuration"; import MapControl from "./components/MapControl"; |
useMemoとGeoを追加。
MAPをMAPSに変更。
MapControlを追加。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
maps: { items: { //[MAP.NAME]: { // REQUIRED - Amazon Location Service Map resource name // style: MAP.STYLE, // REQUIRED - String representing the style of map resource //}, //}, //default: MAP.NAME, // REQUIRED - Amazon Location Service Map resource name to set as default [MAPS[0].NAME]: { // REQUIRED - Amazon Location Service Map resource name style: [MAPS[0].STYLE], // REQUIRED - String representing the style of map resource }, [MAPS[1].NAME]: { // REQUIRED - Amazon Location Service Map resource name style: [MAPS[1].STYLE], // REQUIRED - String representing the style of map resource }, }, default: [MAPS[0].NAME], // REQUIRED - Amazon Location Service Map resource name to set as default }, |
mapsを複数マップに対応。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
const geoConfig = useMemo(() => Geo.getDefaultMap(), []); const [transformRequest, setTransformRequest] = useState(); const styleProps = useMemo( () => ({ height: "100vh", position: "relative", width: "100vw", }), [] ); const [visibleMap, setVisibleMap] = useState(geoConfig.mapName[0]); const handleMapChange = (map) => { setVisibleMap(map); }; |
必要な定数を追加。
1 2 3 |
//mapStyle={MAP.NAME} mapStyle={visibleMap} |
mapStyleを変更
1 2 3 4 5 6 7 8 9 10 11 |
<NavigationControl position="bottom-right" showCompass={false} style={{ left: 20, top: 20 }} /> <MapControl maps={Geo.getAvailableMaps()} visibleMap={visibleMap} onMapChange={handleMapChange} /> |
NavigationControlを変更して、MapControlを追加。
起動時の座標変更
「チャレンジ
現在、起動時のマップはバンクーバーに設定されています。別の地点に変更してみましょう。」
にチャレンジしました。
App.jsxを変更
1 2 3 4 5 6 7 8 |
initialViewState={{ //longitude: -123.1187, //latitude: 49.2819, longitude: -122.333144, latitude: 47.626353, zoom: 11, }} |
initialViewStateの座標を変えました。
検索してピンとポップアップを確認する
左上の検索フィールドに住所を入力して検索結果のピンからポップアップを確認しました。
ポリゴン
任意の範囲を半透明グレーで表示できました。
ルート検索
Routesを押下して、2つのポイントを追加して、[Caluculate]を押下しました。
ひっかけ橋から大阪城までウォーキングで54分との結果が出ました。
歩けますね。
最後までお読みいただきましてありがとうございました!
「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル 改訂第2版」という本を書きました。
「AWS認定資格試験テキスト AWS認定クラウドプラクティショナー 改訂第3版」という本を書きました。
「ポケットスタディ AWS認定 デベロッパーアソシエイト [DVA-C02対応] 」という本を書きました。
「要点整理から攻略するAWS認定ソリューションアーキテクト-アソシエイト」という本を書きました。
「AWSではじめるLinux入門ガイド」という本を書きました。
開発ベンダー5年、ユーザ企業システム部門通算9年、ITインストラクター5年目でプロトタイプビルダーもやりだしたSoftware Engineerです。
質問はコメントかSNSなどからお気軽にどうぞ。
出来る限りなるべく答えます。
このブログの内容/発言の一切は個人の見解であり、所属する組織とは関係ありません。
このブログは経験したことなどの共有を目的としており、手順や結果などを保証するものではありません。
ご参考にされる際は、読者様自身のご判断にてご対応をお願いいたします。
また、勉強会やイベントのレポートは自分が気になったことをメモしたり、聞いて思ったことを書いていますので、登壇者の意見や発表内容ではありません。
ad
ad
関連記事
-
AWS CLIでS3マルチパートアップロードを確認
AWS CLI を使用して、Amazon S3 にファイルをマルチパートアップロ …
-
AWS Global Acceleratorでアクセラレーターを作成する
バージニア北部、東京、大阪のEC2インスタンスをエンドポイントにして作成してみま …
-
既存のAWSアカウントをAWS Control Towerに追加
Account Factoryからは既存アカウントは追加できない? AWS Co …
-
API Gateway 作成済REST APIの定義をSwaggerの形式でエクスポート
SAMで似たようなAPIを作りたくて、エクスポートしました。 Swaggerは、 …
-
AWS Cost Explorerの履歴を38ヶ月とリソース別コストを見られるように設定しました
AWS Cost Explorer がより詳細な履歴データの提供を開始 知らなか …
-
AWS Lambda(Python)で生成した文字をAmazon Connectで音声を設定して発信する
Amazon Connectから発信する電話の音声を動的に設定します。 Lamb …
-
Amazon EC2のスクリーンショットとは
ドキュメント見てたらAmazon EC2でスクリーンショットって機能があったので …
-
Amazon Linux2のCloud9でPython CDKのモジュールインストール
AMIがCloud9AmazonLinux2-2021-02-02T16-48の …
-
AWS LambdaでS3 Select
RDSスナップショットをS3にエクスポートした、Parquetフォーマットのデー …
-
kintoneでEveryoneに権限が設定されているアプリをAWS Lambdaで一括チェックする
こないだ、kintone Cafeでユーザーが自由に作成している環境だと、どんな …