data:image/s3,"s3://crabby-images/81c79/81c79d58908268c6b357fb73028c24b699bc4b2e" alt="Build Interactive Map Control On Canvas App Build Interactive Map Control On Canvas App"
Build Interactive Map Control On Canvas App
Step1: Enable Geospatial service.
Admin Center –> Environments –>”Your Environment” –>Settings –>Features
data:image/s3,"s3://crabby-images/eb289/eb289b66d8a3e29f826f90575a01e6356edd93ef" alt=""
Step2: Adding Map control into screen
data:image/s3,"s3://crabby-images/a079f/a079fe94bb43e1c08ab48692bf9515f4c1315064" alt=""
Step3:
Here my backend database is Dataverse.
Table Name: Account
Collection Used: colAccountData, colRouteCollection
Usage:
colAccountData : To collect all the account address from Account Table.
colRouteCollection: To collect account address which will be used to show routing information.
Step 4: Here I’m loading collection on button click
- ClearCollect(colAccountData,Accounts); –> Load entire table into collection.
- ClearCollect(colAccountData,AddColumns(Accounts,”Color”,”red”,”AccountIcon”,”car”,”AccountName”,’Account Name’)); à Adding three more columns into our collection (Color,AccountIcon,AccountName).
Note: If your table already contains color or icon column you can skip b.
- ClearCollect(colRouteCollection,Filter(colAccountData,’Address 1: City’=”Lynnwood”||’Address 1: City’=”Renton”||’Address 1: City’=”Redmond”)); –> Planning to show route direction for this particular address alone. You can apply your logic here based on requirement.
ClearCollect(colAccountData,Accounts);
ClearCollect(colAccountData,AddColumns(Accounts,"Color","red","AccountIcon","marker","AccountName",'Account Name'));
ClearCollect(colRouteCollection,Filter(colAccountData,'Address 1: City'="Lynnwood"||'Address 1: City'="Renton"||'Address 1: City'="Redmond"));
Step 5: Select your map source
data:image/s3,"s3://crabby-images/a5934/a5934a43436d5670d9bdc64dc820d0f41ee5e027" alt=""
Step 6: Select ItemAddresses property under map control. Here I’m using “address1_composite” column as an input address for the map control.
data:image/s3,"s3://crabby-images/dbfea/dbfeaa71668c94e0ecfecdd71c74c1e1b2345f43" alt=""
Note: you can use latitude, longitude property as well to locate address.
Eg: ItemsLatitudes:”Your Latitude Column Name”
ItemLongitudes:”Your Longitude Column Name”
Now you can find pins located on the map.
data:image/s3,"s3://crabby-images/9a3db/9a3db59145e078d15224ae16a347d4f4bdb3bdc0" alt=""
Step 7: How to change pin color.
In this example I’m using static color for all the pins.
data:image/s3,"s3://crabby-images/4d4c7/4d4c75eb036b5d991e188caa835776a09ca58c37" alt=""
ItemsColors:”Your Color Column Name”
data:image/s3,"s3://crabby-images/86df0/86df07867e85e81288920a684f6399f3eb311566" alt=""
Note: you can apply your logic while adding color column into collection to show different color based on requirement.
data:image/s3,"s3://crabby-images/193fc/193fc75bce785c196797b77f9c0acb2fe2d704f4" alt=""
Step 8: How to change pin icon.
Here I’m using static Icon for all the pins.
data:image/s3,"s3://crabby-images/aab32/aab32eec1934b074f922ee8fb4a21cb875b97ed0" alt=""
data:image/s3,"s3://crabby-images/2b470/2b470bf9b775f7719edb256b1cc5e64819f2bc50" alt=""
Some of the icons you can use in canvas app.
data:image/s3,"s3://crabby-images/c4ced/c4cedcd2f1e8a5cf502695ba787e1ff941740d8f" alt=""
Refer this URL for different icons:
Step 9: Show label for each pins.
Here I’m showing account name on the label. You can map different column.
data:image/s3,"s3://crabby-images/64501/64501b14808b723a41f00b62350ee3bff2f3f055" alt=""
data:image/s3,"s3://crabby-images/d14b5/d14b50faf9ad980fc4ebbe17b9e566e41c003347" alt=""
Step 10: Show Info card for each pin when user clicks/hover
You can show multiple fields data in info card by adding fields in the map control. Refer below image.
data:image/s3,"s3://crabby-images/c9453/c9453ec7e6f0252b46fe9d224391055d2b1cff82" alt=""
Step 11: Cluster near by addresses
Here you can cluster the near by address into single point.
data:image/s3,"s3://crabby-images/d78f1/d78f166701c8b7ce83919d131d54f9fd34b4b977" alt=""
data:image/s3,"s3://crabby-images/35329/3532952cde8e48ea95c45b9988e5db49b3a04af4" alt=""
How to show Route information
Here I’m planning to show route direction for particular addresses alone so I’m using filter. You can apply your logic here based on requirement.
ClearCollect(colRouteCollection,Filter(colAccountData,'Address 1: City'="Lynnwood"||'Address 1: City'="Renton"||'Address 1: City'="Redmond"));
Step 1: Assign your route collection to RouteWaypoints_Items
data:image/s3,"s3://crabby-images/91224/9122433f614d2a1d5fabba582161b2226372083d" alt=""
Step 2: Select RouteWayPointsAddresses property under map control. Here I’m using “address1_composite” column as an input address for the map control.
data:image/s3,"s3://crabby-images/804ca/804caf6f74812b27ea662105ed0a62a05c802db1" alt=""
Then, enable routing option on map control.
data:image/s3,"s3://crabby-images/364ef/364ef79bdd7620adbc3ac9571173f962682f19bd" alt=""
You optimize the route by distance or time.
Now, your map will look like this
data:image/s3,"s3://crabby-images/e821d/e821d507e485a9379e03267e7e5b218698616139" alt=""
Happy Building 🙂