Introducing MusicKit. Media #WWDC17. Tim Parthemore, MusicKit Services Joel Lopes Da Silva, ios Music

Size: px
Start display at page:

Download "Introducing MusicKit. Media #WWDC17. Tim Parthemore, MusicKit Services Joel Lopes Da Silva, ios Music"

Transcription

1 Session Media #WWDC17 Introducing MusicKit 502 Tim Parthemore, MusicKit Services Joel Lopes Da Silva, ios Music 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple.

2 Apple Music Content Artists

3 Apple Music Content Artists Albums

4 Apple Music Content Artists Albums Playlists

5 Apple Music Content Artists Albums Playlists Curators

6 Apple Music Discovery Search

7 Apple Music Discovery Search Charts

8 Apple Music Discovery Search Charts Recommendations

9 MusicKit

10 MusicKit ios Frameworks

11 MusicKit ios Frameworks HTTPS Apple Music API Catalog Services Personalized Services

12 Apple Music API Tim Parthemore, MusicKit Services

13 Request format Resource representations and relationships Limits and pagination Demo Personalized services API Access

14 Apple Music API Catalog

15 Apple Music API Catalog Versioned

16 Apple Music API Catalog Versioned

17 Apple Music API Catalog Versioned Storefront scopes the catalog

18 Apple Music API Catalog /{storefront}/{api} Versioned Storefront scopes the catalog

19 Apple Music API Catalog /{storefront}/{api}?[params] Versioned Storefront scopes the catalog

20 Apple Music API Catalog /{storefront}/{api}?[params] Versioned Storefront scopes the catalog Localized

21 Apple Music API Catalog /{storefront}/{api}?[params] Versioned Storefront scopes the catalog Localized Limits and pagination

22 Apple Music API Catalog /{storefront}/{api}?[params] Versioned Storefront scopes the catalog Localized Limits and pagination Requires a developer token

23 Apple Music API Resource representations id type {"data": [{ "id": " ", "type": "albums", "href": "/v1/catalog/us/albums/ "}]} href

24 Apple Music API Resource representations id type href attributes {"data": [{ "id": " ", "type": "albums", "href": "/v1/catalog/us/albums/ "}]} "/v1/catalog/us/albums/ ", "attributes": { "artwork": { }, "artistname": "Khalid", "discnumber": 1, "genrenames": "playparams": ["R&B/Soul", { }, "Music"], "releasedate": " ", "tracknumber": 15}}]}

25 Apple Music API Resource representations id type href attributes relationships {"data": [{ "id": " ", "type": "albums", "href": "/v1/catalog/us/albums/ "}]} "/v1/catalog/us/albums/ ", "attributes": { }, "relationships": "artwork": { }, { "artistname": "tracks": "Khalid", { "discnumber": "data": 1, [{ },,{ }], "href": /v1/ /albums/ /tracks "/v1/ /albums/ /tracks" }, "genrenames": "playparams": "artists": ["R&B/Soul", { }, { "Music"], "releasedate": "data": " ", [{ }], "tracknumber": "href": 15}}]} /v1/ /albums/ /artists }}}]} "/v1/ /albums/ /artists"}}}]}

26 Apple Music API Resource relationships

27 Apple Music API Resource relationships Album Resource id type href attributes

28 Apple Music API Resource relationships Album Resource tracks id type href attributes

29 Apple Music API Resource relationships Album Resource tracks id type artists href attributes

30 Apple Music API Resource relationships Album Resource tracks id type artists href attributes genres

31 Apple Music API Resource relationships Album Resource id Attributes included tracks Song id type href attributes type href artists attributes genres

32 Apple Music API Resource relationships Album Resource id type href Attributes included tracks Identifiers only artists Song id type href attributes Artist id type href attributes genres

33 Apple Music API Resource relationships Album Resource id type href attributes Attributes included tracks Identifiers only artists Omitted genres Song id type href attributes Artist id type href

34 "relationships": { "tracks": {"data": [{"id": " ", "type": "songs", "href": "/v1/catalog/us/songs/ ", "attributes": { }}, {"id": " ", "type": "songs", "href": "/v1/catalog/us/songs/ " "attributes": { }}], "href": "/v1/catalog/us/albums/ /tracks"}, "artists": {"data": [{"id": " ", "type": "artists", "href": "/v1/catalog/us/artists/ "}], "href": "/v1/catalog/us/albums/ /artists"}}

35 "relationships": { "tracks": {"data": [{"id": " ", "type": "songs", "href": "/v1/catalog/us/songs/ ", "attributes": { }}, {"id": " ", "type": "songs", "href": "/v1/catalog/us/songs/ " "attributes": { }}], "href": "/v1/catalog/us/albums/ /tracks"}, "artists": {"data": [{"id": " ", "type": "artists", "href": "/v1/catalog/us/artists/ "}], "href": "/v1/catalog/us/albums/ /artists"}}

36 "relationships": { "tracks": {"data": [{"id": " ", "type": "songs", "href": "/v1/catalog/us/songs/ ", "attributes": { }}, {"id": " ", "type": "songs", "href": "/v1/catalog/us/songs/ " "attributes": { }}], "href": "/v1/catalog/us/albums/ /tracks"}, "artists": {"data": [{"id": " ", "type": "artists", "href": "/v1/catalog/us/artists/ "}], "href": "/v1/catalog/us/albums/ /artists"}}

37 "relationships": { "tracks": { }, "artists": {"data": [{ "id": " ", "type": "artists", "href": "/v1/catalog/us/artists/ ", "attributes": { "genrenames": ["R&B/Soul","Hip-Hop/Rap", "Rap"] "isgroup": false, "name": "Khalid", } }], "href": "/v1/catalog/us/albums/ /artists"}}

38 "relationships": { "tracks": { }, "artists": {"data": [{ "id": " ", "type": "artists", "href": "/v1/catalog/us/artists/ ", "attributes": { "genrenames": ["R&B/Soul","Hip-Hop/Rap", "Rap"] "isgroup": false, "name": "Khalid", } }], "href": "/v1/catalog/us/albums/ /artists"}}

