chromium/third_party/tflite_support/src/tensorflow_lite_support/odml/java/image/src/com/google/android/odml/image/ImageProperties.java

/* Copyright 2021 Google LLC. 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.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License 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 com.google.android.odml.image;

import com.google.android.odml.image.MlImage.ImageFormat;
import com.google.android.odml.image.MlImage.StorageType;
import com.google.android.odml.image.annotation.KeepForSdk;
import com.google.auto.value.AutoValue;
import com.google.auto.value.extension.memoized.Memoized;

/** Groups a set of properties to describe how an image is stored. */
@AutoValue
public abstract class ImageProperties {

  /**
   * Gets the pixel format of the image.
   *
   * @see MlImage.ImageFormat
   */
  @ImageFormat
  public abstract int getImageFormat();

  /**
   * Gets the storage type of the image.
   *
   * @see MlImage.StorageType
   */
  @StorageType
  public abstract int getStorageType();

  @Memoized
  @Override
  public abstract int hashCode();

  /**
   * Creates a builder of {@link ImageProperties}.
   *
   * @see ImageProperties.Builder
   */
  @KeepForSdk
  static Builder builder() {
    return new AutoValue_ImageProperties.Builder();
  }

  /** Builds a {@link ImageProperties}. */
  @AutoValue.Builder
  @KeepForSdk
  abstract static class Builder {

    /**
     * Sets the {@link MlImage.ImageFormat}.
     *
     * @see ImageProperties#getImageFormat
     */
    @KeepForSdk
    abstract Builder setImageFormat(@ImageFormat int value);

    /**
     * Sets the {@link MlImage.StorageType}.
     *
     * @see ImageProperties#getStorageType
     */
    @KeepForSdk
    abstract Builder setStorageType(@StorageType int value);

    /** Builds the {@link ImageProperties}. */
    @KeepForSdk
    abstract ImageProperties build();
  }

  // Hide the constructor.
  ImageProperties() {}
}