© EVILEG 2015-2018
Рекомендует хостинг
TIMEWEB
5 июля 2018 г. 13: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 (какое бы значение цвета не записывал.

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

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


QColor color = QColor("#000000");

Такой вариант вполне адекватно обрабатывается.

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

Ответы

Только авторизованные пользователи могут отвечать на форуме.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
15 июля 2018 г. 20:20
igorpodoba

C++ - Тест 003. Условия и циклы

  • Результат 92баллов,
  • Очки рейтинга8
15 июля 2018 г. 20:17
igorpodoba

C++ - Тест 002. Константы

  • Результат 91баллов,
  • Очки рейтинга8
14 июля 2018 г. 7:47
igorpodoba

C++ - Тест 003. Условия и циклы

  • Результат 71баллов,
  • Очки рейтинга1
Последние комментарии
14 июля 2018 г. 18:49
Евгений Легоцкой

Qt/C++ - Урок 049. QTranslator - динамический перевод мультиязычного приложения на Qt

У меня на руках есть один проект, где какие-то потуги с переводами и подключением этого добра в CMAKE делались.Но там файл перевода добавляется прямо в ресурсы проекта. То есть бинарных qm файл...
14 июля 2018 г. 18:35
Евгений Легоцкой

Django - Урок 036. Как добавить аутентификацию через социальные сети. ВКонтакте

Не, не будет, в данной батарейке уже есть необходимый функционал по разрулированию этой проблемы. Аутентификации из разных социальных сетей будут сливаться на один аккаунт. Так что всё нормаль...
14 июля 2018 г. 4:17
Gerych

Django - Урок 036. Как добавить аутентификацию через социальные сети. ВКонтакте

Мне интересно что будет если в обеих сетях в авторизации одинаковый еmail. Не выведет ли ошибку ?
13 июля 2018 г. 11:55
Arrow

Qt/C++ - Урок 049. QTranslator - динамический перевод мультиязычного приложения на Qt

Хорошая статья. Только один вопрос как это сделать для CMake? Интересует именно запись в CMakeList TRANSLATIONS += QtLanguage_ru.ts CODECFORSRC = UTF-8 П...
Сейчас обсуждают на форуме
14 июля 2018 г. 18:56
Евгений Легоцкой

Как сделать пустое поле в QDateEdit

Слишком много возни, чтобы подробно объяснить, что нужно сделать.... тем более, что у вас ещё зависимость на базу данных... Для начала нужно наследоваться от QCalendarWidget, посколь...
12 июля 2018 г. 15:02
незнаток

Перенос значений таблицы в другую таблицу

void Opisanie::perevod(){ QString mil; int mf = ui->table1->rowCount(); for(int ik = 0; ik < mf; ik++) { QString tu = ui->table1->model()->data(ui...
12 июля 2018 г. 7:46
Евгений Легоцкой

OpenSSL на Windows10

Совсем забыл. Вот в этом посте есть ссылка на скачивание openssl библиотек для msvc-2015
11 июля 2018 г. 16:05
Ruslan Polupan

Наследование от QLineEdit

Из опыта разработки в нашей конторе (для программирование хобби я техподдержка): Если есть возможность переложить логику приложения на базу данных то это лутший вариант. Т.е. использовать по м...

Рекомендуемые страницы