39 "relationships": { "tracks": { }, "artists": { } "genres": {"data": [{"id": "14", }} "type": "genres", "href": "/v1/catalog/us/genres/14", "attributes": { "name": "Pop"}}, {"id": "34", "type": "genres", "href": "/v1/catalog/us/genres/34", "attributes": { "name": "Music"}], "href": "/v1/catalog/us/albums/ /genres"

40 "relationships": { "tracks": { }, "artists": { } "genres": {"data": [{"id": "14", }} "type": "genres", "href": "/v1/catalog/us/genres/14", "attributes": { "name": "Pop"}}, {"id": "34", "type": "genres", "href": "/v1/catalog/us/genres/34", "attributes": { "name": "Music"}], "href": "/v1/catalog/us/albums/ /genres"

41 Apple Music API Limits and pagination

42 Apple Music API Limits and pagination Song 9 Song 8 Song 7 id Song 6 id Song 5 id type Song 4 id type Song 3 id type Song 2 id href type Song 1 id href type id href type attributes id href type attributes href type attributes href type attributes href attributes href attributes href attributes attributes attributes

43 Apple Music API Limits and pagination

44 Apple Music API Limits and pagination

45 Apple Music API Limits and pagination Song 2 Song 1 id id type type href href attributes attributes

46 Apple Music API Limits and pagination Song 2 Song 1 id id type type href href attributes attributes next

47 Apple Music API Limits and pagination Song 2 Song 1 id id type type href href attributes attributes next /v1/catalog/us/albums/ /tracks?offset=2

48 Apple Music API Limits and pagination

49 Apple Music API Limits and pagination Song 9 Song 8 Song 7 id Song 6 id Song 5 id type Song 4 id type Song 3 id type id href type id href type href type attributes href type attributes href attributes href attributes href attributes attributes attributes

50 Apple Music API Limits and pagination

51 Apple Music API Limits and pagination

52 Apple Music API Limits and pagination Song 4 Song 3 id id type type href href attributes attributes

53 Apple Music API Limits and pagination Song 4 Song 3 id id type type href href attributes attributes next

54 Apple Music API Limits and pagination Song 4 Song 3 id id type type href href attributes attributes next /v1/catalog/us/albums/ /tracks?offset=4

55 {"data": [{ "attributes": { }, "href": "/v1/catalog/us/songs/ ", "id": " ", "relationships": { } "type": "songs" }, { "attributes": { }, "href": "/v1/catalog/us/songs/ ", "id": " ", "relationships": { }, "type": "songs" }], "next": "/v1/catalog/us/albums/ /tracks?offset=2"}

56 Apple Music API Search albums artists songs playlists Album Artists Song Playlist id id id id type type type type href href href href attributes attributes attributes attributes

57 Apple Music API Search albums artists songs playlists Album Artists Song Playlist id id id id type type type type href href href href attributes attributes attributes attributes

58 Apple Music API Search albums Album id type href attributes

59 Demo Apple Music Catalog Search Joel Lopes Da Silva, ios Music

60 Apple Music API Personalized User must have an Apple Music Subscription Required tokens Developer token Music user token

61 API Access Requirements

62 API Access Requirements Apple Developer Program membership

63 API Access Requirements Apple Developer Program membership MusicKit private key

64 API Access Requirements Apple Developer Program membership MusicKit private key Developer token JSON Web Token (RFC 7519) Required in the Authorization header for every Apple Music API request

65 API Access Requirements Apple Developer Program membership MusicKit private key Developer token JSON Web Token (RFC 7519) Required in the Authorization header for every Apple Music API request Security Protect your MusicKit private key Recommend dynamically generating developer tokens

66 API Access More about the developer token

67 API Access More about the developer token Required Headers - Encryption Algorithm (alg), Key Identifier (kid) { } "alg": "ES256", "kid": "ABC123DEFG"

68 API Access More about the developer token Required Headers - Encryption Algorithm (alg), Key Identifier (kid) Required Claims - Issuer/Team ID (iss), Issued at (iat), Expiration (exp) { } { } "alg": "ES256", "kid": "ABC123DEFG" "iss": "DEF123GHIJ", "iat": , "exp":

69 Using MusicKit on ios Joel Lopes Da Silva, ios Music

70 Get access to Apple Music API Allow users to subscribe Play subscription and library content

71 Get access to Apple Music API Allow users to subscribe Play subscription and library content

72 Privacy and User Consent Most users are already signed in No need to authenticate to use MusicKit Requires user consent User consent is per ios device and per app

73

74 Requesting User Consent Needed to access device library or get the music user token Reading authorization status will not prompt Requesting will prompt unless already authorized

75 Requesting User Consent Needed to access device library or get the music user token Reading authorization status will not prompt Requesting will prompt unless already authorized SKCloudServiceController.requestAuthorization { (status: SKCloudServiceAuthorizationStatus) in switch status { case.authorized: case.denied,.restricted: case.notdetermined: } }

76 Fetching Subscription Status

77 Fetching Subscription Status Actual status may be complex

78 Fetching Subscription Status Actual status may be complex We expose three capabilities: Music catalog playback Add to icloud Music Library Can become subscriber

79 Fetching Subscription Status Actual status may be complex We expose three capabilities: Music catalog playback Add to icloud Music Library Can become subscriber Check each capability before corresponding app action

80 Fetching Subscription Status Requires user consent or else you get an error let controller = SKCloudServiceController() controller.requestcapabilities { (capabilities: SKCloudServiceCapability, error: Error?) in let canplay = capabilities.contains(.musiccatalogplayback) let canadd = capabilities.contains(.addtocloudmusiclibrary) let cansubscribe = capabilities.contains(.musiccatalogsubscriptioneligible) }

81 Fetching Storefront Country Code Content identifiers vary across storefronts let controller = SKCloudServiceController() controller.requeststorefrontcountrycode { (countrycode: String?, error: Error?) in if let storefrontcountrycode = countrycode { } }

82 Fetching Storefront Country Code Content identifiers vary across storefronts let controller = SKCloudServiceController() controller.requeststorefrontcountrycode { (countrycode: String?, error: Error?) in if let storefrontcountrycode = countrycode { var topsongsurlcomponents = URLComponents() topsongsurlcomponents.scheme = "https" topsongsurlcomponents.host = "api.music.apple.com" topsongsurlcomponents.path = "/v1/catalog/\(storefrontcountrycode)/charts" topsongsurlcomponents.queryitems = [URLQueryItem(name: "types", value: "songs")] } }

83 Fetching Storefront Country Code Content identifiers vary across storefronts let controller = SKCloudServiceController() controller.requeststorefrontcountrycode { (countrycode: String?, error: Error?) in if let storefrontcountrycode = countrycode { var topsongsurlcomponents = URLComponents() topsongsurlcomponents.scheme = "https" topsongsurlcomponents.host = "api.music.apple.com" topsongsurlcomponents.path = "/v1/catalog/\(storefrontcountrycode)/charts" topsongsurlcomponents.queryitems = [URLQueryItem(name: "types", value: "songs")] } }

84 Fetching Music User Token From your developer token You should cache the token, but don t transfer it across devices Refetch if you get a Forbidden status code (403) from Apple Music API

85 Fetching Music User Token let developertoken = "ey " let controller = SKCloudServiceController() controller.requestusertoken(fordevelopertoken: developertoken) { (usertoken: String?, error: Error?) in if let musicusertoken = usertoken { } }

86 Fetching Music User Token let developertoken = "ey " let controller = SKCloudServiceController() controller.requestusertoken(fordevelopertoken: developertoken) { (usertoken: String?, error: Error?) in if let musicusertoken = usertoken { var request = URLRequest(url: recentlyplayedurl) request.setvalue("bearer \(developertoken)", forhttpheaderfield: "Authorization") request.setvalue(musicusertoken, forhttpheaderfield: "Music-User-Token") } }

87 Fetching Music User Token let developertoken = "ey " let controller = SKCloudServiceController() controller.requestusertoken(fordevelopertoken: developertoken) { (usertoken: String?, error: Error?) in if let musicusertoken = usertoken { var request = URLRequest(url: recentlyplayedurl) request.setvalue("bearer \(developertoken)", forhttpheaderfield: "Authorization") request.setvalue(musicusertoken, forhttpheaderfield: "Music-User-Token") } }

88 Get access to Apple Music API Allow users to subscribe Play subscription and library content

89

90 When to Show the Subscription View? Only if.musiccatalogplayback capability is disabled and.musiccatalogsubscriptioneligible is enabled

91 Configure the Subscription View Choose the main message Optional:.messageIdentifier Default:.join

92 Configure the Subscription View Choose the main message Optional:.messageIdentifier Default:.join Other values:

93 Configure the Subscription View Choose the main message Optional:.messageIdentifier Default:.join Other values:.connect

94 Configure the Subscription View Choose the main message Optional:.messageIdentifier Default:.join Other values:.connect.addmusic

95 Configure the Subscription View Choose the main message Optional:.messageIdentifier Default:.join Other values:.connect.addmusic.playmusic

96 Configure the Subscription View Contextual offer Optional:.iTunesItemIdentifier Type: String Supported content types: songs albums playlists radio stations

97 Configure the Subscription View Other options Key Value.action.subscribe Required.affiliateToken String Optional.campaignToken String Optional

98 // Showing Subscription View let setupviewcontroller = SKCloudServiceSetupViewController() setupviewcontroller.delegate = self let setupoptions: [SKCloudServiceSetupOptionsKey: Any] = [.action: SKCloudServiceSetupAction.subscribe,.messageIdentifier: SKCloudServiceSetupMessageIdentifier.playMusic ] setupviewcontroller.load(options: setupoptions) { (didsucceedloading: Bool, error: Error?) in if didsucceedloading { self.present(setupviewcontroller, animated: true, completion: nil) } })

99 // Showing Subscription View let setupviewcontroller = SKCloudServiceSetupViewController() setupviewcontroller.delegate = self let setupoptions: [SKCloudServiceSetupOptionsKey: Any] = [.action: SKCloudServiceSetupAction.subscribe,.messageIdentifier: SKCloudServiceSetupMessageIdentifier.playMusic ] setupviewcontroller.load(options: setupoptions) { (didsucceedloading: Bool, error: Error?) in if didsucceedloading { self.present(setupviewcontroller, animated: true, completion: nil) } })

100 // Showing Subscription View let setupviewcontroller = SKCloudServiceSetupViewController() setupviewcontroller.delegate = self let setupoptions: [SKCloudServiceSetupOptionsKey: Any] = [.action: SKCloudServiceSetupAction.subscribe,.messageIdentifier: SKCloudServiceSetupMessageIdentifier.playMusic ] setupviewcontroller.load(options: setupoptions) { (didsucceedloading: Bool, error: Error?) in if didsucceedloading { self.present(setupviewcontroller, animated: true, completion: nil) } })

101 // Showing Subscription View let setupviewcontroller = SKCloudServiceSetupViewController() setupviewcontroller.delegate = self let setupoptions: [SKCloudServiceSetupOptionsKey: Any] = [.action: SKCloudServiceSetupAction.subscribe,.messageIdentifier: SKCloudServiceSetupMessageIdentifier.playMusic ] setupviewcontroller.load(options: setupoptions) { (didsucceedloading: Bool, error: Error?) in if didsucceedloading { self.present(setupviewcontroller, animated: true, completion: nil) } })

102 // Showing Subscription View let setupviewcontroller = SKCloudServiceSetupViewController() setupviewcontroller.delegate = self let setupoptions: [SKCloudServiceSetupOptionsKey: Any] = [.action: SKCloudServiceSetupAction.subscribe,.messageIdentifier: SKCloudServiceSetupMessageIdentifier.playMusic ] setupviewcontroller.load(options: setupoptions) { (didsucceedloading: Bool, error: Error?) in if didsucceedloading { self.present(setupviewcontroller, animated: true, completion: nil) } })

103 Get access to Apple Music API Allow users to subscribe Play subscription and library content

104 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer

105 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer Example

106 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer Example Social networking app

107 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer Example Social networking app Fitness app

108 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer Example Social networking app Fitness app Now Playing info reporting Remote commands handling

109 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer Example Social networking app Fitness app Now Playing info reporting Remote commands handling Now Playing app Music app Your app

110 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer Example Social networking app Fitness app Now Playing info reporting Remote commands handling Now Playing app Music app Your app Playback queue ownership Remote-controlling the Music app Your app owns the queue

111 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer Example Social networking app Fitness app Now Playing info reporting Remote commands handling Now Playing app Music app Your app Playback queue ownership Remote-controlling the Music app Your app owns the queue Set queue / Play next / Play later

112 Two Players MPMusicPlayerController systemmusicplayer applicationqueueplayer Example Social networking app Fitness app Now Playing info reporting Remote commands handling Now Playing app Music app Your app Playback queue ownership Remote-controlling the Music app Your app owns the queue Set queue / Play next / Play later Insert items in the middle / Remove items

113 Queue Descriptors Data Use Case

114 Queue Descriptors Data Use Case Media Item MPMediaItem MPMediaItemCollection Device library queries (MPMediaQuery) Media picker

115 Queue Descriptors Data Use Case Media Item MPMediaItem MPMediaItemCollection Device library queries (MPMediaQuery) Media picker Store Queue Store IDs (String) Catalog content (e.g. catalog search)

116 Queue Descriptors Data Use Case Media Item MPMediaItem MPMediaItemCollection Device library queries (MPMediaQuery) Media picker Store Queue Store IDs (String) Catalog content (e.g. catalog search) Play Parameters Dictionaries Personalized content (e.g. recently played)

117 let player = MPMusicPlayerController.systemMusicPlayer player.repeatmode =.all let album: MPMediaItemCollection =... let albumqueuedescriptor = MPMusicPlayerMediaItemQueueDescriptor(itemCollection: album) albumqueuedescriptor.startitem = album.items[3] player.setqueue(with: albumqueuedescriptor) let catalogsongstoreid: String =... let catalogqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [catalogsongstoreid]) player.prepend(catalogqueuedescriptor) let recentlyplayedsongplayparameters: [String: Any] =... let recentlyplayedsongqueuedescriptor = MPMusicPlayerPlayParametersQueueDescriptor( playparametersqueue: [recentlyplayedsongplayparameters] ) player.append(recentlyplayedsongqueuedescriptor)

118 let player = MPMusicPlayerController.systemMusicPlayer player.repeatmode =.all let album: MPMediaItemCollection =... let albumqueuedescriptor = MPMusicPlayerMediaItemQueueDescriptor(itemCollection: album) albumqueuedescriptor.startitem = album.items[3] player.setqueue(with: albumqueuedescriptor) let catalogsongstoreid: String =... let catalogqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [catalogsongstoreid]) player.prepend(catalogqueuedescriptor) let recentlyplayedsongplayparameters: [String: Any] =... let recentlyplayedsongqueuedescriptor = MPMusicPlayerPlayParametersQueueDescriptor( playparametersqueue: [recentlyplayedsongplayparameters] ) player.append(recentlyplayedsongqueuedescriptor)

