chromium/ash/system/brightness_control_delegate.h

// 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_