fixes for 23

This commit is contained in:
Aiden Vigue 2021-05-27 14:05:26 -04:00
parent bd386b4e45
commit decd0bd5c0
No known key found for this signature in database
GPG Key ID: E7570472648F4544
2 changed files with 53 additions and 31 deletions

View File

@ -155,11 +155,13 @@ class PlayerViewController: UIViewController, VLCMediaDelegate, VLCMediaPlayerDe
@IBAction func settingsButtonTapped(_ sender: UIButton) {
let optionsVC = VideoPlayerSettingsView()
print(self.selectedAudioTrack)
print(self.selectedCaptionTrack)
optionsVC.currentSubtitleTrack = self.selectedCaptionTrack
optionsVC.currentAudioTrack = self.selectedAudioTrack
optionsVC.delegate = self;
optionsVC.subtitles = subtitleTrackArray
optionsVC.audioTracks = audioTrackArray
optionsVC.currentSubtitleTrack = selectedCaptionTrack
optionsVC.currentAudioTrack = selectedAudioTrack
// Use the popover presentation style for your view controller.
optionsVC.modalPresentationStyle = .popover
@ -297,6 +299,7 @@ class PlayerViewController: UIViewController, VLCMediaDelegate, VLCMediaPlayerDe
DispatchQueue.global(qos: .background).async {
mediaPlayer.media = VLCMedia(url: playbackItem.videoUrl)
mediaPlayer.play()
mediaPlayer.jumpForward(Int32(manifest.Progress/10000000))
subtitleTrackArray.forEach() { sub in
if(sub.id != -1 && sub.delivery == "External" && sub.codec != "subrip") {
print("adding subs for id: \(sub.id) w/ url: \(sub.url)")
@ -306,10 +309,9 @@ class PlayerViewController: UIViewController, VLCMediaDelegate, VLCMediaPlayerDe
mediaPlayer.pause()
delegate?.showLoadingView(self)
sleep(3)
mediaPlayer.pause()
mediaPlayer.currentVideoSubTitleIndex = selectedCaptionTrack;
mediaPlayer.pause()
mediaPlayer.play()
mediaPlayer.jumpForward(Int32(manifest.Progress/10000000))
}
} catch {

View File

@ -62,21 +62,19 @@ class VideoPlayerSettingsView: UIViewController {
private var shouldClosePublisher: AnyCancellable?
var subtitles: [Subtitle] = []
var audioTracks: [AudioTrack] = []
var currentSubtitleTrack: Int32 = -1;
var currentAudioTrack: Int32 = 0;
var currentSubtitleTrack: Int32!
var currentAudioTrack: Int32!
override func viewDidLoad() {
super.viewDidLoad()
contentViewDelegate.audioTrackID = currentAudioTrack;
contentViewDelegate.subtitleTrackID = currentSubtitleTrack;
ctntView = VideoPlayerSettings(delegate: self.contentViewDelegate, subtitles: self.subtitles, audioTracks: self.audioTracks)
ctntView = VideoPlayerSettings(delegate: self.contentViewDelegate, subtitles: self.subtitles, audioTracks: self.audioTracks, initSub: currentSubtitleTrack, initAudio: currentAudioTrack)
let contentView = UIHostingController(rootView: ctntView)
self.view.addSubview(contentView.view)
contentView.view.translatesAutoresizingMaskIntoConstraints = false;
contentView.view.topAnchor.constraint(equalTo: view.topAnchor).isActive = true;
contentView.view.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true;
contentView.view.leftAnchor.constraint(equalTo: view.leftAnchor).isActive = true;
contentView.view.rightAnchor.constraint(equalTo: view.rightAnchor).isActive = true;
contentView.view.translatesAutoresizingMaskIntoConstraints = false
contentView.view.topAnchor.constraint(equalTo: view.topAnchor).isActive = true
contentView.view.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true
contentView.view.leftAnchor.constraint(equalTo: view.leftAnchor).isActive = true
contentView.view.rightAnchor.constraint(equalTo: view.rightAnchor).isActive = true
self.subChangePublisher = self.contentViewDelegate.subtitlesDidChange.sink { suiDelegate in
self.delegate?.subtitleTrackChanged(newTrackID: suiDelegate.subtitleTrackID)
@ -104,32 +102,54 @@ struct VideoPlayerSettings: View {
@ObservedObject var delegate: SettingsViewDelegate
@State private var subtitles: [Subtitle]
@State private var audioTracks: [AudioTrack]
@State private var subtitleSelection: Int32
@State private var audioTrackSelection: Int32
init(delegate: SettingsViewDelegate, subtitles: [Subtitle], audioTracks: [AudioTrack]) {
init(delegate: SettingsViewDelegate, subtitles: [Subtitle], audioTracks: [AudioTrack], initSub: Int32, initAudio: Int32) {
self.delegate = delegate
self.subtitles = subtitles
self.audioTracks = audioTracks
print(subtitles)
print(audioTracks)
self.subtitleSelection = initSub
self.audioTrackSelection = initAudio
print(initSub)
print(initAudio)
}
var body: some View {
NavigationView() {
Form() {
Picker("Closed Captions", selection: self.$delegate.subtitleTrackID) {
ForEach(subtitles, id: \.id) { caption in
Text(caption.name).tag(caption.id)
GeometryReader { proxy in
NavigationView() {
Form() {
Picker("Closed Captions", selection: $subtitleSelection) {
ForEach(subtitles, id: \.id) { caption in
Text(caption.name).tag(caption.id)
}
}.onChange(of: subtitleSelection) { id in
self.delegate.subtitleTrackID = id
}
Picker("Audio Track", selection: $audioTrackSelection) {
ForEach(audioTracks, id: \.id) { caption in
Text(caption.name).tag(caption.id).lineLimit(1)
}
}.onChange(of: audioTrackSelection) { id in
self.delegate.audioTrackID = id
}
}.navigationTitle("Audio & Captions")
.navigationBarTitleDisplayMode(.inline)
.toolbar {
ToolbarItemGroup(placement: .navigationBarLeading) {
Button {
delegate.close = true;
} label: {
HStack() {
Text("Back").font(.callout)
}
}
}
}
Picker("Audio Track", selection: self.$delegate.audioTrackID) {
ForEach(audioTracks, id: \.id) { caption in
Text(caption.name).tag(caption.id).lineLimit(1)
}
}
}.navigationTitle("Audio & Captions")
.navigationBarTitleDisplayMode(.inline)
}.navigationViewStyle(StackNavigationViewStyle())
}.navigationViewStyle(StackNavigationViewStyle())
.padding(6)
.frame(width: proxy.size.width, height: proxy.size.height)
}
}
}