119 let player = MPMusicPlayerController.systemMusicPlayer player.repeatmode =.all let album: MPMediaItemCollection =... let albumqueuedescriptor = MPMusicPlayerMediaItemQueueDescriptor(itemCollection: album) albumqueuedescriptor.startitem = album.items[3] player.setqueue(with: albumqueuedescriptor) let catalogsongstoreid: String =... let catalogqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [catalogsongstoreid]) player.prepend(catalogqueuedescriptor) let recentlyplayedsongplayparameters: [String: Any] =... let recentlyplayedsongqueuedescriptor = MPMusicPlayerPlayParametersQueueDescriptor( playparametersqueue: [recentlyplayedsongplayparameters] ) player.append(recentlyplayedsongqueuedescriptor)

120 let player = MPMusicPlayerController.systemMusicPlayer player.repeatmode =.all let album: MPMediaItemCollection =... let albumqueuedescriptor = MPMusicPlayerMediaItemQueueDescriptor(itemCollection: album) albumqueuedescriptor.startitem = album.items[3] player.setqueue(with: albumqueuedescriptor) let catalogsongstoreid: String =... let catalogqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [catalogsongstoreid]) player.prepend(catalogqueuedescriptor) let recentlyplayedsongplayparameters: [String: Any] =... let recentlyplayedsongqueuedescriptor = MPMusicPlayerPlayParametersQueueDescriptor( playparametersqueue: [recentlyplayedsongplayparameters] ) player.append(recentlyplayedsongqueuedescriptor)

