mirror of
https://github.com/jellyfin/jellyfin-kodi.git
synced 2025-01-13 11:36:12 +00:00
Merge pull request #892 from Insprill/feature/transcode-av1
Add AV1 as a preferred codec option
This commit is contained in:
commit
fc1bcb36d4
3 changed files with 45 additions and 20 deletions
|
@ -390,6 +390,11 @@ class PlayUtils(object):
|
||||||
elif not settings("transcode_h265.bool"):
|
elif not settings("transcode_h265.bool"):
|
||||||
codecs.insert(1, "hevc")
|
codecs.insert(1, "hevc")
|
||||||
|
|
||||||
|
if settings("videoPreferredCodec") == "AV1":
|
||||||
|
codecs.insert(0, "av1")
|
||||||
|
elif not settings("transcode_av1.bool"):
|
||||||
|
codecs.append("av1")
|
||||||
|
|
||||||
if settings("transcode_mpeg2.bool"):
|
if settings("transcode_mpeg2.bool"):
|
||||||
codecs.remove("mpeg2video")
|
codecs.remove("mpeg2video")
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@
|
||||||
<setting label="30524" id="transcode_vc1" type="bool" default="false" visible="true" />
|
<setting label="30524" id="transcode_vc1" type="bool" default="false" visible="true" />
|
||||||
<setting label="30525" id="transcode_vp9" type="bool" default="false" visible="true" />
|
<setting label="30525" id="transcode_vp9" type="bool" default="false" visible="true" />
|
||||||
<setting label="30526" id="transcode_av1" type="bool" default="false" visible="true" />
|
<setting label="30526" id="transcode_av1" type="bool" default="false" visible="true" />
|
||||||
<setting label="30161" id="videoPreferredCodec" type="select" values="H264/AVC|H265/HEVC" visible="eq(-2,false)" default="H264/AVC" />
|
<setting label="30161" id="videoPreferredCodec" type="select" values="H264/AVC|H265/HEVC|AV1" visible="eq(-2,false)" default="H264/AVC" />
|
||||||
<setting label="30162" id="audioPreferredCodec" type="select" values="AAC|AC3|MP3|Opus|FLAC|Vorbis" visible="true" default="AAC" />
|
<setting label="30162" id="audioPreferredCodec" type="select" values="AAC|AC3|MP3|Opus|FLAC|Vorbis" visible="true" default="AAC" />
|
||||||
<setting label="30163" id="audioBitrate" type="enum" values="96|128|160|192|256|320|384" visible="true" default="4" />
|
<setting label="30163" id="audioBitrate" type="enum" values="96|128|160|192|256|320|384" visible="true" default="4" />
|
||||||
<setting label="30164" id="audioMaxChannels" type="slider" range="2,1,6" option="int" visible="true" default="6" />
|
<setting label="30164" id="audioMaxChannels" type="slider" range="2,1,6" option="int" visible="true" default="6" />
|
||||||
|
|
|
@ -56,18 +56,27 @@ def mock_settings(monkeypatch):
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
"transcode_h265, preferred_codec, expected_result",
|
"transcode_h265, transcode_av1, preferred_codec, expected_result",
|
||||||
[
|
[
|
||||||
(False, "H265/HEVC", "hevc,h264,mpeg4,mpeg2video,vc1"),
|
(False, True, "AV1", "av1,h264,hevc,mpeg4,mpeg2video,vc1"),
|
||||||
(True, "H265/HEVC", "hevc,h264,mpeg4,mpeg2video,vc1"),
|
(False, False, "AV1", "av1,h264,hevc,mpeg4,mpeg2video,vc1"),
|
||||||
(False, "H264/AVC", "h264,hevc,mpeg4,mpeg2video,vc1"),
|
(True, True, "AV1", "av1,h264,mpeg4,mpeg2video,vc1"),
|
||||||
(True, "H264/AVC", "h264,mpeg4,mpeg2video,vc1"),
|
(True, False, "AV1", "av1,h264,mpeg4,mpeg2video,vc1"),
|
||||||
|
(False, True, "H265/HEVC", "hevc,h264,mpeg4,mpeg2video,vc1"),
|
||||||
|
(False, False, "H265/HEVC", "hevc,h264,mpeg4,mpeg2video,vc1,av1"),
|
||||||
|
(True, True, "H265/HEVC", "hevc,h264,mpeg4,mpeg2video,vc1"),
|
||||||
|
(True, False, "H265/HEVC", "hevc,h264,mpeg4,mpeg2video,vc1,av1"),
|
||||||
|
(False, True, "H264/AVC", "h264,hevc,mpeg4,mpeg2video,vc1"),
|
||||||
|
(False, False, "H264/AVC", "h264,hevc,mpeg4,mpeg2video,vc1,av1"),
|
||||||
|
(True, True, "H264/AVC", "h264,mpeg4,mpeg2video,vc1"),
|
||||||
|
(True, False, "H264/AVC", "h264,mpeg4,mpeg2video,vc1,av1"),
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
def test_get_transcoding_video_codec_settings(
|
def test_get_transcoding_video_codec_settings(
|
||||||
play_utils, transcode_h265, preferred_codec, expected_result
|
play_utils, transcode_h265, transcode_av1, preferred_codec, expected_result
|
||||||
):
|
):
|
||||||
playutils.settings("transcode_h265", transcode_h265)
|
playutils.settings("transcode_h265", transcode_h265)
|
||||||
|
playutils.settings("transcode_av1", transcode_av1)
|
||||||
playutils.settings("videoPreferredCodec", preferred_codec)
|
playutils.settings("videoPreferredCodec", preferred_codec)
|
||||||
|
|
||||||
result = play_utils.get_transcoding_video_codec()
|
result = play_utils.get_transcoding_video_codec()
|
||||||
|
@ -77,10 +86,10 @@ def test_get_transcoding_video_codec_settings(
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
"transcode_mpeg2, transcode_vc1, expected_result",
|
"transcode_mpeg2, transcode_vc1, expected_result",
|
||||||
[
|
[
|
||||||
(False, False, "h264,hevc,mpeg4,mpeg2video,vc1"),
|
(False, False, "h264,hevc,mpeg4,mpeg2video,vc1,av1"),
|
||||||
(True, False, "h264,hevc,mpeg4,vc1"),
|
(True, False, "h264,hevc,mpeg4,vc1,av1"),
|
||||||
(False, True, "h264,hevc,mpeg4,mpeg2video"),
|
(False, True, "h264,hevc,mpeg4,mpeg2video,av1"),
|
||||||
(True, True, "h264,hevc,mpeg4"),
|
(True, True, "h264,hevc,mpeg4,av1"),
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
def test_get_transcoding_video_codec_transcode_options(
|
def test_get_transcoding_video_codec_transcode_options(
|
||||||
|
@ -109,28 +118,37 @@ def test_get_transcoding_video_codec_order(
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
"preferred_codec, transcode_h265",
|
"preferred_codec, transcode_h265, transcode_av1",
|
||||||
[
|
[
|
||||||
("H265/HEVC", True),
|
("H265/HEVC", True, True),
|
||||||
("H265/HEVC", False),
|
("H265/HEVC", True, False),
|
||||||
("H264/AVC", True),
|
("H265/HEVC", False, True),
|
||||||
("H264/AVC", False),
|
("H265/HEVC", False, False),
|
||||||
|
("H264/AVC", True, True),
|
||||||
|
("H264/AVC", True, False),
|
||||||
|
("H264/AVC", False, True),
|
||||||
|
("H264/AVC", False, False),
|
||||||
|
("AV1", True, True),
|
||||||
|
("AV1", True, False),
|
||||||
|
("AV1", False, True),
|
||||||
|
("AV1", False, False),
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
def test_get_transcoding_video_codec_no_duplicates(
|
def test_get_transcoding_video_codec_no_duplicates(
|
||||||
play_utils, preferred_codec, transcode_h265
|
play_utils, preferred_codec, transcode_h265, transcode_av1
|
||||||
):
|
):
|
||||||
playutils.settings("videoPreferredCodec", preferred_codec)
|
playutils.settings("videoPreferredCodec", preferred_codec)
|
||||||
playutils.settings("transcode_h265", transcode_h265)
|
playutils.settings("transcode_h265", transcode_h265)
|
||||||
|
playutils.settings("transcode_av1", transcode_av1)
|
||||||
result = play_utils.get_transcoding_video_codec().split(",")
|
result = play_utils.get_transcoding_video_codec().split(",")
|
||||||
assert len(result) == len(set(result))
|
assert len(result) == len(set(result))
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
"transcode_h265, preferred_codec, transcode_mpeg2, transcode_vc1, expected_result",
|
"transcode_h265, preferred_codec, transcode_mpeg2, transcode_vc1, transcode_av1, expected_result",
|
||||||
[
|
[
|
||||||
(True, "H264/AVC", True, True, "h264,mpeg4"),
|
(True, "H264/AVC", True, True, True, "h264,mpeg4"),
|
||||||
(False, "H265/HEVC", False, False, "hevc,h264,mpeg4,mpeg2video,vc1"),
|
(False, "H265/HEVC", False, False, False, "hevc,h264,mpeg4,mpeg2video,vc1,av1"),
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
def test_get_transcoding_video_codec_combined_settings(
|
def test_get_transcoding_video_codec_combined_settings(
|
||||||
|
@ -139,12 +157,14 @@ def test_get_transcoding_video_codec_combined_settings(
|
||||||
preferred_codec,
|
preferred_codec,
|
||||||
transcode_mpeg2,
|
transcode_mpeg2,
|
||||||
transcode_vc1,
|
transcode_vc1,
|
||||||
|
transcode_av1,
|
||||||
expected_result,
|
expected_result,
|
||||||
):
|
):
|
||||||
playutils.settings("transcode_h265", transcode_h265)
|
playutils.settings("transcode_h265", transcode_h265)
|
||||||
playutils.settings("videoPreferredCodec", preferred_codec)
|
playutils.settings("videoPreferredCodec", preferred_codec)
|
||||||
playutils.settings("transcode_mpeg2", transcode_mpeg2)
|
playutils.settings("transcode_mpeg2", transcode_mpeg2)
|
||||||
playutils.settings("transcode_vc1", transcode_vc1)
|
playutils.settings("transcode_vc1", transcode_vc1)
|
||||||
|
playutils.settings("transcode_av1", transcode_av1)
|
||||||
|
|
||||||
result = play_utils.get_transcoding_video_codec()
|
result = play_utils.get_transcoding_video_codec()
|
||||||
assert result == expected_result
|
assert result == expected_result
|
||||||
|
|
Loading…
Reference in a new issue