Introducing MapKit JS
Introducing MapKit JS
WWDC 2018
Get a MapKit JS Key
https://developer.apple.com/account
Client-Side Rendering (CSR)
data:image/s3,"s3://crabby-images/1b751/1b7510959d137d3bee5997e5521d61fe1b56198f" alt=""
data:image/s3,"s3://crabby-images/5744f/5744fdc93108d8b7399d9d8ddc38166e9eb9371d" alt=""
Labels-Only Client-Side Rendering (LO-CSR)
Optimized for low-performance configurations
data:image/s3,"s3://crabby-images/d4a7e/d4a7e1be2e8de5bac1c153e1904444ca435884a8" alt=""
Server-Side Rendering (SSR)
No WebGL? No Problem
data:image/s3,"s3://crabby-images/80e60/80e60fb4780e09253abc196285779424293f0773" alt=""
Adaptive Rendering Modes
- An ideal mode for every client configuration
- The best mode is automatically chosen
- Most users will get either CSR or LO-CSR
Using MapKit JS on Your Website
data:image/s3,"s3://crabby-images/fbd19/fbd199b83a23f03afc5bdad308036ca19934d24b" alt=""
Configurable Controls for Every Scenario
data:image/s3,"s3://crabby-images/f6e80/f6e805d1bbeceb169c2b54edb389e2e20e2c1570" alt=""
Moving Around the Map
- Geocoding retuns a coordinate and a region
- Search returns a boundingRegion that encloses its results
- User map.showItems(Items) to set a region which encloses items
Responding to User Interactions
- Following the model of DOM events
data:image/s3,"s3://crabby-images/e8a67/e8a67a6afc608697e8f239763939ed795c86957f" alt=""
Annotations
data:image/s3,"s3://crabby-images/a231a/a231ac613fe8a0236c242d6afe87143594d78c62" alt=""
Marker Annotations
data:image/s3,"s3://crabby-images/f25dd/f25dd380d928580b58c27b2ed18db138ed4a591d" alt=""
data:image/s3,"s3://crabby-images/c765a/c765ab0f7c7d7680841a49fbed47db5db5eb926d" alt=""
Managing Clustter
data:image/s3,"s3://crabby-images/68b57/68b572d49966886c91542e9d0ab8b22bff82ed47" alt=""
data:image/s3,"s3://crabby-images/4f0f2/4f0f239f8f447937afdbf792b4e5e71df6278e20" alt=""
Image Annotation
data:image/s3,"s3://crabby-images/51520/51520123c11dea1ed81859324c4f60305ad0f329" alt=""
Custom Annotation
data:image/s3,"s3://crabby-images/3cacc/3caccf33b998f4d80d3086a373e3b0ae8002bc06" alt=""
Circle Overlay
data:image/s3,"s3://crabby-images/85e08/85e0876245528adccddbb5acede67902db61f777" alt=""
Polyline Overlay
data:image/s3,"s3://crabby-images/4273f/4273fa0d25cd0e7aef7c3a3a5c4e9e0839cd1651" alt=""
Polygon Overlay
data:image/s3,"s3://crabby-images/d9f96/d9f96c311bab1bceb96d8fd1b52d88054ddf5cc7" alt=""
GeoJSON Import
- Create annotations and overlays from GeoJSON geometry
- Customize annotations and overlays through delegate methods
Using Apple Maps Services in MapKit JS
Using any service requires the same 4 steps
1. Create an instance of service object
2. Specify request parameters and options
3. Make a request
4. Handle the response
Geo Coding
data:image/s3,"s3://crabby-images/8d28f/8d28f0633a74b0bc9d885fe79bdd904867bd91b9" alt=""
Search
data:image/s3,"s3://crabby-images/d9510/d951013824ffff90f66a087234c5a668370ce18e" alt=""
Search AutoComplete
data:image/s3,"s3://crabby-images/84191/841915a21f4152e8410f4735328de9ecad3b1fc3" alt=""
Directions
data:image/s3,"s3://crabby-images/87ba5/87ba55a77e1849f220a0acb237e140ddc24b79ad" alt=""