121 let player = MPMusicPlayerController.systemMusicPlayer player.repeatmode =.all let album: MPMediaItemCollection =... let albumqueuedescriptor = MPMusicPlayerMediaItemQueueDescriptor(itemCollection: album) albumqueuedescriptor.startitem = album.items[3] player.setqueue(with: albumqueuedescriptor) let catalogsongstoreid: String =... let catalogqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [catalogsongstoreid]) player.prepend(catalogqueuedescriptor) let recentlyplayedsongplayparameters: [String: Any] =... let recentlyplayedsongqueuedescriptor = MPMusicPlayerPlayParametersQueueDescriptor( playparametersqueue: [recentlyplayedsongplayparameters] ) player.append(recentlyplayedsongqueuedescriptor)

122 // Advanced Queue Editing using applicationqueueplayer let player = MPMusicPlayerController.applicationQueuePlayer player.perform( queuetransaction: { (mutablequeue: MPMusicPlayerControllerMutableQueue) in // Remove 3rd item mutablequeue.remove(mutablequeue.items[2]) ) // Add song with storeid after 5th item let songstoreid: String =... let songqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [songstoreid]) mutablequeue.insert(songqueuedescriptor, after: mutablequeue.items[4]) }, completionhandler: { (queue: MPMusicPlayerControllerQueue, error: Error?) in }

123 // Advanced Queue Editing using applicationqueueplayer let player = MPMusicPlayerController.applicationQueuePlayer player.perform( queuetransaction: { (mutablequeue: MPMusicPlayerControllerMutableQueue) in // Remove 3rd item mutablequeue.remove(mutablequeue.items[2]) ) // Add song with storeid after 5th item let songstoreid: String =... let songqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [songstoreid]) mutablequeue.insert(songqueuedescriptor, after: mutablequeue.items[4]) }, completionhandler: { (queue: MPMusicPlayerControllerQueue, error: Error?) in }

124 // Advanced Queue Editing using applicationqueueplayer let player = MPMusicPlayerController.applicationQueuePlayer player.perform( queuetransaction: { (mutablequeue: MPMusicPlayerControllerMutableQueue) in // Remove 3rd item mutablequeue.remove(mutablequeue.items[2]) ) // Add song with storeid after 5th item let songstoreid: String =... let songqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [songstoreid]) mutablequeue.insert(songqueuedescriptor, after: mutablequeue.items[4]) }, completionhandler: { (queue: MPMusicPlayerControllerQueue, error: Error?) in }

125 // Advanced Queue Editing using applicationqueueplayer let player = MPMusicPlayerController.applicationQueuePlayer player.perform( queuetransaction: { (mutablequeue: MPMusicPlayerControllerMutableQueue) in // Remove 3rd item mutablequeue.remove(mutablequeue.items[2]) ) // Add song with storeid after 5th item let songstoreid: String =... let songqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [songstoreid]) mutablequeue.insert(songqueuedescriptor, after: mutablequeue.items[4]) }, completionhandler: { (queue: MPMusicPlayerControllerQueue, error: Error?) in }

126 // Advanced Queue Editing using applicationqueueplayer let player = MPMusicPlayerController.applicationQueuePlayer player.perform( queuetransaction: { (mutablequeue: MPMusicPlayerControllerMutableQueue) in // Remove 3rd item mutablequeue.remove(mutablequeue.items[2]) ) // Add song with storeid after 5th item let songstoreid: String =... let songqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [songstoreid]) mutablequeue.insert(songqueuedescriptor, after: mutablequeue.items[4]) }, completionhandler: { (queue: MPMusicPlayerControllerQueue, error: Error?) in }

127 // Advanced Queue Editing using applicationqueueplayer let player = MPMusicPlayerController.applicationQueuePlayer player.perform( queuetransaction: { (mutablequeue: MPMusicPlayerControllerMutableQueue) in // Remove 3rd item mutablequeue.remove(mutablequeue.items[2]) ) // Add song with storeid after 5th item let songstoreid: String =... let songqueuedescriptor = MPMusicPlayerStoreQueueDescriptor(storeIDs: [songstoreid]) mutablequeue.insert(songqueuedescriptor, after: mutablequeue.items[4]) }, completionhandler: { (queue: MPMusicPlayerControllerQueue, error: Error?) in }

128 Timeframe

129 Timeframe

130 Timeframe ios 10.3 Music user tokens (Fall) 1 Storefront country code 2 Catalog playback (with store IDs) *1 API in SKCloudServiceController exists under a different name. *2 As an approximation, you can use Locale.current.regionCode.

131 Timeframe ios 10.3 ios 11 Music user tokens (Fall) 1 Storefront country code 2 Catalog playback (with store IDs) Music user tokens Storefront country code Catalog playback (with store IDs) Catalog playback (with parameters) 3 *1 API in SKCloudServiceController exists under a different name. *2 As an approximation, you can use Locale.current.regionCode. *3 Available in an upcoming ios 11 Beta.

132 Summary Leverage Apple Music s content to keep your users engaged Get music user token from ios Use it to call Apple Music API Use Media Player to control playback

133 More Information

134 Related Sessions What's New in Audio Grand Ballroom B Tuesday 1:50PM What's New in Foundation Hall 2 Wednesday 11:00AM Introducing AirPlay 2 Executive Ballroom Thursday 4:10PM

135 Labs MusicKit Lab Technology Lab G Tue 4:10PM-6:00PM Audio Lab Technology Lab F Tue 4:10PM-6:00PM Foundation Lab Technology Lab C Wed 1:00PM-3:10PM MusicKit Lab Technology Lab F Wed 3:10PM-6:00PM Audio Lab Technology Lab G Thur 1:00PM-3:00PM

136

What s New in watchos

What s New in watchos Session App Frameworks #WWDC17 What s New in watchos 205 Ian Parks, watchos Engineering 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from

More information

Media and Gaming Accessibility

Media and Gaming Accessibility Session System Frameworks #WWDC17 Media and Gaming Accessibility 217 Greg Hughes, Software Engineering Manager Charlotte Hill, Software Engineer 2017 Apple Inc. All rights reserved. Redistribution or public

More information

Getting and Using a MapKit JS Key

Getting and Using a MapKit JS Key #WWDC18 Getting and Using a MapKit JS Key Session 508 Eric Gelinas, MapKit JS 2018 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple.

More information

What s New in Xcode App Signing

What s New in Xcode App Signing Developer Tools #WWDC16 What s New in Xcode App Signing Developing and distributing Session 401 Joshua Pennington Tools Engineering Manager Itai Rom Tools Engineer 2016 Apple Inc. All rights reserved.

More information

Mastering Drag and Drop

Mastering Drag and Drop Session App Frameworks #WWDC17 Mastering Drag and Drop 213 Tom Adriaenssen, UIKit Wenson Hsieh, WebKit Robb Böhnke, UIKit 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted

