// Copyright 2013 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ASH_SYSTEM_BRIGHTNESS_CONTROL_DELEGATE_H_
#define ASH_SYSTEM_BRIGHTNESS_CONTROL_DELEGATE_H_
#include <optional>
#include "base/functional/callback.h"
#include "base/functional/callback_forward.h"
namespace ash {
// Delegate for controlling the brightness.
class BrightnessControlDelegate {
public:
virtual ~BrightnessControlDelegate() {}
// Handles an accelerator-driven request to decrease or increase the screen
// brightness.
virtual void HandleBrightnessDown() = 0;
virtual void HandleBrightnessUp() = 0;
// Enum to represent the source of a brightness change, i.e. what triggered
// the brightness change.
enum class BrightnessChangeSource {
kUnknown = 0,
kQuickSettings = 1,
kSettingsApp = 2,
kRestoredFromUserPref = 3,
kMaxValue = kRestoredFromUserPref,
};
// Enum to represent the source of a ambient light sensor change,
// Note that changing brightness can also disable the Ambient Light
// Sensor. This change is not directly made by calling the
// SetAmbientLightSensorEnabled function in the BrightnessControlDelegate in
// Chrome, it is handled in the platform.
enum class AmbientLightSensorEnabledChangeSource {
kSettingsApp = 0,
kRestoredFromUserPref = 1,
kSystemReenabled = 2,
kMaxValue = kSystemReenabled,
};
// Requests that the brightness be set to |percent|, in the range
// [0.0, 100.0]. |gradual| specifies whether the transition to the new
// brightness should be animated or instantaneous. |source| is required to
// indicate what is causing this brightness change.
virtual void SetBrightnessPercent(double percent,
bool gradual,
BrightnessChangeSource source) = 0;
// Asynchronously invokes |callback| with the current brightness, in the range
// [0.0, 100.0]. In case of error, it is called with nullopt.
virtual void GetBrightnessPercent(
base::OnceCallback<void(std::optional<double>)> callback) = 0;
// Sets whether the ambient light sensor should be used in brightness
// calculations.
virtual void SetAmbientLightSensorEnabled(
bool enabled,
AmbientLightSensorEnabledChangeSource source) = 0;
// Asynchronously invokes |callback| with true if the ambient light sensor is
// enabled (i.e. if the ambient light sensor is currently being used in
// brightness calculations). In case of error, |callback| will be run with
// nullopt.
virtual void GetAmbientLightSensorEnabled(
base::OnceCallback<void(std::optional<bool>)> callback) = 0;
// Asynchronously invokes |callback| with true if the device has at least one
// ambient light sensor. In case of error, |callback| will be run with
// nullopt.
virtual void HasAmbientLightSensor(
base::OnceCallback<void(std::optional<bool>)> callback) = 0;
};
} // namespace ash
#endif // ASH_SYSTEM_BRIGHTNESS_CONTROL_DELEGATE_H_