Arrow
Шілде 5, 2018, 7:45 Т.Қ.

Хранение выбранного цвета в базе данных

Qt, DataBase, QComboBox, QColor

Добрый день!

Помогите пожалуйста со следующим вопросом: В программе хочу реализовать выбор цвета с его записью в базу данных. Подскажите какой тип должно иметь поле в базе данных для хранения цвета.
Как лучше организовать выбор цвета:
1. Список цветов хранится в отдельной таблице в базе данных и оттуда загружается в QComboBox, затем индекс выбранного записывается в поле в основной таблице.  / Сомневаюсь, что это хорошее решение /
2. Реализовать выбора цвета при помощи QColorDialog (нажатие на кнопку открывает диалог; выбранный цвет устанавливается в качестве цвета фона кнопки (или строки QLineEdit), а значение (#RRGGBB) в качестве текста). Потом в базу данных записывать значение цвета / считывать значение цвета и устанавливать на кнопку (QColorDialog при открытии инициализируется этим цветом). / Похоже самое верное решение /

3. Реализовать что-то похожее на изображенное на картинке. / Не знаю как такое сделать /

Как потом считать это значение?
Пробовал считать значение цвета (записано в ручную) в качестве #RRGGBB из ячейки с типом text.

Пытался так:

QSqlQuery query;
query.prepare("SELECT colour_name FROM table");
query.exec();
while (query.next()) {
        QColor color = QColor(query.value(index).toString());
        /* * * * * */
}

Но цвет не распознается - отображается как #000000 (какое бы значение цвета не записывал.

Безымянный.png
2

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

2
Александр Панюшкин
  • Шілде 5, 2018, 8 Т.Қ.
  • Жауап шешім ретінде белгіленді.

Однозначно 2-й вариант. Если не нравится как выглядит диалоговое окно - проще его поднастроить, чем своё создавать.

В базе я бы хранил строковое значение - не уверен, что есть другой вариант.


QColor color = QColor("#000000");

Такой вариант вполне адекватно обрабатывается.
    Arrow
    • Шілде 5, 2018, 8:12 Т.Қ.

    Спасибо! Попробую подшаманить диалог.

      Пікірлер

      Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
      Кіріңіз немесе Тіркеліңіз