* Rename ExperimentalSettingsView.swift to PlaybackQualitySettingsView.swift Fix Merge * Rename MaximumBitrateSettingsView.swift to PlaybackQualitySettingsView.swift fix merge * Re-implement on Main. Should now have all the Main changed. Added a new change to use the Device Profile as a Transcoding Profile. * Part 1 -> Making VideoPlayerType into a struct (I Hope) correctly * Part 1.1 -> Making VideoPlayerType into a struct (I Hope) correctly * Remove unneeded Files * Missing file + CustomDeviceProfileSelection -> CustomDeviceProfileAction Rename * Change + to Appending * Attempt to add StorageValues+User. Not sure if this is correct? * Move the Array unwrapping to funcitons. Not required but this should help prevent accidently doing this wrong. Add subtitles back into the custom profiles since that somehow got dropped. Added a PlaybackCompatibility enum. This might need to work for more than just video * Complete rewrite to allow multiple profiles, compatibility mode, and directplay. * Hardward -> Hardware * Update CustomDeviceProfileSettingsView.swift Double Licensing * It was actually really easy to implement iOS... Trash cans still look weird and small. * Swipe to Delete instead of the edit button * wip * wip * Linting * tvOS Implementation * wip * wip * cleanup * Create Package.resolved --------- Co-authored-by: Joseph Kribs <joseph@kribs.net> Co-authored-by: Ethan Pippin <ethanpippin2343@gmail.com>
56 lines
2.0 KiB
Swift
56 lines
2.0 KiB
Swift
//
|
|
// Swiftfin is subject to the terms of the Mozilla Public
|
|
// License, v2.0. If a copy of the MPL was not distributed with this
|
|
// file, you can obtain one at https://mozilla.org/MPL/2.0/.
|
|
//
|
|
// Copyright (c) 2024 Jellyfin & Jellyfin Contributors
|
|
//
|
|
|
|
import Foundation
|
|
import JellyfinAPI
|
|
|
|
extension TranscodingProfile {
|
|
|
|
init(
|
|
isBreakOnNonKeyFrames: Bool? = nil,
|
|
conditions: [ProfileCondition]? = nil,
|
|
context: EncodingContext? = nil,
|
|
isCopyTimestamps: Bool? = nil,
|
|
enableMpegtsM2TsMode: Bool? = nil,
|
|
enableSubtitlesInManifest: Bool? = nil,
|
|
isEstimateContentLength: Bool? = nil,
|
|
maxAudioChannels: String? = nil,
|
|
minSegments: Int? = nil,
|
|
protocol: String? = nil,
|
|
segmentLength: Int? = nil,
|
|
transcodeSeekInfo: TranscodeSeekInfo? = nil,
|
|
type: DlnaProfileType? = nil,
|
|
@CommaStringBuilder<AudioCodec> audioCodecs: () -> String = { "" },
|
|
@CommaStringBuilder<VideoCodec> videoCodecs: () -> String = { "" },
|
|
@CommaStringBuilder<MediaContainer> containers: () -> String = { "" }
|
|
) {
|
|
let audioCodecs = audioCodecs()
|
|
let videoCodecs = videoCodecs()
|
|
let containers = containers()
|
|
|
|
self.init(
|
|
audioCodec: audioCodecs.isEmpty ? nil : audioCodecs,
|
|
isBreakOnNonKeyFrames: isBreakOnNonKeyFrames,
|
|
conditions: conditions,
|
|
container: containers.isEmpty ? nil : containers,
|
|
context: context,
|
|
isCopyTimestamps: isCopyTimestamps,
|
|
enableMpegtsM2TsMode: enableMpegtsM2TsMode,
|
|
enableSubtitlesInManifest: enableSubtitlesInManifest,
|
|
isEstimateContentLength: isEstimateContentLength,
|
|
maxAudioChannels: maxAudioChannels,
|
|
minSegments: minSegments,
|
|
protocol: `protocol`,
|
|
segmentLength: segmentLength,
|
|
transcodeSeekInfo: transcodeSeekInfo,
|
|
type: type,
|
|
videoCodec: videoCodecs.isEmpty ? nil : videoCodecs
|
|
)
|
|
}
|
|
}
|