You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
session-ios/Session/Calls/CallVC.swift

125 lines
4.3 KiB
Swift

3 years ago
import WebRTC
import SessionUIKit
import SessionMessagingKit
import SessionUtilitiesKit
3 years ago
final class CallVC : UIViewController, WebRTCSessionDelegate {
let sessionID: String
let mode: Mode
let webRTCSession: WebRTCSession
3 years ago
lazy var cameraManager: CameraManager = {
let result = CameraManager()
result.delegate = self
return result
}()
lazy var videoCapturer: RTCVideoCapturer = {
return RTCCameraVideoCapturer(delegate: webRTCSession.localVideoSource)
3 years ago
}()
3 years ago
// MARK: UI Components
private lazy var fadeView: UIView = {
let result = UIView()
let height: CGFloat = 64
var frame = UIScreen.main.bounds
frame.size.height = height
let layer = CAGradientLayer()
layer.frame = frame
layer.colors = [ UIColor(hex: 0x000000).withAlphaComponent(0.4).cgColor, UIColor(hex: 0x000000).withAlphaComponent(0).cgColor ]
result.layer.insertSublayer(layer, at: 0)
result.set(.height, to: height)
return result
}()
private lazy var closeButton: UIButton = {
let result = UIButton(type: .custom)
let image = UIImage(named: "X")!.withTint(.white)
result.setImage(image, for: UIControl.State.normal)
result.set(.width, to: 60)
result.set(.height, to: 60)
return result
}()
// MARK: Mode
enum Mode {
case offer
case answer(sdp: RTCSessionDescription)
}
3 years ago
// MARK: Lifecycle
init(for sessionID: String, mode: Mode) {
self.sessionID = sessionID
self.mode = mode
self.webRTCSession = WebRTCSession.current ?? WebRTCSession(for: sessionID)
super.init(nibName: nil, bundle: nil)
self.webRTCSession.delegate = self
}
required init(coder: NSCoder) { preconditionFailure("Use init(for:) instead.") }
3 years ago
override func viewDidLoad() {
super.viewDidLoad()
view.backgroundColor = .black
WebRTCSession.current = webRTCSession
3 years ago
setUpViewHierarchy()
cameraManager.prepare()
touch(videoCapturer)
if case .offer = mode {
Storage.write { transaction in
self.webRTCSession.sendOffer(to: self.sessionID, using: transaction).retainUntilComplete()
}
} else if case let .answer(sdp) = mode {
webRTCSession.handleRemoteSDP(sdp, from: sessionID) // This sends an answer message internally
}
3 years ago
}
func setUpViewHierarchy() {
3 years ago
// Remote video view
3 years ago
let remoteVideoView = RTCMTLVideoView()
remoteVideoView.contentMode = .scaleAspectFill
webRTCSession.attachRemoteRenderer(remoteVideoView)
3 years ago
view.addSubview(remoteVideoView)
remoteVideoView.translatesAutoresizingMaskIntoConstraints = false
remoteVideoView.pin(to: view)
// Local video view
let localVideoView = RTCMTLVideoView()
localVideoView.contentMode = .scaleAspectFill
webRTCSession.attachLocalRenderer(localVideoView)
3 years ago
localVideoView.set(.width, to: 80)
localVideoView.set(.height, to: 173)
view.addSubview(localVideoView)
localVideoView.pin(.right, to: .right, of: view, withInset: -Values.largeSpacing)
let bottomMargin = UIApplication.shared.keyWindow!.safeAreaInsets.bottom + Values.largeSpacing
localVideoView.pin(.bottom, to: .bottom, of: view, withInset: -bottomMargin)
3 years ago
// Fade view
view.addSubview(fadeView)
fadeView.translatesAutoresizingMaskIntoConstraints = false
fadeView.pin([ UIView.HorizontalEdge.left, UIView.VerticalEdge.top, UIView.HorizontalEdge.right ], to: view)
// Close button
view.addSubview(closeButton)
closeButton.translatesAutoresizingMaskIntoConstraints = false
closeButton.pin(.left, to: .left, of: view)
closeButton.pin(.top, to: .top, of: view, withInset: 32)
3 years ago
}
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
cameraManager.start()
}
override func viewWillDisappear(_ animated: Bool) {
super.viewWillDisappear(animated)
cameraManager.stop()
}
deinit {
WebRTCSession.current = nil
3 years ago
}
3 years ago
// MARK: Interaction
@objc private func close() {
presentingViewController?.dismiss(animated: true, completion: nil)
}
3 years ago
}