More information

What s New in CloudKit

What s New in CloudKit System Frameworks #WWDC15 What s New in CloudKit Session 704 Olivier Bonnet icloud Client Eric Krugler icloud Server 2015 Apple Inc. All rights reserved. Redistribution or public display not permitted

More information

Enabling Your App for CarPlay

Enabling Your App for CarPlay Session App Frameworks #WWDC17 Enabling Your App for CarPlay 719 Albert Wan, CarPlay Engineering 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

Introducing Password AutoFill for Apps

Introducing Password AutoFill for Apps Session App Frameworks #WWDC17 Introducing Password AutoFill for Apps Reducing friction for your users 206 Ricky Mondello, ios Engineer 2017 Apple Inc. All rights reserved. Redistribution or public display

More information

Data Delivery with Drag and Drop

Data Delivery with Drag and Drop Session App Frameworks #WWDC17 Data Delivery with Drag and Drop 227 Dave Rahardja, UIKit Tanu Singhal, UIKit 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted without

More information

Content Protection for HTTP Live Streaming

Content Protection for HTTP Live Streaming Media #WWDC15 Content Protection for HTTP Live Streaming Session 502 Roger Pantos HTTP Live Streaming Engineer 2015 Apple Inc. All rights reserved. Redistribution or public display not permitted without

More information

Introduction to Siri Shortcuts

Introduction to Siri Shortcuts #WWDC8 Introduction to Siri Shortcuts Session 2 Ari Weinstein, Siri Willem Mattelaer, Siri 208 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

What s New in tvos #WWDC16. App Frameworks. Session 206. Hans Kim tvos Engineer

What s New in tvos #WWDC16. App Frameworks. Session 206. Hans Kim tvos Engineer App Frameworks #WWDC16 What s New in tvos Session 206 Hans Kim tvos Engineer 2016 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple. Welcome

More information

Seamless Linking to Your App

Seamless Linking to Your App App Frameworks #WWDC15 Seamless Linking to Your App Session 509 Conrad Shultz Safari and WebKit Software Engineer Jonathan Grynspan Core Services Software Engineer 2015 Apple Inc. All rights reserved.

More information

Building Watch Apps #WWDC15. Featured. Session 108. Neil Desai watchos Engineer

Building Watch Apps #WWDC15. Featured. Session 108. Neil Desai watchos Engineer Featured #WWDC15 Building Watch Apps Session 108 Neil Desai watchos Engineer 2015 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple. Agenda

More information

Enhancing your apps for the next dimension of touch

Enhancing your apps for the next dimension of touch App Frameworks #WWDC16 A Peek at 3D Touch Enhancing your apps for the next dimension of touch Session 228 Tyler Fox UIKit Frameworks Engineer Peter Hajas UIKit Frameworks Engineer 2016 Apple Inc. All rights

More information

What s New in Core Data?

What s New in Core Data? Session App Frameworks #WWDC17 What s New in Core? Persisting since 2004 210 Melissa Turner, Core Engineer Rishi Verma, Core Engineer 2017 Apple Inc. All rights reserved. Redistribution or public display

More information

WatchKit In-Depth, Part 2

WatchKit In-Depth, Part 2 App Frameworks #WWDC15 WatchKit In-Depth, Part 2 Session 208 Nathan de Vries watchos Engineer Chloe Chang watchos Engineer 2015 Apple Inc. All rights reserved. Redistribution or public display not permitted

More information

Automatic Strong Passwords and Security Code AutoFill

Automatic Strong Passwords and Security Code AutoFill Session #WWDC18 Automatic Strong Passwords and Security Code AutoFill 204 Chelsea Pugh, ios Engineer Reza Abbasian, ios Engineer Harris Papadopoulos, ios Engineer 2018 Apple Inc. All rights reserved. Redistribution

More information

What s New in Audio. Media #WWDC17. Akshatha Nagesh, AudioEngine-eer Béla Balázs, Audio Artisan Torrey Holbrook Walker, Audio/MIDI Black Ops

What s New in Audio. Media #WWDC17. Akshatha Nagesh, AudioEngine-eer Béla Balázs, Audio Artisan Torrey Holbrook Walker, Audio/MIDI Black Ops Session Media #WWDC17 What s New in Audio 501 Akshatha Nagesh, AudioEngine-eer Béla Balázs, Audio Artisan Torrey Holbrook Walker, Audio/MIDI Black Ops 2017 Apple Inc. All rights reserved. Redistribution

More information

Using Grouped Notifications

Using Grouped Notifications #WWDC18 Using Grouped Notifications Session 711 Michele Campeotto, ios User Notifications 2018 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

Monetize and Promote Your App with iad

Monetize and Promote Your App with iad Media #WWDC15 Monetize and Promote Your App with iad From design to launch Session 503 Carol Teng Shashank Phadke 2015 Apple Inc. All rights reserved. Redistribution or public display not permitted without

More information

Writing Energy Efficient Apps

Writing Energy Efficient Apps Session App Frameworks #WWDC17 Writing Energy Efficient Apps 238 Daniel Schucker, Software Power Engineer Prajakta Karandikar, Software Power Engineer 2017 Apple Inc. All rights reserved. Redistribution

More information

Using and Extending the Xcode Source Editor

Using and Extending the Xcode Source Editor Developer Tools #WWDC16 Using and Extending the Xcode Source Editor Session 414 Mike Swingler Xcode Infrastructure and Editors Chris Hanson Xcode Infrastructure and Editors 2016 Apple Inc. All rights reserved.

More information

What s New in Device Configuration, Deployment, and Management

What s New in Device Configuration, Deployment, and Management Session Distribution #WWDC17 What s New in Device Configuration, Deployment, and Management 304 Todd Fernandez, Senior Manager, Device Management and Server 2017 Apple Inc. All rights reserved. Redistribution

More information

Modern User Interaction on ios

Modern User Interaction on ios App Frameworks #WWDC17 Modern User Interaction on ios Mastering the UIKit UIGesture System Session 219 Dominik Wagner, UIKit Engineer Michael Turner, UIKit Engineer Glen Low, UIKit Engineer 2017 Apple

More information

Introducing the Photos Frameworks

Introducing the Photos Frameworks Media #WWDC14 Introducing the Photos Frameworks Session 511 Adam Swift ios Photos Frameworks 2014 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

Core ML in Depth. System Frameworks #WWDC17. Krishna Sridhar, Core ML Zach Nation, Core ML

Core ML in Depth. System Frameworks #WWDC17. Krishna Sridhar, Core ML Zach Nation, Core ML System Frameworks #WWDC17 Core ML in Depth Krishna Sridhar, Core ML Zach Nation, Core ML 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from

More information

Advances in TVMLKit. App Frameworks #WWDC17. Trevor Cortez, Localization Engineer Parry Panesar, tvos Engineer Jeremy Foo, tvos Engineer

Advances in TVMLKit. App Frameworks #WWDC17. Trevor Cortez, Localization Engineer Parry Panesar, tvos Engineer Jeremy Foo, tvos Engineer Session App Frameworks #WWDC17 Advances in TVMLKit 202 Trevor Cortez, Localization Engineer Parry Panesar, tvos Engineer Jeremy Foo, tvos Engineer 2017 Apple Inc. All rights reserved. Redistribution or

More information

