All Downloads are FREE. Search and download functionalities are using the official Maven repository.

software.amazon.awssdk.services.mediaconvert.model.ImageInserter Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Elemental MediaConvert module holds the client classes that are used for communicating with AWS Elemental MediaConvert Service

There is a newer version: 2.29.15
Show newest version
/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */

package software.amazon.awssdk.services.mediaconvert.model;

import java.io.Serializable;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * Use the image inserter feature to include a graphic overlay on your video. Enable or disable this feature for each
 * input or output individually. For more information, see
 * https://docs.aws.amazon.com/mediaconvert/latest/ug/graphic-overlay.html. This setting is disabled by default.
 */
@Generated("software.amazon.awssdk:codegen")
public final class ImageInserter implements SdkPojo, Serializable, ToCopyableBuilder {
    private static final SdkField> INSERTABLE_IMAGES_FIELD = SdkField
            .> builder(MarshallingType.LIST)
            .memberName("InsertableImages")
            .getter(getter(ImageInserter::insertableImages))
            .setter(setter(Builder::insertableImages))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("insertableImages").build(),
                    ListTrait
                            .builder()
                            .memberLocationName(null)
                            .memberFieldInfo(
                                    SdkField. builder(MarshallingType.SDK_POJO)
                                            .constructor(InsertableImage::builder)
                                            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
                                                    .locationName("member").build()).build()).build()).build();

    private static final SdkField SDR_REFERENCE_WHITE_LEVEL_FIELD = SdkField. builder(MarshallingType.INTEGER)
            .memberName("SdrReferenceWhiteLevel").getter(getter(ImageInserter::sdrReferenceWhiteLevel))
            .setter(setter(Builder::sdrReferenceWhiteLevel))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("sdrReferenceWhiteLevel").build())
            .build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(INSERTABLE_IMAGES_FIELD,
            SDR_REFERENCE_WHITE_LEVEL_FIELD));

    private static final long serialVersionUID = 1L;

    private final List insertableImages;

    private final Integer sdrReferenceWhiteLevel;

    private ImageInserter(BuilderImpl builder) {
        this.insertableImages = builder.insertableImages;
        this.sdrReferenceWhiteLevel = builder.sdrReferenceWhiteLevel;
    }

    /**
     * For responses, this returns true if the service returned a value for the InsertableImages property. This DOES NOT
     * check that the value is non-empty (for which, you should check the {@code isEmpty()} method on the property).
     * This is useful because the SDK will never return a null collection or map, but you may need to differentiate
     * between the service returning nothing (or null) and the service returning an empty collection or map. For
     * requests, this returns true if a value for the property was specified in the request builder, and false if a
     * value was not specified.
     */
    public final boolean hasInsertableImages() {
        return insertableImages != null && !(insertableImages instanceof SdkAutoConstructList);
    }

    /**
     * Specify the images that you want to overlay on your video. The images must be PNG or TGA files.
     * 

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

*

* This method will never return null. If you would like to know whether the service returned this field (so that * you can differentiate between null and empty), you can use the {@link #hasInsertableImages} method. *

* * @return Specify the images that you want to overlay on your video. The images must be PNG or TGA files. */ public final List insertableImages() { return insertableImages; } /** * Specify the reference white level, in nits, for all of your image inserter images. Use to correct brightness * levels within HDR10 outputs. For 1,000 nit peak brightness displays, we recommend that you set SDR reference * white level to 203 (according to ITU-R BT.2408). Leave blank to use the default value of 100, or specify an * integer from 100 to 1000. * * @return Specify the reference white level, in nits, for all of your image inserter images. Use to correct * brightness levels within HDR10 outputs. For 1,000 nit peak brightness displays, we recommend that you set * SDR reference white level to 203 (according to ITU-R BT.2408). Leave blank to use the default value of * 100, or specify an integer from 100 to 1000. */ public final Integer sdrReferenceWhiteLevel() { return sdrReferenceWhiteLevel; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(hasInsertableImages() ? insertableImages() : null); hashCode = 31 * hashCode + Objects.hashCode(sdrReferenceWhiteLevel()); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof ImageInserter)) { return false; } ImageInserter other = (ImageInserter) obj; return hasInsertableImages() == other.hasInsertableImages() && Objects.equals(insertableImages(), other.insertableImages()) && Objects.equals(sdrReferenceWhiteLevel(), other.sdrReferenceWhiteLevel()); } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. */ @Override public final String toString() { return ToString.builder("ImageInserter").add("InsertableImages", hasInsertableImages() ? insertableImages() : null) .add("SdrReferenceWhiteLevel", sdrReferenceWhiteLevel()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "InsertableImages": return Optional.ofNullable(clazz.cast(insertableImages())); case "SdrReferenceWhiteLevel": return Optional.ofNullable(clazz.cast(sdrReferenceWhiteLevel())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((ImageInserter) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** * Specify the images that you want to overlay on your video. The images must be PNG or TGA files. * * @param insertableImages * Specify the images that you want to overlay on your video. The images must be PNG or TGA files. * @return Returns a reference to this object so that method calls can be chained together. */ Builder insertableImages(Collection insertableImages); /** * Specify the images that you want to overlay on your video. The images must be PNG or TGA files. * * @param insertableImages * Specify the images that you want to overlay on your video. The images must be PNG or TGA files. * @return Returns a reference to this object so that method calls can be chained together. */ Builder insertableImages(InsertableImage... insertableImages); /** * Specify the images that you want to overlay on your video. The images must be PNG or TGA files. This is a * convenience method that creates an instance of the * {@link software.amazon.awssdk.services.mediaconvert.model.InsertableImage.Builder} avoiding the need to * create one manually via {@link software.amazon.awssdk.services.mediaconvert.model.InsertableImage#builder()}. * *

* When the {@link Consumer} completes, * {@link software.amazon.awssdk.services.mediaconvert.model.InsertableImage.Builder#build()} is called * immediately and its result is passed to {@link #insertableImages(List)}. * * @param insertableImages * a consumer that will call methods on * {@link software.amazon.awssdk.services.mediaconvert.model.InsertableImage.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #insertableImages(java.util.Collection) */ Builder insertableImages(Consumer... insertableImages); /** * Specify the reference white level, in nits, for all of your image inserter images. Use to correct brightness * levels within HDR10 outputs. For 1,000 nit peak brightness displays, we recommend that you set SDR reference * white level to 203 (according to ITU-R BT.2408). Leave blank to use the default value of 100, or specify an * integer from 100 to 1000. * * @param sdrReferenceWhiteLevel * Specify the reference white level, in nits, for all of your image inserter images. Use to correct * brightness levels within HDR10 outputs. For 1,000 nit peak brightness displays, we recommend that you * set SDR reference white level to 203 (according to ITU-R BT.2408). Leave blank to use the default * value of 100, or specify an integer from 100 to 1000. * @return Returns a reference to this object so that method calls can be chained together. */ Builder sdrReferenceWhiteLevel(Integer sdrReferenceWhiteLevel); } static final class BuilderImpl implements Builder { private List insertableImages = DefaultSdkAutoConstructList.getInstance(); private Integer sdrReferenceWhiteLevel; private BuilderImpl() { } private BuilderImpl(ImageInserter model) { insertableImages(model.insertableImages); sdrReferenceWhiteLevel(model.sdrReferenceWhiteLevel); } public final List getInsertableImages() { List result = ___listOfInsertableImageCopier.copyToBuilder(this.insertableImages); if (result instanceof SdkAutoConstructList) { return null; } return result; } public final void setInsertableImages(Collection insertableImages) { this.insertableImages = ___listOfInsertableImageCopier.copyFromBuilder(insertableImages); } @Override public final Builder insertableImages(Collection insertableImages) { this.insertableImages = ___listOfInsertableImageCopier.copy(insertableImages); return this; } @Override @SafeVarargs public final Builder insertableImages(InsertableImage... insertableImages) { insertableImages(Arrays.asList(insertableImages)); return this; } @Override @SafeVarargs public final Builder insertableImages(Consumer... insertableImages) { insertableImages(Stream.of(insertableImages).map(c -> InsertableImage.builder().applyMutation(c).build()) .collect(Collectors.toList())); return this; } public final Integer getSdrReferenceWhiteLevel() { return sdrReferenceWhiteLevel; } public final void setSdrReferenceWhiteLevel(Integer sdrReferenceWhiteLevel) { this.sdrReferenceWhiteLevel = sdrReferenceWhiteLevel; } @Override public final Builder sdrReferenceWhiteLevel(Integer sdrReferenceWhiteLevel) { this.sdrReferenceWhiteLevel = sdrReferenceWhiteLevel; return this; } @Override public ImageInserter build() { return new ImageInserter(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy