Accessible Drag and Drop
Accessible Drag and Drop
WWDC 2018
Drag and Drop Refresher
- Interactions are hosted by views
- Starting a drag:
UIDragInteration
- Accepting a drop:
UIDropInteraction
Accessible Drag and Drop Concepts
- Your accessibility element might not host interactions directly
- Subviews might host interactions
- Element might descend from a view that hosts interactions - Solution
- Specify logical drags and drops to Accessibility
UIAccessibilityDragging
- Logical drag sources and drop points
- Drag sources describe where to start drags
- Drop points describe where to drop - Users activate drags and drops like custom actions
- Drags and drops often exposed automatically
- Assigned default name
- Only interactions in an element’s subtree are exposed - Allows exposing exactly the interactions that make sense
- Allows specifying a specific name for each
- Implement for the best experience
data:image/s3,"s3://crabby-images/44dd3/44dd318fa5f1cc50e6df25c02c7d01bc77f8e8c1" alt=""
Exposing an Ancestor’s Drag
Example
- Bar graph built with
CALayer
- Drag and drop bar data by dragging the bar itself
data:image/s3,"s3://crabby-images/7966e/7966e15477ad942452203b654a1e7a77fa7195fd" alt=""
data:image/s3,"s3://crabby-images/eadf3/eadf3d99f6342f19761fe4eac405dcbde0fdf2b7" alt=""
UIAccessibilityLocationDescriptor
- Names and describes where to activate an interaction
- A point
- In a view
- With a name
data:image/s3,"s3://crabby-images/ee3a8/ee3a8203f5080e5545ff27b4ecb2c0b588948800" alt=""
accessibilityDragSourceDescriptors
- Expose drag sources logically associated with the element
data:image/s3,"s3://crabby-images/454d6/454d67d1347b71ed42779ecc51bc20735fa1bd6a" alt=""
data:image/s3,"s3://crabby-images/00ba3/00ba3f6654052323c27a7bdd1bf5aba34b0750c8" alt=""
accessibilityDropPointDescriptors
- Expose drop points logically associated with this element
⚠️ Descriptors must reference the views with the relevant interaction ⚠️
Exposing Multiple Drops
Example
- Contact card
- Card is one element
- Drop into multiple “well” in the card
data:image/s3,"s3://crabby-images/0aad4/0aad43664e98306f3c6204822280b19228d33409" alt=""
data:image/s3,"s3://crabby-images/3469c/3469c799ab6b71857182be070ec1ace8755d4cc3" alt=""