From 1973a62b5158ce69d278467d1fb13161b91b9f24 Mon Sep 17 00:00:00 2001 From: Chris Griffith Date: Wed, 3 May 2023 19:03:35 -0500 Subject: [PATCH] Version 5.5.4 (#478) * Fixing #474 SVT-AV1 single pass would not be set on return from queue (thanks to veldspar) * Fixing #475 Autocrop can break with index error (thanks to No Name / phanluchoaofficial1152) * Fixing #477 HDR10+ not extracting with NVEncC encoder, switching to built in copy ability (thanks to Genine-Collin) --- CHANGES | 6 ++ fastflix/data/languages.yaml | 60 +++++++++++++++++++ fastflix/encoders/common/setting_panel.py | 9 +++ .../encoders/nvencc_av1/command_builder.py | 4 +- .../encoders/nvencc_av1/settings_panel.py | 29 +-------- .../encoders/nvencc_avc/settings_panel.py | 30 ---------- .../encoders/nvencc_hevc/command_builder.py | 4 +- .../encoders/nvencc_hevc/settings_panel.py | 29 +-------- .../encoders/qsvencc_av1/command_builder.py | 4 +- .../encoders/qsvencc_av1/settings_panel.py | 29 +-------- .../encoders/qsvencc_hevc/command_builder.py | 4 +- .../encoders/qsvencc_hevc/settings_panel.py | 29 +-------- fastflix/encoders/svt_av1/settings_panel.py | 13 ++-- .../encoders/vceencc_av1/command_builder.py | 4 +- .../encoders/vceencc_av1/settings_panel.py | 38 ++---------- .../encoders/vceencc_hevc/command_builder.py | 4 +- .../encoders/vceencc_hevc/settings_panel.py | 34 +---------- fastflix/models/encode.py | 6 ++ fastflix/version.py | 2 +- fastflix/widgets/main.py | 3 + fastflix/widgets/panels/queue_panel.py | 2 +- 21 files changed, 114 insertions(+), 229 deletions(-) diff --git a/CHANGES b/CHANGES index a559be62..7768c1bd 100644 --- a/CHANGES +++ b/CHANGES @@ -1,5 +1,11 @@ # Changelog +## Version 5.5.4 + +* Fixing #474 SVT-AV1 single pass would not be set on return from queue (thanks to veldspar) +* Fixing #475 Autocrop can break with index error (thanks to No Name / phanluchoaofficial1152) +* Fixing #477 HDR10+ not extracting with NVEncC encoder, switching to built in copy ability (thanks to Genine-Collin) + ## Version 5.5.3 * Fixing missing language options (thanks to RoDanny2021) diff --git a/fastflix/data/languages.yaml b/fastflix/data/languages.yaml index 38a9bc55..344305e6 100644 --- a/fastflix/data/languages.yaml +++ b/fastflix/data/languages.yaml @@ -10275,3 +10275,63 @@ Output Depth: ukr: Тільки 8 біт kor: 8 비트 만 ron: Numai 8-Bit +Copy HDR10+: + eng: Copy HDR10+ + deu: HDR10+ kopieren + fra: Copier HDR10+ + ita: Copia HDR10+ + spa: Copiar HDR10+ + zho: 复制HDR10+ + jpn: HDR10+をコピー + rus: Копировать HDR10+ + por: Copiar HDR10+ + swe: Kopiera HDR10+ + pol: Skopiuj HDR10+ + ukr: Скопіювати HDR10+ + kor: HDR10+ 복사 + ron: Copiați HDR10+ +Copy HDR10+ dynamic metadata from input file: + eng: Copy HDR10+ dynamic metadata from input file + deu: Kopieren Sie HDR10+ dynamische Metadaten aus der Eingabedatei + fra: Copier les métadonnées dynamiques HDR10+ du fichier d'entrée + ita: Copia i metadati dinamici HDR10+ dal file di input + spa: Copiar metadatos dinámicos HDR10+ del archivo de entrada + zho: 从输入文件复制HDR10+动态元数据 + jpn: 入力ファイルからHDR10+ダイナミックメタデータをコピー + rus: Скопировать динамические метаданные HDR10+ из входного файла + por: Copiar metadados dinâmicos HDR10+ do arquivo de entrada + swe: Kopiera HDR10+ dynamisk metadata från inmatningsfilen + pol: Skopiuj dynamiczne metadane HDR10+ z pliku wejściowego + ukr: Скопіювати динамічні метадані HDR10+ з вхідного файлу + kor: 입력 파일에서 HDR10+ 동적 메타 데이터 복사 + ron: Copiați metadatele dinamice HDR10+ din fișierul de intrare +Single Pass: + eng: Single Pass + deu: Einzelner Pass + fra: Passe unique + ita: Passaggio singolo + spa: Pase único + zho: 单次通过 + jpn: シングルパス + rus: Одиночный проход + por: Passe único + swe: Enkelt pass + pol: Pojedyncze przejście + ron: O singură trecere + kor: 단일 패스 + ukr: Одноразовий пропуск +Single Pass Encoding: + eng: Single Pass Encoding + deu: Single-Pass-Codierung + fra: Encodage à passage unique + ita: Codifica a passaggio singolo + spa: Codificación de una sola pasada + zho: 单程编码 + jpn: シングルパスエンコード + rus: Однопроходное кодирование + por: Codificação de passagem única + swe: Kodning i ett enda steg + pol: Kodowanie jednoprzebiegowe + ron: Codificare cu o singură trecere + kor: 싱글 패스 인코딩 + ukr: Однопрохідне кодування diff --git a/fastflix/encoders/common/setting_panel.py b/fastflix/encoders/common/setting_panel.py index 9800f400..de99efab 100644 --- a/fastflix/encoders/common/setting_panel.py +++ b/fastflix/encoders/common/setting_panel.py @@ -599,6 +599,15 @@ def init_decoder(self): min_width=80, ) + def init_dhdr10_info(self): + layout = self._add_check_box( + label="Copy HDR10+", + widget_name="copy_hdr10", + tooltip="Copy HDR10+ dynamic metadata from input file", + opt="copy_hdr10", + ) + return layout + class QSVEncPanel(RigayaPanel): def init_adapt_ref(self): diff --git a/fastflix/encoders/nvencc_av1/command_builder.py b/fastflix/encoders/nvencc_av1/command_builder.py index 355eb2a7..522a537a 100644 --- a/fastflix/encoders/nvencc_av1/command_builder.py +++ b/fastflix/encoders/nvencc_av1/command_builder.py @@ -35,8 +35,8 @@ def build(fastflix: FastFlix): max_cll = f'--max-cll "{fastflix.current_video.cll}"' dhdr = None - if settings.hdr10plus_metadata: - dhdr = f'--dhdr10-info "{settings.hdr10plus_metadata}"' + if settings.copy_hdr10: + dhdr = f"--dhdr10-info copy" seek = "" seekto = "" diff --git a/fastflix/encoders/nvencc_av1/settings_panel.py b/fastflix/encoders/nvencc_av1/settings_panel.py index 976bef18..cedda91b 100644 --- a/fastflix/encoders/nvencc_av1/settings_panel.py +++ b/fastflix/encoders/nvencc_av1/settings_panel.py @@ -362,29 +362,6 @@ def init_metrics(self): tooltip="Calculate PSNR and SSIM and show in the encoder output", ) - def init_dhdr10_info(self): - layout = self._add_file_select( - label="HDR10+ Metadata", - widget_name="hdr10plus_metadata", - button_action=lambda: self.dhdr10_update(), - tooltip="dhdr10_info: Path to HDR10+ JSON metadata file", - ) - self.labels["hdr10plus_metadata"].setFixedWidth(200) - self.extract_button = QtWidgets.QPushButton(t("Extract HDR10+")) - self.extract_button.hide() - self.extract_button.clicked.connect(self.extract_hdr10plus) - - self.extract_label = QtWidgets.QLabel(self) - self.extract_label.hide() - self.movie = QtGui.QMovie(loading_movie) - self.movie.setScaledSize(QtCore.QSize(25, 25)) - self.extract_label.setMovie(self.movie) - - layout.addWidget(self.extract_button) - layout.addWidget(self.extract_label) - - return layout - def init_modes(self): layout = self._add_modes(recommended_bitrates, recommended_crfs, qp_name="cqp") return layout @@ -418,7 +395,7 @@ def update_video_encoder_settings(self): lookahead=self.widgets.lookahead.currentIndex() if self.widgets.lookahead.currentIndex() > 0 else None, aq=self.widgets.aq.currentText(), aq_strength=self.widgets.aq_strength.currentIndex(), - hdr10plus_metadata=self.widgets.hdr10plus_metadata.text().strip(), # .replace("\\", "/"), + copy_hdr10=self.widgets.copy_hdr10.isChecked(), multipass=self.widgets.multipass.currentText(), mv_precision=self.widgets.mv_precision.currentText(), init_q_i=self.widgets.init_q_i.currentText() if self.widgets.init_q_i.currentIndex() != 0 else None, @@ -458,10 +435,6 @@ def new_source(self): if not self.app.fastflix.current_video: return super().new_source() - if self.app.fastflix.current_video.hdr10_plus: - self.extract_button.show() - else: - self.extract_button.hide() if self.app.fastflix.current_video.current_video_stream.bit_depth > 8 and not self.main.remove_hdr: self.widgets.force_ten_bit.setChecked(True) self.widgets.force_ten_bit.setDisabled(True) diff --git a/fastflix/encoders/nvencc_avc/settings_panel.py b/fastflix/encoders/nvencc_avc/settings_panel.py index c0b49d21..2e083e39 100644 --- a/fastflix/encoders/nvencc_avc/settings_panel.py +++ b/fastflix/encoders/nvencc_avc/settings_panel.py @@ -126,8 +126,6 @@ def __init__(self, parent, main, app: FastFlixApp): even_more.addLayout(self.init_metrics()) grid.addLayout(even_more, 7, 2, 1, 4) - grid.addLayout(self.init_dhdr10_info(), 8, 2, 1, 4) - grid.setRowStretch(9, 1) guide_label = QtWidgets.QLabel( @@ -355,29 +353,6 @@ def init_metrics(self): tooltip="Calculate PSNR and SSIM and show in the encoder output", ) - def init_dhdr10_info(self): - layout = self._add_file_select( - label="HDR10+ Metadata", - widget_name="hdr10plus_metadata", - button_action=lambda: self.dhdr10_update(), - tooltip="dhdr10_info: Path to HDR10+ JSON metadata file", - ) - self.labels["hdr10plus_metadata"].setFixedWidth(200) - self.extract_button = QtWidgets.QPushButton(t("Extract HDR10+")) - self.extract_button.hide() - self.extract_button.clicked.connect(self.extract_hdr10plus) - - self.extract_label = QtWidgets.QLabel(self) - self.extract_label.hide() - self.movie = QtGui.QMovie(loading_movie) - self.movie.setScaledSize(QtCore.QSize(25, 25)) - self.extract_label.setMovie(self.movie) - - layout.addWidget(self.extract_button) - layout.addWidget(self.extract_label) - - return layout - def init_modes(self): layout = self._add_modes(recommended_bitrates, recommended_crfs, qp_name="cqp") return layout @@ -404,7 +379,6 @@ def update_video_encoder_settings(self): lookahead=self.widgets.lookahead.currentIndex() if self.widgets.lookahead.currentIndex() > 0 else None, aq=self.widgets.aq.currentText(), aq_strength=self.widgets.aq_strength.currentIndex(), - hdr10plus_metadata=self.widgets.hdr10plus_metadata.text().strip(), # .replace("\\", "/"), multipass=self.widgets.multipass.currentText(), mv_precision=self.widgets.mv_precision.currentText(), init_q_i=self.widgets.init_q_i.currentText() if self.widgets.init_q_i.currentIndex() != 0 else None, @@ -444,7 +418,3 @@ def new_source(self): if not self.app.fastflix.current_video: return super().new_source() - if self.app.fastflix.current_video.hdr10_plus: - self.extract_button.show() - else: - self.extract_button.hide() diff --git a/fastflix/encoders/nvencc_hevc/command_builder.py b/fastflix/encoders/nvencc_hevc/command_builder.py index 9e9f1d6d..1484dc68 100644 --- a/fastflix/encoders/nvencc_hevc/command_builder.py +++ b/fastflix/encoders/nvencc_hevc/command_builder.py @@ -35,8 +35,8 @@ def build(fastflix: FastFlix): max_cll = f'--max-cll "{fastflix.current_video.cll}"' dhdr = None - if settings.hdr10plus_metadata: - dhdr = f'--dhdr10-info "{settings.hdr10plus_metadata}"' + if settings.copy_hdr10: + dhdr = f"--dhdr10-info copy" seek = "" seekto = "" diff --git a/fastflix/encoders/nvencc_hevc/settings_panel.py b/fastflix/encoders/nvencc_hevc/settings_panel.py index 908443a2..77243247 100644 --- a/fastflix/encoders/nvencc_hevc/settings_panel.py +++ b/fastflix/encoders/nvencc_hevc/settings_panel.py @@ -360,29 +360,6 @@ def init_metrics(self): tooltip="Calculate PSNR and SSIM and show in the encoder output", ) - def init_dhdr10_info(self): - layout = self._add_file_select( - label="HDR10+ Metadata", - widget_name="hdr10plus_metadata", - button_action=lambda: self.dhdr10_update(), - tooltip="dhdr10_info: Path to HDR10+ JSON metadata file", - ) - self.labels["hdr10plus_metadata"].setFixedWidth(200) - self.extract_button = QtWidgets.QPushButton(t("Extract HDR10+")) - self.extract_button.hide() - self.extract_button.clicked.connect(self.extract_hdr10plus) - - self.extract_label = QtWidgets.QLabel(self) - self.extract_label.hide() - self.movie = QtGui.QMovie(loading_movie) - self.movie.setScaledSize(QtCore.QSize(25, 25)) - self.extract_label.setMovie(self.movie) - - layout.addWidget(self.extract_button) - layout.addWidget(self.extract_label) - - return layout - def init_modes(self): layout = self._add_modes(recommended_bitrates, recommended_crfs, qp_name="cqp") return layout @@ -416,7 +393,7 @@ def update_video_encoder_settings(self): lookahead=self.widgets.lookahead.currentIndex() if self.widgets.lookahead.currentIndex() > 0 else None, aq=self.widgets.aq.currentText(), aq_strength=self.widgets.aq_strength.currentIndex(), - hdr10plus_metadata=self.widgets.hdr10plus_metadata.text().strip(), # .replace("\\", "/"), + copy_hdr10=self.widgets.copy_hdr10.isChecked(), multipass=self.widgets.multipass.currentText(), mv_precision=self.widgets.mv_precision.currentText(), init_q_i=self.widgets.init_q_i.currentText() if self.widgets.init_q_i.currentIndex() != 0 else None, @@ -456,10 +433,6 @@ def new_source(self): if not self.app.fastflix.current_video: return super().new_source() - if self.app.fastflix.current_video.hdr10_plus: - self.extract_button.show() - else: - self.extract_button.hide() if self.app.fastflix.current_video.current_video_stream.bit_depth > 8 and not self.main.remove_hdr: self.widgets.force_ten_bit.setChecked(True) self.widgets.force_ten_bit.setDisabled(True) diff --git a/fastflix/encoders/qsvencc_av1/command_builder.py b/fastflix/encoders/qsvencc_av1/command_builder.py index 4f4c1ea7..019afe23 100644 --- a/fastflix/encoders/qsvencc_av1/command_builder.py +++ b/fastflix/encoders/qsvencc_av1/command_builder.py @@ -35,8 +35,8 @@ def build(fastflix: FastFlix): max_cll = f'--max-cll "{fastflix.current_video.cll}"' dhdr = None - if settings.hdr10plus_metadata: - dhdr = f'--dhdr10-info "{settings.hdr10plus_metadata}"' + if settings.copy_hdr10: + dhdr = f"--dhdr10-info copy" seek = "" seekto = "" diff --git a/fastflix/encoders/qsvencc_av1/settings_panel.py b/fastflix/encoders/qsvencc_av1/settings_panel.py index 7581bdd0..fcb1772f 100644 --- a/fastflix/encoders/qsvencc_av1/settings_panel.py +++ b/fastflix/encoders/qsvencc_av1/settings_panel.py @@ -295,29 +295,6 @@ def init_metrics(self): tooltip="Calculate PSNR and SSIM and show in the encoder output", ) - def init_dhdr10_info(self): - layout = self._add_file_select( - label="HDR10+ Metadata", - widget_name="hdr10plus_metadata", - button_action=lambda: self.dhdr10_update(), - tooltip="dhdr10_info: Path to HDR10+ JSON metadata file", - ) - self.labels["hdr10plus_metadata"].setFixedWidth(200) - self.extract_button = QtWidgets.QPushButton(t("Extract HDR10+")) - self.extract_button.hide() - self.extract_button.clicked.connect(self.extract_hdr10plus) - - self.extract_label = QtWidgets.QLabel(self) - self.extract_label.hide() - self.movie = QtGui.QMovie(loading_movie) - self.movie.setScaledSize(QtCore.QSize(25, 25)) - self.extract_label.setMovie(self.movie) - - layout.addWidget(self.extract_button) - layout.addWidget(self.extract_label) - - return layout - def init_modes(self): layout = self._add_modes(recommended_bitrates, recommended_crfs, qp_name="cqp") return layout @@ -347,7 +324,7 @@ def update_video_encoder_settings(self): preset=self.widgets.preset.currentText().split("-")[0].strip(), force_ten_bit=self.widgets.force_ten_bit.isChecked(), lookahead=self.widgets.lookahead.currentText() if self.widgets.lookahead.currentIndex() > 0 else None, - hdr10plus_metadata=self.widgets.hdr10plus_metadata.text().strip(), # .replace("\\", "/"), + copy_hdr10=self.widgets.copy_hdr10.isChecked(), max_q_i=self.widgets.max_q_i.currentText() if self.widgets.max_q_i.currentIndex() != 0 else None, max_q_p=self.widgets.max_q_p.currentText() if self.widgets.max_q_p.currentIndex() != 0 else None, max_q_b=self.widgets.max_q_b.currentText() if self.widgets.max_q_b.currentIndex() != 0 else None, @@ -383,10 +360,6 @@ def new_source(self): if not self.app.fastflix.current_video: return super().new_source() - if self.app.fastflix.current_video.hdr10_plus: - self.extract_button.show() - else: - self.extract_button.hide() if self.app.fastflix.current_video.current_video_stream.bit_depth > 8 and not self.main.remove_hdr: self.widgets.force_ten_bit.setChecked(True) self.widgets.force_ten_bit.setDisabled(True) diff --git a/fastflix/encoders/qsvencc_hevc/command_builder.py b/fastflix/encoders/qsvencc_hevc/command_builder.py index f66dc3f7..dfe65639 100644 --- a/fastflix/encoders/qsvencc_hevc/command_builder.py +++ b/fastflix/encoders/qsvencc_hevc/command_builder.py @@ -35,8 +35,8 @@ def build(fastflix: FastFlix): max_cll = f'--max-cll "{fastflix.current_video.cll}"' dhdr = None - if settings.hdr10plus_metadata: - dhdr = f'--dhdr10-info "{settings.hdr10plus_metadata}"' + if settings.copy_hdr10: + dhdr = f"--dhdr10-info copy" seek = "" seekto = "" diff --git a/fastflix/encoders/qsvencc_hevc/settings_panel.py b/fastflix/encoders/qsvencc_hevc/settings_panel.py index f354fe35..41b0fd04 100644 --- a/fastflix/encoders/qsvencc_hevc/settings_panel.py +++ b/fastflix/encoders/qsvencc_hevc/settings_panel.py @@ -287,29 +287,6 @@ def init_metrics(self): tooltip="Calculate PSNR and SSIM and show in the encoder output", ) - def init_dhdr10_info(self): - layout = self._add_file_select( - label="HDR10+ Metadata", - widget_name="hdr10plus_metadata", - button_action=lambda: self.dhdr10_update(), - tooltip="dhdr10_info: Path to HDR10+ JSON metadata file", - ) - self.labels["hdr10plus_metadata"].setFixedWidth(200) - self.extract_button = QtWidgets.QPushButton(t("Extract HDR10+")) - self.extract_button.hide() - self.extract_button.clicked.connect(self.extract_hdr10plus) - - self.extract_label = QtWidgets.QLabel(self) - self.extract_label.hide() - self.movie = QtGui.QMovie(loading_movie) - self.movie.setScaledSize(QtCore.QSize(25, 25)) - self.extract_label.setMovie(self.movie) - - layout.addWidget(self.extract_button) - layout.addWidget(self.extract_label) - - return layout - def init_modes(self): layout = self._add_modes(recommended_bitrates, recommended_crfs, qp_name="cqp") return layout @@ -339,7 +316,7 @@ def update_video_encoder_settings(self): preset=self.widgets.preset.currentText().split("-")[0].strip(), force_ten_bit=self.widgets.force_ten_bit.isChecked(), lookahead=self.widgets.lookahead.currentText() if self.widgets.lookahead.currentIndex() > 0 else None, - hdr10plus_metadata=self.widgets.hdr10plus_metadata.text().strip(), # .replace("\\", "/"), + copy_hdr10=self.widgets.copy_hdr10.isChecked(), max_q_i=self.widgets.max_q_i.currentText() if self.widgets.max_q_i.currentIndex() != 0 else None, max_q_p=self.widgets.max_q_p.currentText() if self.widgets.max_q_p.currentIndex() != 0 else None, max_q_b=self.widgets.max_q_b.currentText() if self.widgets.max_q_b.currentIndex() != 0 else None, @@ -375,10 +352,6 @@ def new_source(self): if not self.app.fastflix.current_video: return super().new_source() - if self.app.fastflix.current_video.hdr10_plus: - self.extract_button.show() - else: - self.extract_button.hide() if self.app.fastflix.current_video.current_video_stream.bit_depth > 8 and not self.main.remove_hdr: self.widgets.force_ten_bit.setChecked(True) self.widgets.force_ten_bit.setDisabled(True) diff --git a/fastflix/encoders/svt_av1/settings_panel.py b/fastflix/encoders/svt_av1/settings_panel.py index 5efe7021..c2548c1b 100644 --- a/fastflix/encoders/svt_av1/settings_panel.py +++ b/fastflix/encoders/svt_av1/settings_panel.py @@ -131,13 +131,12 @@ def init_sc_detection(self): ) def init_single_pass(self): - layout = QtWidgets.QHBoxLayout() - layout.addWidget(QtWidgets.QLabel("Single Pass")) - self.widgets.single_pass = QtWidgets.QCheckBox() - self.widgets.single_pass.setChecked(False) - self.widgets.single_pass.toggled.connect(lambda: self.main.page_update()) - layout.addWidget(self.widgets.single_pass) - return layout + return self._add_check_box( + label="Single Pass", + widget_name="single_pass", + tooltip="Single Pass Encoding", + opt="single_pass", + ) def init_preset(self): return self._add_combo_box( diff --git a/fastflix/encoders/vceencc_av1/command_builder.py b/fastflix/encoders/vceencc_av1/command_builder.py index 2d7466b5..4e6ff4fb 100644 --- a/fastflix/encoders/vceencc_av1/command_builder.py +++ b/fastflix/encoders/vceencc_av1/command_builder.py @@ -36,8 +36,8 @@ def build(fastflix: FastFlix): max_cll = f'--max-cll "{fastflix.current_video.cll}"' dhdr = None - if settings.hdr10plus_metadata: - dhdr = f'--dhdr10-info "{settings.hdr10plus_metadata}"' + if settings.copy_hdr10: + dhdr = f"--dhdr10-info copy" seek = "" seekto = "" diff --git a/fastflix/encoders/vceencc_av1/settings_panel.py b/fastflix/encoders/vceencc_av1/settings_panel.py index dc1b5150..b5930e90 100644 --- a/fastflix/encoders/vceencc_av1/settings_panel.py +++ b/fastflix/encoders/vceencc_av1/settings_panel.py @@ -247,34 +247,6 @@ def init_ref(self): min_width=60, ) - def init_dhdr10_info(self): - layout = self._add_file_select( - label="HDR10+ Metadata", - widget_name="hdr10plus_metadata", - button_action=lambda: self.dhdr10_update(), - tooltip="dhdr10_info: Path to HDR10+ JSON metadata file", - ) - self.labels["hdr10plus_metadata"].setFixedWidth(200) - self.extract_button = QtWidgets.QPushButton(t("Extract HDR10+")) - self.extract_button.hide() - self.extract_button.clicked.connect(self.extract_hdr10plus) - - self.extract_label = QtWidgets.QLabel(self) - self.extract_label.hide() - self.movie = QtGui.QMovie(loading_movie) - self.movie.setScaledSize(QtCore.QSize(25, 25)) - self.extract_label.setMovie(self.movie) - - layout.addWidget(self.extract_button) - layout.addWidget(self.extract_label) - - warning_label = QtWidgets.QLabel() - warning_label.setPixmap(QtGui.QIcon(get_icon("onyx-warning", self.app.fastflix.config.theme)).pixmap(22)) - layout.addWidget(warning_label) - layout.addWidget(QtWidgets.QLabel("7.12+")) - - return layout - def init_metrics(self): return self._add_check_box( widget_name="metrics", @@ -316,7 +288,7 @@ def update_video_encoder_settings(self): pre_analysis=self.widgets.pre_analysis.isChecked(), vbaq=self.widgets.vbaq.isChecked(), decoder=self.widgets.decoder.currentText(), - hdr10plus_metadata=self.widgets.hdr10plus_metadata.text().strip(), + copy_hdr10=self.widgets.copy_hdr10.isChecked(), bitrate_mode=self.widgets.bitrate_mode.currentText(), device=int(self.widgets.device.currentText().split(":", 1)[0] or 0), pa_sc=self.widgets.pa_sc.currentText(), @@ -350,7 +322,7 @@ def new_source(self): if not self.app.fastflix.current_video: return super().new_source() - if self.app.fastflix.current_video.hdr10_plus: - self.extract_button.show() - else: - self.extract_button.hide() + # if self.app.fastflix.current_video.hdr10_plus: + # self.extract_button.show() + # else: + # self.extract_button.hide() diff --git a/fastflix/encoders/vceencc_hevc/command_builder.py b/fastflix/encoders/vceencc_hevc/command_builder.py index fc11a762..d3606fc0 100644 --- a/fastflix/encoders/vceencc_hevc/command_builder.py +++ b/fastflix/encoders/vceencc_hevc/command_builder.py @@ -36,8 +36,8 @@ def build(fastflix: FastFlix): max_cll = f'--max-cll "{fastflix.current_video.cll}"' dhdr = None - if settings.hdr10plus_metadata: - dhdr = f'--dhdr10-info "{settings.hdr10plus_metadata}"' + if settings.copy_hdr10: + dhdr = f"--dhdr10-info copy" seek = "" seekto = "" diff --git a/fastflix/encoders/vceencc_hevc/settings_panel.py b/fastflix/encoders/vceencc_hevc/settings_panel.py index 0b830c0f..cef9dc58 100644 --- a/fastflix/encoders/vceencc_hevc/settings_panel.py +++ b/fastflix/encoders/vceencc_hevc/settings_panel.py @@ -240,34 +240,6 @@ def init_ref(self): min_width=60, ) - def init_dhdr10_info(self): - layout = self._add_file_select( - label="HDR10+ Metadata", - widget_name="hdr10plus_metadata", - button_action=lambda: self.dhdr10_update(), - tooltip="dhdr10_info: Path to HDR10+ JSON metadata file", - ) - self.labels["hdr10plus_metadata"].setFixedWidth(200) - self.extract_button = QtWidgets.QPushButton(t("Extract HDR10+")) - self.extract_button.hide() - self.extract_button.clicked.connect(self.extract_hdr10plus) - - self.extract_label = QtWidgets.QLabel(self) - self.extract_label.hide() - self.movie = QtGui.QMovie(loading_movie) - self.movie.setScaledSize(QtCore.QSize(25, 25)) - self.extract_label.setMovie(self.movie) - - layout.addWidget(self.extract_button) - layout.addWidget(self.extract_label) - - warning_label = QtWidgets.QLabel() - warning_label.setPixmap(QtGui.QIcon(get_icon("onyx-warning", self.app.fastflix.config.theme)).pixmap(22)) - layout.addWidget(warning_label) - layout.addWidget(QtWidgets.QLabel("7.12+")) - - return layout - def init_metrics(self): return self._add_check_box( widget_name="metrics", @@ -310,7 +282,7 @@ def update_video_encoder_settings(self): pre_analysis=self.widgets.pre_analysis.isChecked(), vbaq=self.widgets.vbaq.isChecked(), decoder=self.widgets.decoder.currentText(), - hdr10plus_metadata=self.widgets.hdr10plus_metadata.text().strip(), + copy_hdr10=self.widgets.copy_hdr10.isChecked(), device=int(self.widgets.device.currentText().split(":", 1)[0] or 0), pa_sc=self.widgets.pa_sc.currentText(), pa_ss=self.widgets.pa_ss.currentText(), @@ -343,7 +315,3 @@ def new_source(self): if not self.app.fastflix.current_video: return super().new_source() - if self.app.fastflix.current_video.hdr10_plus: - self.extract_button.show() - else: - self.extract_button.hide() diff --git a/fastflix/models/encode.py b/fastflix/models/encode.py index 38238b54..6132ed11 100644 --- a/fastflix/models/encode.py +++ b/fastflix/models/encode.py @@ -146,6 +146,7 @@ class NVEncCSettings(EncoderSettings): force_ten_bit: bool = False device: int = 0 decoder: str = "Auto" + copy_hdr10: bool = False class NVEncCAV1Settings(EncoderSettings): @@ -179,6 +180,7 @@ class NVEncCAV1Settings(EncoderSettings): force_ten_bit: bool = False device: int = 0 decoder: str = "Auto" + copy_hdr10: bool = False class QSVEncCSettings(EncoderSettings): @@ -204,6 +206,7 @@ class QSVEncCSettings(EncoderSettings): adapt_ref: bool = False adapt_cqm: bool = False adapt_ltr: bool = False + copy_hdr10: bool = False class QSVEncCAV1Settings(EncoderSettings): @@ -229,6 +232,7 @@ class QSVEncCAV1Settings(EncoderSettings): adapt_ref: bool = False adapt_cqm: bool = False adapt_ltr: bool = False + copy_hdr10: bool = False class QSVEncCH264Settings(EncoderSettings): @@ -320,6 +324,7 @@ class VCEEncCSettings(EncoderSettings): pa_taq: int | None = None pa_motion_quality: str | None = None output_depth: str | None = None + copy_hdr10: bool = False class VCEEncCAV1Settings(EncoderSettings): @@ -354,6 +359,7 @@ class VCEEncCAV1Settings(EncoderSettings): pa_taq: int | None = None pa_motion_quality: str | None = None output_depth: str | None + copy_hdr10: bool = False class VCEEncCAVCSettings(EncoderSettings): diff --git a/fastflix/version.py b/fastflix/version.py index 33cda5e8..82250897 100644 --- a/fastflix/version.py +++ b/fastflix/version.py @@ -1,4 +1,4 @@ #!/usr/bin/env python # -*- coding: utf-8 -*- -__version__ = "5.5.3" +__version__ = "5.5.4" __author__ = "Chris Griffith" diff --git a/fastflix/widgets/main.py b/fastflix/widgets/main.py index 2404c42e..8f232da2 100644 --- a/fastflix/widgets/main.py +++ b/fastflix/widgets/main.py @@ -1238,6 +1238,9 @@ def get_auto_crop(self): for x in times ] ProgressBar(self.app, tasks) + if not result_list: + logger.warning("Autocrop did not return crop points, please use a ffmpeg version with cropdetect filter") + return smallest = (self.app.fastflix.current_video.height + self.app.fastflix.current_video.width) * 2 selected = result_list[0] diff --git a/fastflix/widgets/panels/queue_panel.py b/fastflix/widgets/panels/queue_panel.py index 73c6b925..23dee7b1 100644 --- a/fastflix/widgets/panels/queue_panel.py +++ b/fastflix/widgets/panels/queue_panel.py @@ -90,7 +90,7 @@ def __init__(self, parent, video: Video, index, first=False): o["file_path"] = str(o["file_path"]) del settings.conversion_commands - title.setToolTip(settings.to_yaml()) + title.setToolTip(settings.video_encoder_settings.to_yaml()) open_button = QtWidgets.QPushButton( QtGui.QIcon(get_icon("play", self.parent.app.fastflix.config.theme)), t("Open Directory")