TPStreamsSDK is a versatile iOS native SDK with support for both DRM (FairPlay) and non-DRM content.
- Requirements
- Integration using Swift Package Manager (SPM)
- Intializing TPStreamsSDK
- Playing a Video with TPStreamsSDK
- Sample iOS app
Before integrating TPStreamsSDK into your iOS application, ensure that your project meets the following requirement:
- Minimum Deployment Version: iOS 14 or later
- Swift: Version 5.5 or later
To add TPStreamsSDK to your Xcode project using Swift Package Manager, follow these steps:
- Select File > Add Packages in Xcode.
- In the search bar, enter the following URL:
https://github.com/testpress/iOSPlayerSDK
. - Select 'iOSPlayerSDK' from the search results. Click Add package button.
Once the package is added, you can start using TPStreamsSDK in your iOS application.
In the application(_:didFinishLaunchingWithOptions:)
method in your AppDelegate, call TPStreamsSDK.initialize(withOrgCode:)
to initialize the SDK with your organization code.
class AppDelegate: UIResponder, UIApplicationDelegate {
func application(_ application: UIApplication,didFinishLaunchingWithOptions launchOptions [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
TPStreamsSDK.initialize(withOrgCode: "YOUR_ORGANIZATION_CODE")
return true
}
}
Please note that the above code assumes you are using SwiftUI for your application. If you are using a different app architecture, you may need to adapt the integration steps accordingly.
- Instantiate a TPAVPlayer by providing the appropriate assetID and accessToken.
- Embed the TPStreamPlayerView in your SwiftUI view.
struct ContentView: View {
let player = TPAVPlayer(assetID: "YOUR_ASSET_ID", accessToken: "YOUR_ACCESS_TOKEN")
var body: some View {
VStack {
TPStreamPlayerView(player: player)
.frame(height: 240)
Spacer()
}
}
}
- Instantiate a TPAVPlayer with the relevant assetID and accessToken.
- Create a TPStreamPlayerViewController and assign the previously created TPAVPlayer to the player attribute.
- Add the TPStreamPlayerViewController.view to the view hierarchy. This will display the video player within the specified playerContainer view.
class ViewController: UIViewController {
@IBOutlet weak var playerContainer: UIView!
var playerViewController: TPStreamPlayerViewController?
var player: TPAVPlayer?
override func viewDidLoad() {
super.viewDidLoad()
self.setupPlayerView()
player?.play()
}
func setupPlayerView(){
player = TPAVPlayer(assetID: "YOUR_ASSET_ID", accessToken: "YOUR_ACCESS_TOKEN")
playerViewController = TPStreamPlayerViewController()
playerViewController?.player = player
addChild(playerViewController!)
playerContainer.addSubview(playerViewController!.view)
playerViewController!.view.frame = playerContainer.bounds
}
}
TPAVPlayer is a wrapper class of AVPlayer that provides built-in support for playing our videos without requiring additional effort. It also supports FairPlay streaming for DRM-protected content.
Since TPAVPlayer is a wrapper class of AVPlayer, you can also use the TPAVPlayer with native iOS player to play Streams Videos.
For a practical implementation and usage of TPStreamsSDK, refer to our Sample iOS App.