Localizing with Xcode 9

Localizing with Xcode 9 Session Developer Tools #WWDC17 Localizing with Xcode 9 401 Sara Radi, Software Engineer Aya Siblini, Software Engineer Chris Hanson, Software Engineer 2017 Apple Inc. All rights reserved. Redistribution

More information

Vision Framework. Building on Core ML. Media #WWDC17. Brett Keating, Apple Manager Frank Doepke, He who wires things together

Vision Framework. Building on Core ML. Media #WWDC17. Brett Keating, Apple Manager Frank Doepke, He who wires things together Session Media #WWDC17 Vision Framework Building on Core ML 506 Brett Keating, Apple Manager Frank Doepke, He who wires things together 2017 Apple Inc. All rights reserved. Redistribution or public display

More information

Touch Bar Fundamentals

Touch Bar Fundamentals Session App Frameworks #WWDC17 Touch Bar Fundamentals 211 Chris Dreessen John Tegtmeyer 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from

More information

Creating Audio Apps for watchos

Creating Audio Apps for watchos Session #WWDC18 Creating Audio Apps for watchos 504 Neil Desai, watchos Frameworks Engineer 2018 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

Mastering UIKit on tvos

Mastering UIKit on tvos App Frameworks #WWDC16 Mastering UIKit on tvos Session 210 Justin Voss UIKit Engineer 2016 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from

More information

Securing APIs and Microservices with OAuth and OpenID Connect

Securing APIs and Microservices with OAuth and OpenID Connect Securing APIs and Microservices with OAuth and OpenID Connect By Travis Spencer, CEO @travisspencer, @curityio Organizers and founders ü All API Conferences ü API Community ü Active blogosphere 2018 Platform

More information

Insider Tips for using Music Station & Qmusic

Insider Tips for using Music Station & Qmusic Insider Tips for using Music Station & Qmusic I am a music enthusiast, and I... have a huge amount of digital music, including high resolution FLAC files. I hope there could be a huge storage to keep files

More information

Swift API Design Guidelines

Swift API Design Guidelines Developer Tools #WWDC16 Swift API Design Guidelines The Grand Renaming Session 403 Doug Gregor Swift Engineer Michael Ilseman Swift Engineer 2016 Apple Inc. All rights reserved. Redistribution or public

More information

Your Apps and the Future of macos Security

Your Apps and the Future of macos Security #WWDC18 Your Apps and the Future of macos Security Pierre-Olivier Martel, Security Engineering Manager Kelly Yancey, OS Security Garrett Jacobson, Trusted Execution 2018 Apple Inc. All rights reserved.

More information

What s New in Notifications

What s New in Notifications System Frameworks #WWDC15 What s New in Notifications Session 720 Michele Campeotto ios Notifications Gokul Thirumalai Apple Push Notification Service 2015 Apple Inc. All rights reserved. Redistribution

More information

Your Apps and Evolving Network Security Standards

Your Apps and Evolving Network Security Standards Session System Frameworks #WWDC17 Your Apps and Evolving Network Security Standards 701 Bailey Basile, Secure Transports Engineer Chris Wood, Secure Transports Engineer 2017 Apple Inc. All rights reserved.

More information

What's New in Core Spotlight

What's New in Core Spotlight Session System Frameworks #WWDC17 What's New in Core Spotlight Search on macos and ios 231 John Hörnkvist, Spotlight Lyn Fong, Spotlight 2017 Apple Inc. All rights reserved. Redistribution or public display

More information

Securing ArcGIS Server Services An Introduction

Securing ArcGIS Server Services An Introduction 2013 Esri International User Conference July 8 12, 2013 San Diego, California Technical Workshop Securing ArcGIS Server Services An Introduction David Cordes & Derek Law Esri - Redlands, CA Agenda Security

More information

Advances in AVFoundation Playback

Advances in AVFoundation Playback Media #WWDC16 Advances in AVFoundation Playback Waiting, looping, switching, widening, optimizing Session 503 Sam Bushell Media Systems Architect 2016 Apple Inc. All rights reserved. Redistribution or

More information

Getting the Most Out of HealthKit

Getting the Most Out of HealthKit App Frameworks #WWDC16 Getting the Most Out of HealthKit What s new and best practices Session 209 Matthew Salesi ios Software Engineer Joefrey Kibuule ios Software Engineer 2016 Apple Inc. All rights

More information

CloudKit Tips And Tricks

CloudKit Tips And Tricks System Frameworks #WWDC15 CloudKit Tips And Tricks Session 715 Nihar Sharma CloudKit Engineer 2015 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

Extending Your Apps with SiriKit

Extending Your Apps with SiriKit App Frameworks #WWDC16 Extending Your Apps with SiriKit Session 225 Vineet Khosla SiriKit Engineering Diana Huang SiriKit Engineering Scott Andrus SiriKit Engineering 2016 Apple Inc. All rights reserved.

More information

CS193P - Lecture 16. iphone Application Development. Audio APIs Video Playback Displaying Web Content Settings

CS193P - Lecture 16. iphone Application Development. Audio APIs Video Playback Displaying Web Content Settings CS193P - Lecture 16 iphone Application Development Audio APIs Video Playback Displaying Web Content Settings 1 Today s Topics Audio APIs Video Playback Settings Bundles 2 Audio Playback 3 Uses for Audio

More information

CS144: Sessions. Cookie : CS144: Web Applications

CS144: Sessions. Cookie : CS144: Web Applications CS144: Sessions HTTP is a stateless protocol. The server s response is purely based on the single request, not anything else Q: How does a web site like Amazon can remember a user and customize its results?

More information

Convert Technologies ION EZ Vinyl 2 App (ios version)

Convert Technologies ION EZ Vinyl 2 App (ios version) Convert Technologies ION EZ Vinyl 2 App (ios version) Meet the first app in the world to give you the power to record your vinyl music library straight to your device. The Vinyl Recorder app lets you enjoy

More information

Media AI. Adaptive. Intelligent. Architectural Design Document

Media AI. Adaptive. Intelligent. Architectural Design Document Adaptive. Intelligent. Nick Burwell CS 130 Software Development Thursday, December 16, 2004 Table of Contents 1. Introduction...1 2. Architecture...1 3. Component Design...2 3.1 User login & administration...2

More information

Managing Documents In Your ios Apps

Managing Documents In Your ios Apps Session #WWDC18 Managing Documents In Your ios Apps 216 Brandon Tennant, Software Engineer Thomas Deniau, Software Engineer Rony Fadel, Software Engineer 2018 Apple Inc. All rights reserved. Redistribution

More information

CarPlay Audio and Navigation Apps

CarPlay Audio and Navigation Apps #WWDC18 CarPlay Audio and Navigation Apps Tunes and turns Jonathan Hersh, ios Car Experience Albert Wan, ios Car Experience Mike Knippers, ios Car Experience 2018 Apple Inc. All rights reserved. Redistribution

More information

CS193p Spring 2010 Wednesday, May 26, 2010

CS193p Spring 2010 Wednesday, May 26, 2010 CS193p Spring 2010 Announcements Please e-mail if you want to take the option to present your final project next Wednesday. (You will still have until the following Tuesday to turn in your code.) No class

More information

ArcGIS Server and Portal for ArcGIS An Introduction to Security

