2020-01-14 16:12:02 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2020 Inria
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup drivers_disp_dev Display device generic API
|
|
|
|
* @ingroup drivers_display
|
|
|
|
* @brief Define the generic API of a display device
|
|
|
|
* @experimental This API is experimental and in an early state - expect
|
|
|
|
* changes!
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @author Alexandre Abadie <alexandre.abadie@inria.fr>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef DISP_DEV_H
|
|
|
|
#define DISP_DEV_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2020-03-19 11:08:41 +01:00
|
|
|
#include "board.h"
|
|
|
|
|
|
|
|
#ifndef BACKLIGHT_ON
|
|
|
|
#define BACKLIGHT_ON
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef BACKLIGHT_OFF
|
|
|
|
#define BACKLIGHT_OFF
|
|
|
|
#endif
|
|
|
|
|
2020-01-14 16:12:02 +01:00
|
|
|
/**
|
|
|
|
* @brief Forward declaration for display device struct
|
|
|
|
*/
|
|
|
|
typedef struct disp_dev disp_dev_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Generic type for a display driver
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/**
|
|
|
|
* @brief Map an area to display on the device
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to the display device
|
|
|
|
* @param[in] x1 Left coordinate
|
|
|
|
* @param[in] x2 Right coordinate
|
|
|
|
* @param[in] y1 Top coordinate
|
|
|
|
* @param[in] y2 Bottom coordinate
|
|
|
|
* @param[in] color Array of color to map to the display
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
void (*map)(const disp_dev_t *dev,
|
2020-01-14 16:12:02 +01:00
|
|
|
uint16_t x1, uint16_t x2, uint16_t y1, uint16_t y2,
|
|
|
|
const uint16_t *color);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the height of the display device
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to the display device
|
|
|
|
*
|
|
|
|
* @return Height in pixels
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
uint16_t (*height)(const disp_dev_t *dev);
|
2020-01-14 16:12:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the width of the display device
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to the display device
|
|
|
|
*
|
|
|
|
* @return Width in pixels
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
uint16_t (*width)(const disp_dev_t *dev);
|
2020-01-14 16:12:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the color depth of the display device
|
|
|
|
*
|
|
|
|
* @return The color depth
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
uint8_t (*color_depth)(const disp_dev_t *dev);
|
2020-01-14 16:12:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Invert the display device colors
|
|
|
|
*
|
|
|
|
* @param[in] dev Network device descriptor
|
|
|
|
* @param[in] invert Invert mode (true if invert, false otherwise)
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
void (*set_invert)(const disp_dev_t *dev, bool invert);
|
2020-01-14 16:12:02 +01:00
|
|
|
} disp_dev_driver_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Generic type for a display device
|
|
|
|
*/
|
|
|
|
struct disp_dev {
|
|
|
|
const disp_dev_driver_t *driver; /**< Pointer to driver of the display device */
|
|
|
|
};
|
|
|
|
|
2020-06-21 18:16:21 +02:00
|
|
|
/**
|
|
|
|
* @brief Disp dev registry entry
|
|
|
|
*/
|
|
|
|
typedef struct disp_dev_reg {
|
|
|
|
struct disp_dev_reg *next; /**< pointer to the next display device in the list */
|
|
|
|
disp_dev_t *dev; /**< pointer to the device descriptor */
|
|
|
|
uint8_t screen_id; /**< id of the screen this display is attached to */
|
|
|
|
} disp_dev_reg_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Export the display device registry as global variable
|
|
|
|
*/
|
|
|
|
extern disp_dev_reg_t *disp_dev_reg;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Add pointer to a display device item to the list of display items
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to the display device
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -ENODEV on invalid entry
|
|
|
|
*/
|
|
|
|
int disp_dev_reg_add(disp_dev_reg_t *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Find the display device that is attached to a given screen
|
|
|
|
*
|
|
|
|
* @param[in] screen_id Identifier (number) of the screen
|
|
|
|
*
|
|
|
|
* @return pointer to the display device in the registry
|
|
|
|
* @return NULL if there's no match
|
|
|
|
*/
|
|
|
|
disp_dev_reg_t *disp_dev_reg_find_screen(uint8_t screen_id);
|
|
|
|
|
2020-01-14 16:12:02 +01:00
|
|
|
/**
|
|
|
|
* @brief Map an area to display on the device
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to the display device
|
|
|
|
* @param[in] x1 Left coordinate
|
|
|
|
* @param[in] x2 Right coordinate
|
|
|
|
* @param[in] y1 Top coordinate
|
|
|
|
* @param[in] y2 Bottom coordinate
|
|
|
|
* @param[in] color Array of color to map to the display
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
void disp_dev_map(const disp_dev_t *dev,
|
|
|
|
uint16_t x1, uint16_t x2, uint16_t y1, uint16_t y2,
|
|
|
|
const uint16_t *color);
|
2020-01-14 16:12:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the height of the display device
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to the display device
|
|
|
|
*
|
|
|
|
* @return Height in pixels
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
uint16_t disp_dev_height(const disp_dev_t *dev);
|
2020-01-14 16:12:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the width of the display device
|
|
|
|
*
|
|
|
|
* @param[in] dev Pointer to the display device
|
|
|
|
*
|
|
|
|
* @return Width in pixels
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
uint16_t disp_dev_width(const disp_dev_t *dev);
|
2020-01-14 16:12:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the color depth of the display device
|
|
|
|
*
|
|
|
|
* @return The color depth
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
uint8_t disp_dev_color_depth(const disp_dev_t *dev);
|
2020-01-14 16:12:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Invert the display device colors
|
|
|
|
*
|
2020-03-19 11:08:41 +01:00
|
|
|
* @param[in] dev Pointer to the display device
|
2020-01-14 16:12:02 +01:00
|
|
|
* @param[in] invert Invert mode (true if invert, false otherwise)
|
|
|
|
*/
|
2020-04-28 11:53:27 +02:00
|
|
|
void disp_dev_set_invert(const disp_dev_t *dev, bool invert);
|
2020-01-14 16:12:02 +01:00
|
|
|
|
2020-03-19 11:08:41 +01:00
|
|
|
/**
|
|
|
|
* @brief Enable the backlight pin
|
|
|
|
*/
|
|
|
|
static inline void disp_dev_backlight_on(void)
|
|
|
|
{
|
|
|
|
BACKLIGHT_ON;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Disable the backlight pin
|
|
|
|
*/
|
|
|
|
static inline void disp_dev_backlight_off(void)
|
|
|
|
{
|
|
|
|
BACKLIGHT_OFF;
|
|
|
|
}
|
|
|
|
|
2020-01-14 16:12:02 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* DISP_DEV_H */
|
|
|
|
/** @} */
|