fix handling and displaying captions

fixes #490

It also fixes the caption picker being empty when a caption was selected in the previous watched video.
This commit is contained in:
Toni Förster 2024-04-21 01:01:55 +02:00
parent d1cf45c6a1
commit f3637e2426
No known key found for this signature in database
GPG Key ID: 292F3E5086C83FC7
4 changed files with 19 additions and 14 deletions

View File

@ -264,6 +264,10 @@ final class MPVBackend: PlayerBackend {
self.startClientUpdates() self.startClientUpdates()
// Captions should only be displayed when selected by the user,
// not when the video starts. So, we remove them.
self.client?.removeSubs()
if !preservingTime, if !preservingTime,
!upgrading, !upgrading,
let segment = self.model.sponsorBlock.segments.first, let segment = self.model.sponsorBlock.segments.first,

View File

@ -771,10 +771,12 @@ final class PlayerModel: ObservableObject {
func handleCurrentItemChange() { func handleCurrentItemChange() {
if currentItem == nil { if currentItem == nil {
captions = nil
FeedModel.shared.calculateUnwatchedFeed() FeedModel.shared.calculateUnwatchedFeed()
} }
// Captions need to be set to nil on item change, to clear the previus values.
captions = nil
#if os(macOS) #if os(macOS)
Windows.player.window?.title = windowTitle Windows.player.window?.title = windowTitle
#endif #endif

View File

@ -312,7 +312,6 @@ struct ControlsOverlay: View {
.foregroundColor(.primary) .foregroundColor(.primary)
} }
.transaction { t in t.animation = .none } .transaction { t in t.animation = .none }
.buttonStyle(.plain) .buttonStyle(.plain)
.foregroundColor(.primary) .foregroundColor(.primary)
.frame(width: 240, height: 40) .frame(width: 240, height: 40)
@ -374,14 +373,14 @@ struct ControlsOverlay: View {
let captions = player.currentVideo?.captions ?? [] let captions = player.currentVideo?.captions ?? []
Picker("Captions", selection: captionsBinding) { Picker("Captions", selection: captionsBinding) {
if captions.isEmpty { if captions.isEmpty {
Text("Not available") Text("Not available").tag(Captions?.none)
} else { } else {
Text("Disabled").tag(Captions?.none) Text("Disabled").tag(Captions?.none)
}
ForEach(captions) { caption in ForEach(captions) { caption in
Text(caption.description).tag(Optional(caption)) Text(caption.description).tag(Optional(caption))
} }
} }
}
.disabled(captions.isEmpty) .disabled(captions.isEmpty)
} }

View File

@ -433,14 +433,14 @@ struct PlaybackSettings: View {
let captions = player.currentVideo?.captions ?? [] let captions = player.currentVideo?.captions ?? []
Picker("Captions".localized(), selection: $player.captions) { Picker("Captions".localized(), selection: $player.captions) {
if captions.isEmpty { if captions.isEmpty {
Text("Not available") Text("Not available").tag(Captions?.none)
} else { } else {
Text("Disabled").tag(Captions?.none) Text("Disabled").tag(Captions?.none)
}
ForEach(captions) { caption in ForEach(captions) { caption in
Text(caption.description).tag(Optional(caption)) Text(caption.description).tag(Optional(caption))
} }
} }
}
.disabled(captions.isEmpty) .disabled(captions.isEmpty)
} }
} }