ArcGIS Server and Portal for ArcGIS An Introduction to Security ArcGIS Server and Portal for ArcGIS An Introduction to Security Jeff Smith & Derek Law July 21, 2015 Agenda Strongly Recommend: Knowledge of ArcGIS Server and Portal for ArcGIS Security in the context

More information

Localization Best Practices on tvos

Localization Best Practices on tvos Session App Frameworks #WWDC17 Localization Best Practices on tvos 248 Joaquim Lobo Silva, Internationalization Software Engineer 2017 Apple Inc. All rights reserved. Redistribution or public display not

More information

How to configure your Triton Player

How to configure your Triton Player How to configure your Triton Player This training document is specifically designed to show you how to manage all of the settings needed to control the look, feel and functionality of your new Triton Digital

More information

What s New in Swift Playgrounds

What s New in Swift Playgrounds Session Developer Tools #WWDC17 What s New in Swift Playgrounds 408 Connor Wakamo, Playgrounds Engineer Grace Kendall, Playgrounds Engineer Najla Bulous, Playgrounds Engineer 2017 Apple Inc. All rights

More information

imessage Apps and Stickers, Part 2

imessage Apps and Stickers, Part 2 App Frameworks #WWDC16 imessage Apps and Stickers, Part 2 Interactive Messages Session 224 Alex Carter Messages Engineer Stephen Lottermoser Messages Engineer 2016 Apple Inc. All rights reserved. Redistribution

More information

Music, Radio & Podcasts

Music, Radio & Podcasts Music, Radio & Podcasts *Buying Music *Streaming Music *Radio Online *Podcasts Buying Music (downloading): itunes Store, Amazon. Single tracks are mostly $1.29. Older music is less. Album prices vary.

More information

ESOTERIC Sound Stream. User s Manual

ESOTERIC Sound Stream. User s Manual ESOTERIC Sound Stream User s Manual Layout Now Playing This is the main screen of the ESOTERIC Sound Stream app. Now Playing: Use to show the current file and control its playback. Playlist: This shows

More information

What s New in ARKit 2

What s New in ARKit 2 Session #WWDC18 What s New in ARKit 2 602 Arsalan Malik, ARKit Engineer Reinhard Klapfer, ARKit Engineer 2018 Apple Inc. All rights reserved. Redistribution or public display not permitted without written

More information

Introducing the Contacts Framework

Introducing the Contacts Framework App Frameworks #WWDC15 Introducing the Contacts Framework For OS X, ios, and watchos Session 223 Bruce Stadnyk ios Contacts Engineer Dave Dribin OS X Contacts Engineer Julien Robert ios Contacts Engineer

More information

AVContentKeySession Best Practices

AVContentKeySession Best Practices Session #WWDC18 AVContentKeySession Best Practices 507 Anil Katti, AVFoundation Engineer 2018 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from

More information

Multitasking Support on the ios Platform

Multitasking Support on the ios Platform Multitasking Support on the ios Platform Priya Rajagopal Invicara (www.invicara.com) @rajagp Multitasking on ios? Multitasking allows apps to perform certain tasks in the background while you're using

More information

Can the app be installed on the device? Does the app behave as designed/desired if there is an incoming SMS?

Can the app be installed on the device? Does the app behave as designed/desired if there is an incoming SMS? 1) Can the app be installed on the device? Does the app behave as designed/desired if there is an incoming call? Does the app behave as designed/desired if there is an incoming SMS? Does the app behave

More information

Building for Voice with Siri Shortcuts

Building for Voice with Siri Shortcuts #WWDC18 Building for Voice with Siri Shortcuts Session 214 Amit Jain, Siri Ayaka Nonaka, Siri 2018 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

What s New in imessage Apps

What s New in imessage Apps Session App Frameworks #WWDC17 What s New in imessage Apps 234 Eugene Bistolas, Messages Engineer Jay Chae, Messages Engineer Stephen Lottermoser, Messages Engineer 2017 Apple Inc. All rights reserved.

More information

FREEGAL MUSIC. Freegal Music offers access to nearly 3 million songs, including Sony Music s catalog of legendary artists.

FREEGAL MUSIC. Freegal Music offers access to nearly 3 million songs, including Sony Music s catalog of legendary artists. FREEGAL MUSIC Freegal Music offers access to nearly 3 million songs, including Sony Music s catalog of legendary artists. In total, the collection is comprised of music from over 10,000 labels with music

More information

USER MANUAL NAIM DESKTOP CLIENT INTERFACE E N G L I S H

USER MANUAL NAIM DESKTOP CLIENT INTERFACE E N G L I S H USER MANUAL NAIM DESKTOP CLIENT INTERFACE E N G L I S H Contents Section Page Contents Introduction 1 1 The Desktop Client Interface 1 1.1 Connecting to The HDX 1 1.2 The Interface Screen 2 1.3 Interface

More information

Introducing CloudKit. A how-to guide for icloud for your Apps. Frameworks #WWDC14. Session 208 Olivier Bonnet CloudKit Client Software

Introducing CloudKit. A how-to guide for icloud for your Apps. Frameworks #WWDC14. Session 208 Olivier Bonnet CloudKit Client Software Frameworks #WWDC14 Introducing CloudKit A how-to guide for icloud for your Apps Session 208 Olivier Bonnet CloudKit Client Software 2014 Apple Inc. All rights reserved. Redistribution or public display

More information

Building Apps with Dynamic Type

Building Apps with Dynamic Type Session App Frameworks #WWDC17 Building Apps with Dynamic Type 245 Clare Kasemset, Software Engineering Manager Nandini Sundar, Software Engineer 2017 Apple Inc. All rights reserved. Redistribution or

More information

Integration Note. Ovation Summit OS Solo & Duet, some OMS(x) Fusion Research, Inc.

Integration Note. Ovation Summit OS Solo & Duet, some OMS(x) Fusion Research, Inc. Integration Note Manufacturer: Model Number(s): Fusion Research Ovation Summit OS Solo & Duet, some OMS(x) Core Module Version: Driver Developer: Fusion Research, Inc. Document Revision Date: 2018-04-13

More information

HLS Authoring Update. Media #WWDC17. Eryk Vershen, AVFoundation Engineer

HLS Authoring Update. Media #WWDC17. Eryk Vershen, AVFoundation Engineer Session Media #WWDC17 HLS Authoring Update 515 Eryk Vershen, AVFoundation Engineer 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple.

More information

Implementing UI Designs in Interface Builder

Implementing UI Designs in Interface Builder Developer Tools #WWDC15 Implementing UI Designs in Interface Builder Session 407 Kevin Cathey Interface Builder Engineer Tony Ricciardi Interface Builder Engineer 2015 Apple Inc. All rights reserved. Redistribution

More information

MEDIAMPLIFY : A Cloud to Cable TV Platform for Music, TV, and Video Dr. Edwin A. Hernandez Chief Technology Officer EGLA COMMUNICATIONS

MEDIAMPLIFY : A Cloud to Cable TV Platform for Music, TV, and Video Dr. Edwin A. Hernandez Chief Technology Officer EGLA COMMUNICATIONS MEDIAMPLIFY : Amplify your reach A Cloud to Cable TV Platform for Music, TV, and Video Dr. Edwin A. Hernandez Chief Technology Officer Mediamplify is the one stop shop multi-platform media distribution

More information

Fix the Missing Tags in your MP3 Files

Fix the Missing Tags in your MP3 Files Fix the Missing Tags in your MP3 Files Use the Free Software FixTunes to Automagically Find, and Correct the Tags missing from your MP3 Collection in itunes, Windows Media Player, etc. Table of Contents

More information

ArcGIS Enterprise Security: An Introduction. Gregory Ponto & Jeff Smith

ArcGIS Enterprise Security: An Introduction. Gregory Ponto & Jeff Smith ArcGIS Enterprise Security: An Introduction Gregory Ponto & Jeff Smith Agenda ArcGIS Enterprise Security Model Portal for ArcGIS Authentication Authorization Building the Enterprise Encryption Collaboration

More information

Queens Library API Requirements Document For e-content Partners

Queens Library API Requirements Document For e-content Partners Queens Library API Requirements Document For e-content Partners Version Date Author Description 1 08/03/2015 Surinder Pal Singh Draft 1.1 08/07/2015 Surinder Pal Singh Revised by Team 1.2 08/19//2015 Surinder

More information

We make Apple Better. Quick Start Guide FEB ONE

We make Apple Better. Quick Start Guide FEB ONE We make Apple Better Quick Start Guide FEB. 2016 ONE App Quick Start Guide Setting up i-flashdrive ONE App. P.3 Home Screen P.4 Settings - Options. Help. Auto Backup.. P.5 Settings - Cloud. 3D Touch Shortcut

More information

What s New in MapKit. App Frameworks #WWDC17. Fredrik Olsson

What s New in MapKit. App Frameworks #WWDC17. Fredrik Olsson Session App Frameworks #WWDC17 What s New in MapKit 237 Fredrik Olsson 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple. MKMapView.mapType.standard

More information

What s New in SiriKit

What s New in SiriKit Session App Frameworks #WWDC17 What s New in SiriKit 214 Sirisha Yerroju, SiriKit Engineer Tin Tran, SiriKit Engineer 2017 Apple Inc. All rights reserved. Redistribution or public display not permitted

More information

Freegal emusic PC user guide

Freegal emusic PC user guide Freegal emusic PC user guide What is Freegal? Freegal is a free music streaming and downloading service. Freegal offers access to about 7 million songs including the Sony Music catalogue. In total the

More information

Finding Bugs Using Xcode Runtime Tools

Finding Bugs Using Xcode Runtime Tools Session Developer Tools #WWDC17 Finding Bugs Using Xcode Runtime Tools 406 Kuba Mracek, Program Analysis Engineer Vedant Kumar, Compiler Engineer 2017 Apple Inc. All rights reserved. Redistribution or

More information

ArcGIS Enterprise Security: An Introduction. Randall Williams Esri PSIRT

ArcGIS Enterprise Security: An Introduction. Randall Williams Esri PSIRT ArcGIS Enterprise Security: An Introduction Randall Williams Esri PSIRT Agenda ArcGIS Enterprise Security for *BEGINNING to INTERMIDIATE* users ArcGIS Enterprise Security Model Portal for ArcGIS Authentication

More information

Connect. explained. Vladimir Dzhuvinov. :

Connect. explained. Vladimir Dzhuvinov.   : Connect explained Vladimir Dzhuvinov Email: vladimir@dzhuvinov.com : Twitter: @dzhivinov Married for 15 years to Java C Python JavaScript JavaScript on a bad day So what is OpenID Connect? OpenID Connect

More information

Working with Metal Overview

Working with Metal Overview Graphics and Games #WWDC14 Working with Metal Overview Session 603 Jeremy Sandmel GPU Software 2014 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

New Ways to Work with Workouts

New Ways to Work with Workouts Session #WWDC18 New Ways to Work with Workouts 707 Niharika Bedekar, Fitness Software Engineer Karim Benhmida, Health Software Engineer 2018 Apple Inc. All rights reserved. Redistribution or public display

More information

Building Visually Rich User Experiences

Building Visually Rich User Experiences Session App Frameworks #WWDC17 Building Visually Rich User Experiences 235 Noah Witherspoon, Software Engineer Warren Moore, Software Engineer 2017 Apple Inc. All rights reserved. Redistribution or public

More information

General. What is Freegal?

General. What is Freegal? General What is Freegal? Freegal is a downloadable music service from your library. All you need is your library card number and, if your library requires it, a PIN. Freegal offers access to about 3 million

More information

Advanced Notifications

Advanced Notifications System Frameworks #WWDC16 Advanced Notifications Session 708 Michele Campeotto ios Notifications 2016 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

Designing Great Apple Watch Experiences

Designing Great Apple Watch Experiences Design #WWDC16 Designing Great Apple Watch Experiences Session 804 Mike Stern User Experience Evangelist 2016 Apple Inc. All rights reserved. Redistribution or public display not permitted without written

More information

Validating HTTP Live Streams

Validating HTTP Live Streams Media #WWDC16 Validating HTTP Live Streams Session 510 Eryk Vershen Media Engineer 2016 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple.

More information

Introducing the Modern WebKit API

Introducing the Modern WebKit API Frameworks #WWDC14 Introducing the Modern WebKit API Session 206 Anders Carlsson Safari and WebKit Engineer 2014 Apple Inc. All rights reserved. Redistribution or public display not permitted without written

More information

Audio Servers S1, H1, H3, H5CD and Others

Audio Servers S1, H1, H3, H5CD and Others Integration Note Manufacturer: S1Digital Model Number(s): Core Module Version: Comments: Audio Servers S1, H1, H3, H5CD and Others g! 6.0 and above Document Revision Date: 3/9/2016 S1Digital Software 2.2-2.4.x

More information

COPYRIGHTED MATERIAL. chapter 1. How Do I Configure My iphone? 2

COPYRIGHTED MATERIAL. chapter 1. How Do I Configure My iphone? 2 chapter 1 How Do I Configure My iphone? 2 Customizing the Home Screen to Suit Your Style 4 Creating an app folder 5 Adding a Safari web clip to the Home screen 6 Resetting the default Home screen layout

More information

Building Faster in Xcode

Building Faster in Xcode #WWDC18 Building Faster in Xcode Session 408 David Owens, Xcode Engineer Jordan Rose, Swift Engineer 2018 Apple Inc. All rights reserved. Redistribution or public display not permitted without written

More information

Getting Published in Apple News

Getting Published in Apple News Media #WWDC16 Getting Published in Apple News Session 502 Ryan Griggs Apple News 2016 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple.

More information

What s New in tvos 12

What s New in tvos 12 #WWDC18 What s New in tvos 12 Session 208 Hans Kim, tvos Engineering 2018 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission from Apple. Agenda Agenda

More information

Getting Started with CareKit

Getting Started with CareKit App Frameworks #WWDC16 Getting Started with CareKit Session 237 Umer Khan Software Engineer 2016 Apple Inc. All rights reserved. Redistribution or public display not permitted without written permission

More information

Display Audio Operation

Display Audio Operation Display Audio Operation Use simple gestures including touching, swiping, and scrolling to operate certain audio functions. Some items may be grayed out during driving to reduce the potential for distraction.

More information

Accessibility on ios. Developing for everyone. Frameworks #WWDC14. Session 210 Clare Kasemset ios Accessibility

Accessibility on ios. Developing for everyone. Frameworks #WWDC14. Session 210 Clare Kasemset ios Accessibility Frameworks #WWDC14 Accessibility on ios Developing for everyone Session 210 Clare Kasemset ios Accessibility 2014 Apple Inc. All rights reserved. Redistribution or public display not permitted without

More information