blob: d0f6e797f3eea662b6ba882f8c313b8e84d5bc68 [file] [log] [blame]
#ifndef GARNET_BIN_DISPLAY_MANAGER_DISPLAY_H_
#define GARNET_BIN_DISPLAY_MANAGER_DISPLAY_H_
#include <memory>
#include "display.h"
namespace display {
// The Display class is responsible for exposing display control. It
// encapsulates interacting with the driver via IOCTL in the Zircon layer.
class Display {
public:
// Default constructor, taking the IOCTL file descriptor for the display.
Display(int fd);
~Display();
// Instantiates an Display instance. For now, we only return the default
// embedded display. If there is an error retrieving the display, NULL is
// returned.
static Display* GetDisplay();
// Retrieves the backlight's current brightness. The brightness is set as a
// percentage of the max brightness. If successful, true will be returned.
// False otherwise.
bool GetBrightness(double* brightness);
// Sets the backlight's brightness. The brightness is specified as a
// percentage of the max brightness.
bool SetBrightness(double brightness);
private:
int fd_;
};
} // namespace display
#endif // GARNET_BIN_DISPLAY_MANAGER_DISPLAY_H_