Live Screen Broadcast with ReplayKit
Live Screen Broadcast with ReplayKit
WWDC 2018
ReplayKit
- Capture
- Screen visuals
- App audio
- Microphone input - Record and share
- Broadcast live
- HD quality capture
- Low latency
- Low performance impact
- Minimal power usage
- Privacy safeguards
Live Broadcast
- Broadcast live to 3rd party broadcast services (ex. Facebook)
- Stream audio and visuals directly from device
- Provide commentary with microphone and camera (iOS)
- Content is secure and only accessible to the broadcast service
- Usage examples
- Stream gameplay to Mobcrush or YouTube
- Mirror screen on a WebEx call
- Work with customer support via TeamViewerQS
- Stream a drawing app to Facebook
ReplayKit vs ReplayKit 2
data:image/s3,"s3://crabby-images/7b972/7b972ede5688ea8c7798e76cdca5fa5eb6c6ee50" alt=""
In-App Broadcast
- Your app or game
- Provides the content — visuals and audio
- Starts and stops the boardcast - Broadcaster app
- Provides sign-in and upload extensions
- Streams content to their network
iOS System Broadcast
- Broadcasts all onscreen activity (and sounds)
- Start and stop from Control Center
- Systemwide, continuous session
- Home screen
- Moving app to app - Build-in to iOS 11 and above
data:image/s3,"s3://crabby-images/db857/db857bb3963c3ceae6e17e7a8077e6a6337d44fa" alt=""
System Broadcast Picker
- Your app can initiate an iOS system broadcast session
- Simple 1-button UI
- No compromises for privacy
- Secure architecture
- New in iOS 12
data:image/s3,"s3://crabby-images/56111/56111c4bd17ece77d1612610cbd35651d6598010" alt=""
data:image/s3,"s3://crabby-images/e90de/e90de8466e5dacbd31215fa61dbaaec9b25685f7" alt=""
data:image/s3,"s3://crabby-images/3d10f/3d10f3a5e985d38dcb2629a9b6cd3cc4cd80be40" alt=""
data:image/s3,"s3://crabby-images/1b196/1b196ad07c68410cc05c3864b500c209a6fd304f" alt=""
data:image/s3,"s3://crabby-images/e64a0/e64a0a819dfbcec5a700ff2874aa72cc1e04eb1f" alt=""
data:image/s3,"s3://crabby-images/1f98f/1f98f98889a2ef401c9810947ced58ddcec9abd6" alt=""
preferredExtension
- Pair broadcast picker to a particular extension
- Assign bundle identifier of your extension
- Initialize before view is presented
data:image/s3,"s3://crabby-images/3e69f/3e69f7cf220de6e7688348b355a18aca7ccc3051" alt=""
RPSystemBroadcastPickerView
- Brings up system broadcast picker
- Allows to configure broadcast picker
- Doesn’t own any state of the session
data:image/s3,"s3://crabby-images/1ef5f/1ef5fb33d60874a924ee5a43b1cd8e483df7a2fd" alt=""
Broadcast App and Extension
- Broadcast Application
- Account sign-in, broadcast title - Broadcast Upload Extension
- Encode samples, upload to service
data:image/s3,"s3://crabby-images/a7d49/a7d49258ce93dcdd418d860eb5cebf675cc61818" alt=""
Broadcast Upload Extension
- Receives audio and video samples
- Encodes and uploads video stream
- Handles device orientation changes
- Annotates broadcast with app information
data:image/s3,"s3://crabby-images/ea54d/ea54d5a9ed24d908fb50481f8c6aa51b1daa346b" alt=""
Broadcast Extension Template
data:image/s3,"s3://crabby-images/defbb/defbb3b271714e4da4be3f4f8f80b7fe1eb0f135" alt=""
data:image/s3,"s3://crabby-images/7e473/7e47366e1935cdb079e747af763b9ffb34e751cc" alt=""
Broadcast Lifecycle
data:image/s3,"s3://crabby-images/1abd1/1abd14265efcbb17c518fbb57218d24107fe3f4e" alt=""
Handling Sign-In and Broadcast Setup
Broadcast application
data:image/s3,"s3://crabby-images/61037/610377e693b1b9fba97844f9b5b7499989fc89e6" alt=""
Initialization
data:image/s3,"s3://crabby-images/fa8d0/fa8d03acc13a1036154cc701e721dd4892631dd4" alt=""
data:image/s3,"s3://crabby-images/de0b7/de0b79a9c4465f449626434f8a1db5e3bb761ead" alt=""
Handling broadcastStarted
data:image/s3,"s3://crabby-images/a3803/a38037d213e2d2d0d4ffc32b6335f057ef8633b2" alt=""
data:image/s3,"s3://crabby-images/790da/790daa506477728884ecb3b45b7be45a5b60dec0" alt=""
Processing Media Samples
data:image/s3,"s3://crabby-images/ae3d7/ae3d7b066fa33f66d18a78a18d53aeb4dfb157d5" alt=""
data:image/s3,"s3://crabby-images/49c86/49c86574c2254ab6111afa8382a4912798a081cf" alt=""
Handling Application Information
data:image/s3,"s3://crabby-images/5b93d/5b93db542790dbd1a52c8a588bb853580dac5c90" alt=""
data:image/s3,"s3://crabby-images/2275f/2275f1a6be7fb9d961713331b98e5a69b6a80dc8" alt=""
Handling ‘ broadcastFinished ’
data:image/s3,"s3://crabby-images/7238a/7238abb80df643e9b9fc52acff92a8e8e2b4421e" alt=""
Handling Sign-In
data:image/s3,"s3://crabby-images/9ed29/9ed292a0346f62f17ea86e279e8820d5c05a1b6c" alt=""
data:image/s3,"s3://crabby-images/9d062/9d0625b006b5df01cdfb9c2a86028053ebd0d3e2" alt=""
data:image/s3,"s3://crabby-images/0bd0f/0bd0f1bba676e9464f7fb42f59ab18639fe86c70" alt=""
Protecting Content
UIScreen.isCaptured
- Prevent capturing of audio and video content of your app
- Stop media playback or displaying sensitive content
- Check value ofUIScreen.captured
- Register forUIScreenCapturedDidChangeNotification
- CheckUIScreen.screens.count
to allow screen mirroring
data:image/s3,"s3://crabby-images/d4067/d40673c517c4b56865f5d0e4c2a39ad951596688" alt=""