Визуальные темы
Визуальные темы
Подcистема Theme предоставляет удобный способ централизованного хранения визуальных настроек. Подсистема предназначена для единобразного отображения контролов приложения и легкой централизованной смены текущей темы на другую на лету.
Подсистема предоставляет удобные хелперы для работы с темами. Данные хелперы оперируют синглтоном который по умолчанию используют все контролы приложения. Подсистема позволяет звгрузить тему из json который может храниться на диске или быть ресурсом Windows приложения.
Пример json файла содержащий визуальные параметры основных контролов.
Несмотря на то, что в приложении всегда есть тема по умолчанию, вы можете создать свою кастомную тему и указать любому контролу ее для использования. В таком случае, контрол будет отображаться в соответствии с вашей темой.
Ниже представлены основные хелперы для централизованной работы с темой приложения. Данные хелперы по сути представляют доступ к синглтону инстанса темы по умолчанию приложения.
Хелперы
namespace wui
{
/// Set and get the current theme
#ifdef _WIN32
bool set_default_theme_from_resource(const std::string &name, int32_t resource_index, const std::string &resource_section);
#endif
bool set_default_theme_from_json(const std::string &name, const std::string &json);
bool set_default_theme_from_file(const std::string &name, const std::string &file_name);
void set_default_theme_empty(const std::string &name);
/// Return the pointer to current default theme instance
std::shared_ptr<i_theme> get_default_theme();
/// Make the custom theme for the some control
std::shared_ptr<i_theme> make_custom_theme(const std::string &name = "");
std::shared_ptr<i_theme> make_custom_theme(const std::string &name, const std::string &json);
/// Return the item's color by current theme
color theme_color(const std::string &control, const std::string &value, std::shared_ptr<i_theme> theme_ = nullptr);
/// Return the item's dimension by current theme
int32_t theme_dimension(const std::string &control, const std::string &value, std::shared_ptr<i_theme> theme_ = nullptr);
/// Return the item's string value by current theme
const std::string &theme_string(const std::string &control, const std::string &value, std::shared_ptr<i_theme> theme_ = nullptr);
/// Return the item's font value by current theme
font theme_font(const std::string &control, const std::string &value, std::shared_ptr<i_theme> theme_ = nullptr);
const std::vector<uint8_t> &theme_image(const std::string &name, std::shared_ptr<i_theme> theme_ = nullptr);
set_default_theme_from_resource (Windows only)
Входные параметры
- const std::string &name - имя темы, например "dark"
- int32_t resource_index - ID ресурса
- const std::string &resource_section - секция ресурсов, например "JSONS"
Возвращаемое значение
- true в случае успеха
Функция загружающая дефолтную тему приложения из json файла который хранится в ресурсе приложения.
Пример:
#ifdef _WIN32
auto ok = wui::set_default_theme_from_resource("dark", TXT_DARK_THEME, "JSONS");
if (!ok)
{
std::cerr << "can't load theme" << std::endl;
return -1;
}
#endif
set_default_theme_from_json
Входные параметры
- const std::string &name - имя темы
- const std::string &json - строка содержащая json темы
Возвращаемое значение
- true в случае успеха
Функция загружающая дефолтную тему приложения из json строки
set_default_theme_from_file
Входные параметры
- const std::string &name - имя темы
- const std::string &file_name - путь к json файлу темы
Возвращаемое значение
- true в случае успеха
Функция загружающая дефолтную тему приложения из json файла
Пример:
#ifdef _WIN32
...
#else
auto ok = wui::set_default_theme_from_file("dark", "res/dark.json");
if (!ok)
{
std::cerr << "can't load theme" << std::endl;
return -1;
}
#endif
set_default_theme_empty
Входные параметры
- const std::string &name - имя темы
Устанавливает в текущую тему пустую тему, например для последующей настройки ее при помощи сеттеров инстанса.
get_default_theme
Возвращаемое значение
- std::shared_ptr<i_theme> - указатель на инстанс темы по умолчанию
Возвращает указатель на инстанс темы по умолчанию
make_custom_theme
Входные параметры
- const std::string &name - имя темы
Возвращаемое значение
- std::shared_ptr<i_theme> - указатель на инстанс созданной темы
Создает и возвращает указатель на пустую кастомную тему. Предназначена для использования в отдельном контроле или группе контролов.
make_custom_theme
Входные параметры
- const std::string &name - имя темы
- const std::string &json - строка содержащая json темы
Возвращаемое значение
- std::shared_ptr<i_theme> - указатель на инстанс созданной темы
Создает и возвращает указатель на кастомную тему загруженную из json. Предназначена для использования в отдельном контроле или группе контролов.
theme_color
Входные параметры
- const std::string &control - имя контрола, например "button"
- const std::string &value - название цвета, например "active"
- std::shared_ptr<i_theme> theme_ = nullptr - указатель на инстанс темы, если nullptr - берется тема по умолчанию
Возвращаемое значение
- color - запрошенный цвет
Возвращает цвет для значения value
контрола control
. Параметр theme_
может содержать инстанс кастомной темы или быть опущен, тогда будет взят цвет из темы по умолчанию.
Пример:
auto fill_color = enabled_ ? (active || turned_ ? theme_color(tcn, tv_active, theme_) : theme_color(tcn, tv_calm, theme_)) : theme_color(tcn, tv_disabled, theme_);
Где:
tcn = "button";
tv_active = "active";
tv_calm = "calm";
tv_disabled = "disabled";
Фрагмент json темы:
{
"type": "button",
"calm": "#06a5df",
"active": "#1aafe9",
"disabled": "#a5a5a0"
}
theme_dimension
Входные параметры
- const std::string &control - имя контрола, например "button"
- const std::string &value - название размера, например "border_width"
- std::shared_ptr<i_theme> theme_ = nullptr - указатель на инстанс темы, если nullptr - берется тема по умолчанию
Возвращаемое значение
- int32_t - запрошенный размер
Возвращает размер для значения value
контрола control
. Параметр theme_
может содержать инстанс кастомной темы или быть опущен, тогда будет взят размер из темы по умолчанию.
theme_string
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название строки
- std::shared_ptr<i_theme> theme_ = nullptr - указатель на инстанс темы, если nullptr - берется тема по умолчанию
Возвращаемое значение
- const std::string & - ссылка на запрошенную строку
Возвращает строку для значения value
контрола control
. Параметр theme_
может содержать инстанс кастомной темы или быть опущен, тогда будет взята строка из темы по умолчанию.
theme_font
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название шрифта, например "caption_font"
- std::shared_ptr<i_theme> theme_ = nullptr - указатель на инстанс темы, если nullptr - берется тема по умолчанию
Возвращаемое значение
- font - запрошенный шрифт
Возвращает шрифт для значения value
контрола control
. Параметр theme_
может содержать инстанс кастомной темы или быть опущен, тогда будет взят шрифт из темы по умолчанию.
theme_image
Входные параметры
- const std::string &name - имя изображения
- std::shared_ptr<i_theme> theme_ = nullptr - указатель на инстанс темы, если nullptr - берется тема по умолчанию
Возвращаемое значение
- const std::vector<uint8_t>& - запрошенное изображение
Возвращает массив байтов содержащий изображение темы для значения value
контрола control
. Тема поддеживает хранение изображений в json в виде экранированного массива. Также массив может быть загружен в тему сеттером инстанса.
Пример json:
"images": [
{ "window_expand": "0x89, 0x50, 0x4E, 0x47, 0x0D, 0x0A, 0x1A, 0x0A, 0x00, 0x00, 0x00, 0x0D, 0x49, 0x48, 0x44, 0x52, 0x00, 0x00, 0x00, 0x19, 0x00, 0x00, 0x00, 0x19, 0x08, 0x06, 0x00, 0x00, 0x00, 0xC4, 0xE9, 0x85, 0x63, 0x00, 0x00, 0x00, 0x09, 0x70, 0x48, 0x59, 0x73, 0x00, 0x00, 0x0B, 0x13, 0x00, 0x00, 0x0B, 0x13, 0x01, 0x00, 0x9A, 0x9C, 0x18, 0x00, 0x00, 0x00, 0x19, 0x74, 0x45, 0x58, 0x74, 0x53, 0x6F, 0x66, 0x74, 0x77, 0x61, 0x72, 0x65, 0x00, 0x41, 0x64, 0x6F, 0x62, 0x65, 0x20, 0x49, 0x6D, 0x61, 0x67, 0x65, 0x52, 0x65, 0x61, 0x64, 0x79, 0x71, 0xC9, 0x65, 0x3C, 0x00, 0x00, 0x00, 0x64, 0x49, 0x44, 0x41, 0x54, 0x78, 0xDA, 0x62, 0xFC, 0xFF, 0xFF, 0x3F, 0x03, 0xAD, 0x01, 0x13, 0x03, 0x1D, 0xC0, 0xA8, 0x25, 0x23, 0xD4, 0x12, 0x16, 0x6C, 0x82, 0x17, 0x2E, 0x9D, 0x9B, 0x00, 0xA4, 0x0C, 0x48, 0x35, 0xCC, 0x40, 0xCF, 0xC8, 0x81, 0x14, 0x9F, 0x18, 0x90, 0x68, 0x89, 0x02, 0x10, 0xDB, 0x93, 0xE4, 0x13, 0x98, 0x87, 0x70, 0xB9, 0x0C, 0x8B, 0xCF, 0x1B, 0x80, 0x54, 0xFD, 0x68, 0xEA, 0x1A, 0xB5, 0x64, 0x90, 0x64, 0x46, 0x58, 0xDA, 0x87, 0x26, 0x4D, 0x62, 0x80, 0x03, 0xB9, 0x96, 0xC8, 0xE3, 0x4B, 0xFB, 0xA4, 0x00, 0xC6, 0xD1, 0x9A, 0x71, 0xD4, 0x92, 0xA1, 0x6D, 0x09, 0x40, 0x80, 0x01, 0x00, 0x94, 0xC7, 0x13, 0xEF, 0xA5, 0x34, 0x2A, 0xAF, 0x00, 0x00, 0x00, 0x00, 0x49, 0x45, 0x4E, 0x44, 0xAE, 0x42, 0x60, 0x82" }
]
Интерфейс инстанса темы
class i_theme
{
public:
virtual std::string get_name() const = 0;
virtual void set_color(const std::string &control, const std::string &value, color color_) = 0;
virtual color get_color(const std::string &control, const std::string &value) const = 0;
virtual void set_dimension(const std::string &control, const std::string &value, int32_t dimension) = 0;
virtual int32_t get_dimension(const std::string &control, const std::string &value) const = 0;
virtual void set_string(const std::string &control, const std::string &value, const std::string &str) = 0;
virtual const std::string &get_string(const std::string &control, const std::string &value) const = 0;
virtual void set_font(const std::string &control, const std::string &value, const font &font_) = 0;
virtual font get_font(const std::string &control, const std::string &value) const = 0;
virtual void set_image(const std::string &name, const std::vector<uint8_t> &data) = 0;
virtual const std::vector<uint8_t> &get_image(const std::string &name) = 0;
#ifdef _WIN32
virtual void load_resource(int32_t resource_index, const std::string &resource_section) = 0;
#endif
virtual void load_json(const std::string &json) = 0;
virtual void load_file(const std::string &file_name) = 0;
virtual void load_theme(const i_theme &theme_) = 0;
virtual bool is_ok() const = 0;
virtual ~i_theme() {}
};
Каждый контрол принимает данный интерфейс того, чтобы получать визуальные параметры своего отображения.
get_name
Возвращаемое значение
- const std::string - имя инстанса темы
Возвращает символьное имя темы, например
"dark"
или"light"
set_color
Входные параметры
- const std::string &control - имя контрола, например "button"
- const std::string &value - название цвета, например "active"
- color color_ - устанавливаемый цвет
Устанавливает цвет для значения value
контрола control
Например:
auto redButtonTheme = wui::make_custom_theme(); // Создаем новую кастомную тему
redButtonTheme->load_theme(*wui::get_default_theme()); // Загружаем ее из дефолтной, чтобы не устанавливать все значения
redButtonTheme->set_color(wui::button::tc, wui::button::tv_calm, wui::make_color(205, 15, 20)); // Устанавливаем цвет заливки кнопки в режиме покоя
... Используем новую тему при создании кнопки или применяем ее к имеющейся
Где:
wui::button::tc = "button";
wui::button::tv_calm = "calm";
Что означает данный цвет будет применен к контролу с названием "button"
в состоянии покоя "calm"
get_color
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название цвета
Возвращаемое значение
- color - запрошенный цвет
Возвращает цвет для значения value
контрола control
set_dimension
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название размера
- int32_t dimension - устанавливаемый размер
Устанавливает размер для значения value
контрола control
get_dimension
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название размера
Возвращаемое значение
- int32_t - запрошенный размер
Возвращает размер для значения value
контрола control
set_string
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название строки
- const std::string &str - устанавливаемая строка
Устанавливает строку для значения value
контрола control
get_string
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название строки
Возвращаемое значение
- const std::string & - ссылка на запрошенную строку
Возвращает строку для значения value
контрола control
set_font
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название шрифта
- const font &font_ - устанавливаемый шрифт
Устанавливает шрифт для значения value
контрола control
get_font
Входные параметры
- const std::string &control - имя контрола
- const std::string &value - название шрифта
Возвращаемое значение
- font - запрошенный шрифт
Возвращает шрифт для значения value
контрола control
set_image
Входные параметры
- const std::string &name - имя изображения
- const std::vector<uint8_t> &data - устанавливаемое изображение
Устанавливает изображение с именем name
из массива байтов data
get_image
Входные параметры
- const std::string &name - имя изображения
Возвращаемое значение
- const std::vector<uint8_t> & - запрошенное изображение
Возвращает ссылку на массив байтов содержащий изображение темы для значения value
контрола control
load_resource (Windows only)
Входные параметры
- int32_t resource_index - ID ресурса
- const std::string &resource_section - секция ресурсов, например "JSONS"
Функция загружающая тему из json файла который хранится в ресурсе приложения
load_json
Входные параметры
- const std::string &json - json строка
Функция загружающая тему из json строки
load_file
Входные параметры
- const std::string &file_name - путь к json файлу
Функция загружающая тему из json файла
load_theme
Входные параметры
- const i_theme &theme_ - ссылка на другую тему
Функция загружающая тему из другого инстанса темы
is_ok
Возвращаемое значение
- true в случае если json загружен успешно
Возвращает нормально ли загрузилась тема из json