What’s New in tvOS 12
What’s New in tvOS 12
WWDC 2018
Password AutoFill
- Ensure QuickType bar appears
- Get your app’s credentials on the QuickType bar
- Enable 1-tap sign in
data:image/s3,"s3://crabby-images/df107/df107d87af9bf119c7dbb0b43b45a3bebc4f7f0d" alt=""
data:image/s3,"s3://crabby-images/2b6f8/2b6f86fe43fd4ded855609fb0445a8be3607a70e" alt=""
Ensure QuickType Bar Appears
Adopt UITextContentType
- tvOS wil try to automatically detect username and password fields
- Explicitly mark the text field types
data:image/s3,"s3://crabby-images/80c82/80c82e70062e08507150a75250be224e3ca6f487" alt=""
QuickType Bar Suggestions
Associated Domains
- Powers many other features
- Strong relationship between app and website
- Introducing Password AutoFill for Apps ( WWDC 2017 )
data:image/s3,"s3://crabby-images/483e6/483e63dff8a775cba2862bb3b293ad2a4291269c" alt=""
Enable 1-Tap Sign In
Implement preferredFocusEnvironments
- AutoFill will perform a focused button’s action after filling
- Implement
preferredFocusEnvironments
to provide your login button for focus
data:image/s3,"s3://crabby-images/b55d8/b55d88a78f916a0defeb05cd66690b1281776a0a" alt=""
data:image/s3,"s3://crabby-images/653fa/653fa6301cc68831062c7c2b796c430e8ca9fabd" alt=""
Focus on tvOS
data:image/s3,"s3://crabby-images/45855/45855b017c5ef9bb398900df7856733752f71bc0" alt=""
Focus Engine now supports apps regardless of how they are rendered ( new )
data:image/s3,"s3://crabby-images/906fd/906fd7b267b4c2ab8c56622b3a07445050f59eb4" alt=""
What’s Included
- State management
- Focus item geometry
- Accessibility
- tvOS’s native feel
- Momentum during swipes
- Scrolling inertia
- Focus movement hinting
New Focus Features
data:image/s3,"s3://crabby-images/3b95f/3b95fcf7e5c02f8b722221c7e1f8232b68e87735" alt=""
UIFocusEnvironment ( new )
- Hooking into the focus engine
data:image/s3,"s3://crabby-images/331c7/331c79bd86feae79d3392b7d0ef325ec0b1446a3" alt=""
- Controlling and reacting to focus updates
data:image/s3,"s3://crabby-images/83081/8308168e06f1382cbf13675789e624e352453f28" alt=""
- Focus updating functions
data:image/s3,"s3://crabby-images/8972d/8972de4fc48d45ee87626a943af585b21994db86" alt=""
data:image/s3,"s3://crabby-images/2cad1/2cad1d7fb62d0a0c958afc7cfa89d8158b6753c6" alt=""
UIFocusItemContainer ( new )
- Provide a
coordinateSpace
- UIView provides itself - Implement
focusItems(in rect: CGRect)
rect
is expressed incoordinateSpace
- Focus Items’ frames must also be expressed in
coordinateSpace
data:image/s3,"s3://crabby-images/2cb03/2cb0330eac1ec51b4ee36dd6f87ca541952e0dad" alt=""
UIFocusItem ( new )
- Inherits from UIFocusEnvironment
- Implement
canBecomeFocused
- Implement
didHintFocusMovment(_ hint: UIFocusMovmentHint)
- Provide a frame
- Same coordinate space as its containing UIFocusItemContainer
data:image/s3,"s3://crabby-images/74efb/74efb4d4a09da1283a8949de91675a4d54d121e3" alt=""
UIFocusMovementHint ( new )
data:image/s3,"s3://crabby-images/78177/78177532b7f836c25d78ee32bed8fa9e2d4ba69a" alt=""
UIFocusItemScrollableContainer ( new )
- Inherits from UIFocusItemContainer
- 3 additional properties
data:image/s3,"s3://crabby-images/9d00f/9d00f8816f802b4c9de9e931bfa10b292b0667a0" alt=""
contentOffset
is set automatically
data:image/s3,"s3://crabby-images/cdcd2/cdcd21bb43be265ede01551e83dec4a6808a0c3c" alt=""
Accessibility
- It’s incredibly easy !
- Implement
UIFocusItemContainer.focusItems(in rect: CGRect)
- Set
accessibilityLabel
andaccessibilityHint
on your Focus Items - What’s New in Accessibility ( WWDC 2016 )
Demo 1
data:image/s3,"s3://crabby-images/5cdec/5cdec795c1c2d8807f3beb08831a7ff0da598973" alt=""
data:image/s3,"s3://crabby-images/fa9da/fa9dacb554b39af2951de9a1908431ad37bb28c6" alt=""
Demo 2
data:image/s3,"s3://crabby-images/8d720/8d720e40bc1badc6f175b58c25488ec98d3e0cd0" alt=""
data:image/s3,"s3://crabby-images/85d45/85d45837a5a3055e63d0c0b030474dccfb8ed9e7" alt=""
Demo 3
data:image/s3,"s3://crabby-images/5be56/5be5680ce5bea8e5eeea2332aded29a8117b0326" alt=""
data:image/s3,"s3://crabby-images/79d1a/79d1a47190b1dcb566266ec00d4fb5dd9daece44" alt=""
Text Scrolling ( new )
Marquee
- Present variable-length strings in fixed geometry
- Visually highlights current focus
data:image/s3,"s3://crabby-images/27971/27971069c8e875dc499398ab3b30fef6cceaa8c6" alt=""
data:image/s3,"s3://crabby-images/f364b/f364b116fd3216c4c9092bf518a4ef04f3b1a35b" alt=""
data:image/s3,"s3://crabby-images/2f2e0/2f2e043cefbd76a475204d1641c78f868af8932f" alt=""
TVUIKit ( new )
- Easy adoption of common UI patterns
- Built-in support for localization and accessibility
- Developer Beta
data:image/s3,"s3://crabby-images/56296/56296548935b61686eb564a08ccab752e74add09" alt=""
TVPosterView ( new )
data:image/s3,"s3://crabby-images/1191d/1191dec5ed1eee26f37e918fb3c8babcb2f00cde" alt=""
data:image/s3,"s3://crabby-images/ad001/ad001cd05c3526f33ef5178a105d968d376ff7d0" alt=""
data:image/s3,"s3://crabby-images/fa8c7/fa8c746590455562d641a74387e518ae40108cf8" alt=""
TVCaptionButtonView ( new )
data:image/s3,"s3://crabby-images/c63ee/c63ee39c2b698518adc841b976162353e2c5bc60" alt=""
data:image/s3,"s3://crabby-images/df262/df2629c8f747a4dfe4c3f7a79702f6822b6e8c67" alt=""
data:image/s3,"s3://crabby-images/ee378/ee378d2ca95584fbd499b1015f131df04e2fa313" alt=""
TVCardView ( new )
data:image/s3,"s3://crabby-images/181ee/181ee69b8f4843554f887fd5819d60ed10a2adcc" alt=""
data:image/s3,"s3://crabby-images/b899f/b899f9c84409e5e6d0435ccf39a9718b71df29e4" alt=""
data:image/s3,"s3://crabby-images/1224b/1224be238be8821b672bba8069522b1805dbc352" alt=""
TVMonogramView ( new )
data:image/s3,"s3://crabby-images/eca02/eca022c91a2f6c8c776a409adf434969c138f4a7" alt=""
data:image/s3,"s3://crabby-images/92b5f/92b5f0e8e8a839df85dfbd20e0a9563dc5f931bc" alt=""
data:image/s3,"s3://crabby-images/4a23b/4a23bf8ef41a481552bebf1f4e674a5ede127705" alt=""
Common Theme ( new )
data:image/s3,"s3://crabby-images/c45bd/c45bde93ec7fe150e48f79b2e0e03ce34b9f8ae5" alt=""
TVLockupView ( new )
- Custom content
- Your own widget that responds to focus
- Customize 4 special purpose subclasses
- TVPosterView
- TVCaptionButtonView
- TVCardView
- TVMonogramView
data:image/s3,"s3://crabby-images/4d241/4d241ea1b0c08c22373e54769f9395e3e5745966" alt=""
data:image/s3,"s3://crabby-images/55526/55526ce26efad23e26ba6b9645eb578c8521b054" alt=""
data:image/s3,"s3://crabby-images/4a209/4a209cba8167cf4f8db63892c6faac711f7653be" alt=""
TVDigitEntryViewController
data:image/s3,"s3://crabby-images/67b59/67b593df0a51bdd260d248b28f2bac97145fa5ac" alt=""
data:image/s3,"s3://crabby-images/a7880/a7880dc4c14b5bf896124d1a0ee817f3ebd0aff9" alt=""
data:image/s3,"s3://crabby-images/bae9b/bae9b51579fde558796505cb6e551d087831eaf8" alt=""
Demo 1
data:image/s3,"s3://crabby-images/7f652/7f652373a780936afaa18e50eabe7f71ec6299a2" alt=""
data:image/s3,"s3://crabby-images/18e0c/18e0c4894fa45482865edc99448164b768b11f9f" alt=""
Demo 2
data:image/s3,"s3://crabby-images/84b51/84b513a44267f55f9c0a9358276f4e4ee1d59d2f" alt=""
data:image/s3,"s3://crabby-images/2c9e5/2c9e59db03ac83497dcff81668d7b907eb4f232e" alt=""