blob: 53a9a75fbca066d254920d16965ac2c38e4a83ef [file] [log] [blame]
/*
* Copyright (C) 2021 The Android Open Source Project
*
* 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 android.hardware.display;
import android.annotation.IntDef;
import android.os.Parcel;
import android.os.Parcelable;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
/**
* Data about the current brightness state.
* {@see android.view.Display.getBrightnessInfo()}
*
* @hide
*/
public final class BrightnessInfo implements Parcelable {
@IntDef(prefix = {"HIGH_BRIGHTNESS_MODE_"}, value = {
HIGH_BRIGHTNESS_MODE_OFF,
HIGH_BRIGHTNESS_MODE_SUNLIGHT,
HIGH_BRIGHTNESS_MODE_HDR
})
@Retention(RetentionPolicy.SOURCE)
public @interface HighBrightnessMode {}
/**
* High brightness mode is OFF. The high brightness range is not currently accessible to the
* user.
*/
public static final int HIGH_BRIGHTNESS_MODE_OFF = 0;
/**
* High brightness mode is ON due to high ambient light (sunlight). The high brightness range is
* currently accessible to the user.
*/
public static final int HIGH_BRIGHTNESS_MODE_SUNLIGHT = 1;
/**
* High brightness mode is ON due to high ambient light (sunlight). The high brightness range is
* currently accessible to the user.
*/
public static final int HIGH_BRIGHTNESS_MODE_HDR = 2;
@IntDef(prefix = {"BRIGHTNESS_MAX_REASON_"}, value = {
BRIGHTNESS_MAX_REASON_NONE,
BRIGHTNESS_MAX_REASON_THERMAL,
BRIGHTNESS_MAX_REASON_POWER_IC
})
@Retention(RetentionPolicy.SOURCE)
public @interface BrightnessMaxReason {}
/**
* Maximum brightness is unrestricted.
*/
public static final int BRIGHTNESS_MAX_REASON_NONE = 0;
/**
* Maximum brightness is restricted due to thermal throttling.
*/
public static final int BRIGHTNESS_MAX_REASON_THERMAL = 1;
/**
* Maximum brightness is restricted due to power throttling.
*/
public static final int BRIGHTNESS_MAX_REASON_POWER_IC = 2;
/** Brightness */
public final float brightness;
/** Brightness after {@link DisplayPowerController} adjustments */
public final float adjustedBrightness;
/** Current minimum supported brightness. */
public final float brightnessMinimum;
/** Current maximum supported brightness. */
public final float brightnessMaximum;
/** Brightness values greater than this point are only used in High Brightness Mode. */
public final float highBrightnessTransitionPoint;
/**
* Current state of high brightness mode.
* Can be any of HIGH_BRIGHTNESS_MODE_* values.
*/
public final int highBrightnessMode;
/**
* The current reason for restricting maximum brightness.
* Can be any of BRIGHTNESS_MAX_REASON_* values.
*/
public final int brightnessMaxReason;
public BrightnessInfo(float brightness, float brightnessMinimum, float brightnessMaximum,
@HighBrightnessMode int highBrightnessMode, float highBrightnessTransitionPoint,
@BrightnessMaxReason int brightnessMaxReason) {
this(brightness, brightness, brightnessMinimum, brightnessMaximum, highBrightnessMode,
highBrightnessTransitionPoint, brightnessMaxReason);
}
public BrightnessInfo(float brightness, float adjustedBrightness, float brightnessMinimum,
float brightnessMaximum, @HighBrightnessMode int highBrightnessMode,
float highBrightnessTransitionPoint, @BrightnessMaxReason int brightnessMaxReason) {
this.brightness = brightness;
this.adjustedBrightness = adjustedBrightness;
this.brightnessMinimum = brightnessMinimum;
this.brightnessMaximum = brightnessMaximum;
this.highBrightnessMode = highBrightnessMode;
this.highBrightnessTransitionPoint = highBrightnessTransitionPoint;
this.brightnessMaxReason = brightnessMaxReason;
}
/**
* @return User-friendly string for specified {@link HighBrightnessMode} parameter.
*/
public static String hbmToString(@HighBrightnessMode int highBrightnessMode) {
switch (highBrightnessMode) {
case HIGH_BRIGHTNESS_MODE_OFF:
return "off";
case HIGH_BRIGHTNESS_MODE_HDR:
return "hdr";
case HIGH_BRIGHTNESS_MODE_SUNLIGHT:
return "sunlight";
}
return "invalid";
}
/**
* @return User-friendly string for specified {@link BrightnessMaxReason} parameter.
*/
public static String briMaxReasonToString(@BrightnessMaxReason int reason) {
switch (reason) {
case BRIGHTNESS_MAX_REASON_NONE:
return "none";
case BRIGHTNESS_MAX_REASON_THERMAL:
return "thermal";
case BRIGHTNESS_MAX_REASON_POWER_IC:
return "power IC";
}
return "invalid";
}
@Override
public int describeContents() {
return 0;
}
@Override
public void writeToParcel(Parcel dest, int flags) {
dest.writeFloat(brightness);
dest.writeFloat(adjustedBrightness);
dest.writeFloat(brightnessMinimum);
dest.writeFloat(brightnessMaximum);
dest.writeInt(highBrightnessMode);
dest.writeFloat(highBrightnessTransitionPoint);
dest.writeInt(brightnessMaxReason);
}
public static final @android.annotation.NonNull Creator<BrightnessInfo> CREATOR =
new Creator<BrightnessInfo>() {
@Override
public BrightnessInfo createFromParcel(Parcel source) {
return new BrightnessInfo(source);
}
@Override
public BrightnessInfo[] newArray(int size) {
return new BrightnessInfo[size];
}
};
private BrightnessInfo(Parcel source) {
brightness = source.readFloat();
adjustedBrightness = source.readFloat();
brightnessMinimum = source.readFloat();
brightnessMaximum = source.readFloat();
highBrightnessMode = source.readInt();
highBrightnessTransitionPoint = source.readFloat();
brightnessMaxReason = source.readInt();
}
}