commonMain.aws.sdk.kotlin.services.mediaconvert.model.H264QvbrSettings.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mediaconvert Show documentation
Show all versions of mediaconvert Show documentation
The AWS SDK for Kotlin client for MediaConvert
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.mediaconvert.model
/**
* Settings for quality-defined variable bitrate encoding with the H.264 codec. Use these settings only when you set QVBR for Rate control mode (RateControlMode).
*/
public class H264QvbrSettings private constructor(builder: Builder) {
/**
* Use this setting only when Rate control mode is QVBR and Quality tuning level is Multi-pass HQ. For Max average bitrate values suited to the complexity of your input video, the service limits the average bitrate of the video part of this output to the value that you choose. That is, the total size of the video element is less than or equal to the value you set multiplied by the number of seconds of encoded output.
*/
public val maxAverageBitrate: kotlin.Int = builder.maxAverageBitrate
/**
* Use this setting only when you set Rate control mode (RateControlMode) to QVBR. Specify the target quality level for this output. MediaConvert determines the right number of bits to use for each part of the video to maintain the video quality that you specify. When you keep the default value, AUTO, MediaConvert picks a quality level for you, based on characteristics of your input video. If you prefer to specify a quality level, specify a number from 1 through 10. Use higher numbers for greater quality. Level 10 results in nearly lossless compression. The quality level for most broadcast-quality transcodes is between 6 and 9. Optionally, to specify a value between whole numbers, also provide a value for the setting qvbrQualityLevelFineTune. For example, if you want your QVBR quality level to be 7.33, set qvbrQualityLevel to 7 and set qvbrQualityLevelFineTune to .33.
*/
public val qvbrQualityLevel: kotlin.Int = builder.qvbrQualityLevel
/**
* Optional. Specify a value here to set the QVBR quality to a level that is between whole numbers. For example, if you want your QVBR quality level to be 7.33, set qvbrQualityLevel to 7 and set qvbrQualityLevelFineTune to .33. MediaConvert rounds your QVBR quality level to the nearest third of a whole number. For example, if you set qvbrQualityLevel to 7 and you set qvbrQualityLevelFineTune to .25, your actual QVBR quality level is 7.33.
*/
public val qvbrQualityLevelFineTune: kotlin.Double = builder.qvbrQualityLevelFineTune
public companion object {
public operator fun invoke(block: Builder.() -> kotlin.Unit): aws.sdk.kotlin.services.mediaconvert.model.H264QvbrSettings = Builder().apply(block).build()
}
override fun toString(): kotlin.String = buildString {
append("H264QvbrSettings(")
append("maxAverageBitrate=$maxAverageBitrate,")
append("qvbrQualityLevel=$qvbrQualityLevel,")
append("qvbrQualityLevelFineTune=$qvbrQualityLevelFineTune")
append(")")
}
override fun hashCode(): kotlin.Int {
var result = maxAverageBitrate
result = 31 * result + (qvbrQualityLevel)
result = 31 * result + (qvbrQualityLevelFineTune.hashCode())
return result
}
override fun equals(other: kotlin.Any?): kotlin.Boolean {
if (this === other) return true
if (other == null || this::class != other::class) return false
other as H264QvbrSettings
if (maxAverageBitrate != other.maxAverageBitrate) return false
if (qvbrQualityLevel != other.qvbrQualityLevel) return false
if (qvbrQualityLevelFineTune != other.qvbrQualityLevelFineTune) return false
return true
}
public inline fun copy(block: Builder.() -> kotlin.Unit = {}): aws.sdk.kotlin.services.mediaconvert.model.H264QvbrSettings = Builder(this).apply(block).build()
public class Builder {
/**
* Use this setting only when Rate control mode is QVBR and Quality tuning level is Multi-pass HQ. For Max average bitrate values suited to the complexity of your input video, the service limits the average bitrate of the video part of this output to the value that you choose. That is, the total size of the video element is less than or equal to the value you set multiplied by the number of seconds of encoded output.
*/
public var maxAverageBitrate: kotlin.Int = 0
/**
* Use this setting only when you set Rate control mode (RateControlMode) to QVBR. Specify the target quality level for this output. MediaConvert determines the right number of bits to use for each part of the video to maintain the video quality that you specify. When you keep the default value, AUTO, MediaConvert picks a quality level for you, based on characteristics of your input video. If you prefer to specify a quality level, specify a number from 1 through 10. Use higher numbers for greater quality. Level 10 results in nearly lossless compression. The quality level for most broadcast-quality transcodes is between 6 and 9. Optionally, to specify a value between whole numbers, also provide a value for the setting qvbrQualityLevelFineTune. For example, if you want your QVBR quality level to be 7.33, set qvbrQualityLevel to 7 and set qvbrQualityLevelFineTune to .33.
*/
public var qvbrQualityLevel: kotlin.Int = 0
/**
* Optional. Specify a value here to set the QVBR quality to a level that is between whole numbers. For example, if you want your QVBR quality level to be 7.33, set qvbrQualityLevel to 7 and set qvbrQualityLevelFineTune to .33. MediaConvert rounds your QVBR quality level to the nearest third of a whole number. For example, if you set qvbrQualityLevel to 7 and you set qvbrQualityLevelFineTune to .25, your actual QVBR quality level is 7.33.
*/
public var qvbrQualityLevelFineTune: kotlin.Double = 0.0
@PublishedApi
internal constructor()
@PublishedApi
internal constructor(x: aws.sdk.kotlin.services.mediaconvert.model.H264QvbrSettings) : this() {
this.maxAverageBitrate = x.maxAverageBitrate
this.qvbrQualityLevel = x.qvbrQualityLevel
this.qvbrQualityLevelFineTune = x.qvbrQualityLevelFineTune
}
@PublishedApi
internal fun build(): aws.sdk.kotlin.services.mediaconvert.model.H264QvbrSettings = H264QvbrSettings(this)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy