Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/13: Рейтинг темы: голосов - 13, средняя оценка - 4.62
0 / 0 / 0
Регистрация: 15.08.2011
Сообщений: 14

DBGrid закрасить несколько ячеек

29.03.2016, 19:31. Показов 2506. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всех приветствую, столкнулся с такой вот задачей:
имеется на форме DBGrid, таблица ADOTable 1 с полями: Наименование, Стоимость, Количество дней, Дата начала, Статус( всего 3 статуса: Занято, Выполняется, Свободно, для каждого свой цвет), данные в DBGrid выводятся из перекрестного запроса ADOQuery1.
Задача, закрасить ячейки в таблице DBGrid, в которых есть определенный текст(статус)
Это я сделал, получилось закрасить 1 определенную ячейку, все ячейки где есть нужный мне текст, и всю строку, в которой встречается этот текст, НО
закрасить мне нужно не 1 ячейку, а несколько в одной строке (определенный диапазон ячеек), а именно
Заполнена только 1 ячейка в строке 1, например "Занято", эту ячейку нужно закрасить красным (этого добился, получилось закрасить все ячейки в таблице с выбранным параметром), далее известно что количество дней = , например, 3 , а значит нужно закрасить ещё 2 ячейки справа (в этих ячейках никаких данных не заполнено).
Проще говоря, суть проблемы в том, чтобы закрасить диапазон (несколько диапазонов) ячеек в строке таблицы DBGrid.
(Прикрепляю пример, как должно быть)
Миниатюры
DBGrid закрасить несколько ячеек  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.03.2016, 19:31
Ответы с готовыми решениями:

DBgrid закрасить нужную строку
Всем привет, не совладал я с DBgrid-ом, чет не идет. Подскажите кодом:help: К DBgrid подключена таблица в этой таблице есть несколько...

Закрасить цветом выделенную строку в DBGrid
Здравствуйте! Необходимо закрасить выделенную строку в DBGrid, при этом сохранив возможность редактирования (т.е не включать RowSelect). ...

Закрасить строку DBGrid при нажатии на Button
В общем есть две кнопки ("Пометить", "Снять пометку"), и есть DBGrid. Требуется при нажатии на кнопку "Пометить" закрасить...

9
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
30.03.2016, 03:54
В DBGridDrawColumnCell крути свои условия по столбцам и значениям, и крась через DBGrid->Canvas->Brush->Color
0
0 / 0 / 0
Регистрация: 15.08.2011
Сообщений: 14
30.03.2016, 04:47  [ТС]
Это я и делаю, но получается закрасить либо ячейки, соответствующие условию (а нужно еще несколько ячеек дополнительно), либо строку целиком.
Вот мой код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
void __fastcall TForm1::DBGrid3DrawColumnCell(TObject *Sender, const TRect &Rect,
          int DataCol, TColumn *Column, TGridDrawState State)
{
 int i;
for(i=0; i<DBGrid3->DataSource->DataSet->FieldCount;++i)
    {     if(Column->Field->Text == "Занят") //Закрасятся все ячейки где записано Занят
 
    // if (DBGrid3->Columns->Items[i]->Field->AsString=="Занят") //Закрасится вся строка, где встречается Занят
        {
            ((TDBGrid*)Sender)->Canvas->Brush->Color = clRed;
        
                 break;
              }
    }
   ((TDBGrid*)Sender)->Canvas->FillRect(Rect);
    ((TDBGrid*)Sender)->DefaultDrawColumnCell(Rect, DataCol, Column, State);
}
Может кто пример подскажет?
0
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
30.03.2016, 07:59
Вы получайте индекс ячейки, в которой выполняется условие, далее "вручную" проходите по соседним справа и закрашивайте, причем нужно условие, чтобы не выйти за диапазон таблицы и не словить ошибку.
0
0 / 0 / 0
Регистрация: 15.08.2011
Сообщений: 14
30.03.2016, 08:26  [ТС]
Цитата Сообщение от Почтальон Посмотреть сообщение
Вы получайте индекс ячейки, в которой выполняется условие, далее "вручную" проходите по соседним справа и закрашивайте, причем нужно условие, чтобы не выйти за диапазон таблицы и не словить ошибку.
А как это реализовать?
Есть таблица ADOTable1, в которой есть поле "Количество дней" - это количество закрашиваемых ячеек,
и "Наименование" и "Дата".
В ADOQuery строится перекрестный запрос по таблице ADOTable1 с полями, которые видно на рисунке.

Как получить индекс ячейки? и как вручную закрасить остальные ячейки (количество проходов равно "Количество дней -1" )

