Arrow
ArrowШілде 5, 2018, 9: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
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

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

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

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

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


QColor color = QColor("#000000");

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

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

      Пікірлер

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

      C++ - Тест 001. Первая программа и типы данных

      • Нәтиже:66ұпай,
      • Бағалау ұпайлары-1
      t

      C++ - Тест 001. Первая программа и типы данных

      • Нәтиже:33ұпай,
      • Бағалау ұпайлары-10
      t

      Qt - Тест 001. Сигналы и слоты

      • Нәтиже:52ұпай,
      • Бағалау ұпайлары-4
      Соңғы пікірлер
      G
      GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
      Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
      d
      dblas5Шілде 5, 2024, 11:02 Т.Ж.
      QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
      k
      kmssrАқп. 8, 2024, 6:43 Т.Қ.
      Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
      АК
      Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
      Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
      Енді форумда талқылаңыз
      Evgenii Legotckoi
      Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
      добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
      F
      FynjyШілде 22, 2024, 4:15 Т.Ж.
      при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
      BlinCT
      BlinCTМаусым 25, 2024, 1 Т.Ж.
      Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
      BlinCT
      BlinCTМамыр 5, 2024, 5:46 Т.Ж.
      Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
      Evgenii Legotckoi
      Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
      Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

      Бізді әлеуметтік желілерде бақылаңыз