Добавлено через 1 минуту
Может возможно сделать такую "шахматку" не в DBGrid?
0
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
30.03.2016, 09:53
Я еще не силен в области БД, но у вас же в параметрах процедуры передается Column. Вот тут по всей видимости и нужно обращаться к колонке. Sender, как я понял, имеет целую строку(набор колонок, т.е. полей)
0
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
30.03.2016, 11:41
Цитата Сообщение от t7102 Посмотреть сообщение
перекрестный запрос по таблице ADOTable1
Покажи запрос, может лучше его перекроить?
0
0 / 0 / 0
Регистрация: 15.08.2011
Сообщений: 14
30.03.2016, 13:34  [ТС]
Цитата Сообщение от Bit_Man Посмотреть сообщение
Покажи запрос, может лучше его перекроить?
Прикрепляю скрины данных основной таблицы ADOTable, и результат ADOQuery, а так же SQL код запроса,
в результирующей таблице ячейка с текстом "Занят" закрашена красным, другие ячейки тоже должны будут закрашены своими цветами, но с этим разберусь.
КОД ЗАПРОСА:
SQL
1
2
3
4
5
TRANSFORM MIN(Номер.Статус) AS [Min-Статус]
SELECT Номер.Номер, Номер.Мест, Номер.[Цена-день]
FROM Номер
GROUP BY Номер.Номер, Номер.Мест, Номер.[Цена-день]
PIVOT Номер.[Дата от];
Миниатюры
DBGrid закрасить несколько ячеек   DBGrid закрасить несколько ячеек  
0
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
31.03.2016, 04:41
с PIVOT не работал, но запрос не верный. У тебя не выводятся период брони последнего номера.
И самого отбора по датам нет. Поэтому, если у тебя будет много таких записей то и столбцов будет много.
Предлагаю тебе переделать запрос и чтобы в каждом столбце был статус. Облегчишь себе жизнь.
0
0 / 0 / 0
Регистрация: 15.08.2011
Сообщений: 14
01.04.2016, 05:56  [ТС]
Цитата Сообщение от Bit_Man Посмотреть сообщение
с PIVOT не работал, но запрос не верный. У тебя не выводятся период брони последнего номера.
И самого отбора по датам нет. Поэтому, если у тебя будет много таких записей то и столбцов будет много.
Предлагаю тебе переделать запрос и чтобы в каждом столбце был статус. Облегчишь себе жизнь.
Период брони выводить нельзя, так как будет больше строк, а строк должно быть столько - сколько всего номеров, отбор по датам сделаю, не в нём суть. А столбцов и должно быть много, если, например, занятое время выберу 100 дней, то и столбцов в таблице запроса должно сформироваться 100, в итоге я принял такое решение, при создании записи, автоматически будут создаваться записи на следующие даты с таким же статусом, чтобы он потом был прописан в каждой клетке таблицы запроса, тогда получиться все что нужно закрашивать.
Как реализую, поделюсь результатом )

Добавлено через 11 минут
И ещё нужно будет предусмотреть, если меняю статус, например с "бронь", на "свободно", то статус во всех автоматически созданных записях статус тоже должен будет измениться, ну и ,соответственно, цвет ячейки в таблице запроса тоже измениться, в зависимости от статуса.

Добавлено через 3 минуты
Минусом такого метода с запросом будет то, что если на дату в определенном промежутке не заполнено никакого статуса, то эти столбцы не будут формироваться в таблице, а значит визуально, пользователь не увидит, что в тот день не один номер не имеет статуса (не занят или не забронирован, например), в связи с чем, могут быь ошибки с заполнением, не знаю как это решить.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.04.2016, 05:56
Помогаю со студенческими работами здесь

Редактирование ячеек в DBGrid
Подскажите пожалуйста, как сделать, чтобы после редактирования данных в ячейке, изменения автоматически не фиксировались в базе данных....

DBGrid произведение 2 ячеек
Здравствуйте подскажите пожалуйста, как сделать чтобы в столбик С заносилось произведение столбика А и В? я пробовал получать значение...

DBGrid, раскраска ячеек
Как сделать что бы красило ток те ячейки где есть цифра 7? for (int i = 3; i &lt; DBGrid1-&gt;Columns-&gt;Count; i++) { if...

Закрасить несколько ячеек StringGrid при клике мышью
Здравствуйте! Знаю, что по данной теме есть куча разделов и тем, но я так и не нашёл в них ответ на мой вопрос! Делая курсовую, я...

Как закрасить DBGrid
Как закрасить определенную строку в dbgrid, и как закрасить определенную ячейку допустим в 3 столбце 5 строку, как в стригриде cells.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru