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

Закрашивание строки в Stringgrid

09.07.2011, 14:10. Показов 2427. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задача такова: считать с базы данные, проверить все данные столбца "Легенда", если true, то зарисовать всю строку желтым, если нет, то ничего не делать.
Вот код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
void __fastcall TMain::N11Click(TObject *Sender)
{
    if (ADOQuery->Active) ADOQuery->Close ();
 
    if (OpenDialog->Execute())
    {
        ADOQuery->ConnectionString = DefaultConnStr + OpenDialog->FileName;
        ADOQuery->SQL->Clear();
        ADOQuery->SQL->Add ("SELECT * FROM [Вхідна кореспонденція]");
        try
        {
            ADOQuery->Open ();
            SGdata->RowCount = ADOQuery->RecordCount + 1;
        }
        catch (EOleException&)
        {
            MessageBox (Handle, "Не вдалось відкрити базу даних", "Помилка", MB_ICONERROR | MB_OK);
        }
    }
    ADOQuery->First();
    while (!ADOQuery->Eof) {
        for (int i = 1; i < ADOQuery->RecordCount + 1; i++) {
            void __fastcall TMain::SGdataDrawCell(TObject *Sender, int ACol, int ARow, TRect &Rect,TGridDrawState State)
            {
                if (ADOQuery->FieldByName("Легенда")->AsString)
                {
                     SGdata->Canvas->Brush->Color = clYellow;
                     SGdata->Canvas->FillRect(Rect);
                }
                SGdata->Cells[0][i] = ADOQuery->FieldByName("Код")->AsString;
                SGdata->Cells[1][i] = ADOQuery->FieldByName("ЖРЗПЗ")->AsString;
                SGdata->Cells[2][i] = ADOQuery->FieldByName("від (ЖРЗПЗ)")->AsString;
                SGdata->Cells[3][i] = ADOQuery->FieldByName("Рішення")->AsString;
                SGdata->Cells[4][i] = ADOQuery->FieldByName("від (рішення)")->AsString;
                SGdata->Cells[5][i] = ADOQuery->FieldByName("Служба")->AsString;
                SGdata->Cells[6][i] = ADOQuery->FieldByName("Направлено")->AsString;
                SGdata->Cells[7][i] = ADOQuery->FieldByName("від (направлено)")->AsString;
                SGdata->Cells[8][i] = ADOQuery->FieldByName("Повернено")->AsString;
                SGdata->Cells[9][i] = ADOQuery->FieldByName("Легенда")->AsString;
                ADOQuery->Next();
            }
        ADOQuery->Next();
        }
    }
}
Ошибка при компиляции: E2089 Identifier 'SGdataDrawCell' cannot have a type qualifier
Помогите решить, пожалуйста =)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.07.2011, 14:10
Ответы с готовыми решениями:

StringGrid - закрашивание
Подсчитать количество локальных максимумов в массиве целых чисел. Локальный максимум — такой элемент массива, который больше своих соседей....

Закрашивание ячейки StringGrid
Функция-обработчик закрашивания ячейки в черный цвет левой кнопкой мыши: void __fastcall gridDrawCell(TObject *Sender, int ACol, ...

Закрашивание ячейки StringGrid
Подскажите, пожалуйста, как закрасить ячейку при таком условии: Если a&gt;b, то ячейка закрашивается, иначе в лейбл записывается ошибка ...

5
 Аватар для Зоти Сергей
230 / 227 / 65
Регистрация: 18.12.2009
Сообщений: 316
09.07.2011, 21:37
У Вас реализация функции SGdataDrawCell как то попала не туда.. скажем прямо...
Она у Вас в цикле объявлена. Должно быть что-то вроде вот этого:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
void __fastcall TMain::N11Click(TObject *Sender)
{
        if (ADOQuery->Active) ADOQuery->Close ();
 
        if (OpenDialog->Execute())
        {
                ADOQuery->ConnectionString = DefaultConnStr + OpenDialog->FileName;
                ADOQuery->SQL->Clear();
                ADOQuery->SQL->Add ("SELECT * FROM [Вхідна кореспонденція]");
                try
                {
                        ADOQuery->Open ();
                        SGdata->RowCount = ADOQuery->RecordCount + 1;
                }
                catch (EOleException&)
                {
                        MessageBox (Handle, "Не вдалось відкрити базу даних", "Помилка", MB_ICONERROR | MB_OK);
                }
        }
        ADOQuery->First();
        while (!ADOQuery->Eof) 
        {
                for (int i = 1; i < ADOQuery->RecordCount + 1; i++) 
                {
                          SGdata->Cells[0][i] = ADOQuery->FieldByName("Код")->AsString;
                          SGdata->Cells[1][i] = ADOQuery->FieldByName("ЖРЗПЗ")->AsString;
                          SGdata->Cells[2][i] = ADOQuery->FieldByName("від (ЖРЗПЗ)")->AsString;
                          SGdata->Cells[3][i] = ADOQuery->FieldByName("Рішення")->AsString;
                          SGdata->Cells[4][i] = ADOQuery->FieldByName("від (рішення)")->AsString;
                          SGdata->Cells[5][i] = ADOQuery->FieldByName("Служба")->AsString;
                          SGdata->Cells[6][i] = ADOQuery->FieldByName("Направлено")->AsString;
                          SGdata->Cells[7][i] = ADOQuery->FieldByName("від (направлено)")->AsString;
                          SGdata->Cells[8][i] = ADOQuery->FieldByName("Повернено")->AsString;
                          SGdata->Cells[9][i] = ADOQuery->FieldByName("Легенда")->AsString;
                          ADOQuery->Next();
                }
                ADOQuery->Next();
                
        }
}
 
void __fastcall TMain::SGdataDrawCell(TObject *Sender, int ACol, int ARow, TRect &Rect,TGridDrawState State)
{
        if (ADOQuery->FieldByName("Легенда")->AsString)
        {
                 SGdata->Canvas->Brush->Color = clYellow;
                 SGdata->Canvas->FillRect(Rect);
        }
                                
}
0
 Аватар для Samrisbe
1365 / 732 / 67
Регистрация: 28.01.2011
Сообщений: 2,069
10.07.2011, 01:26
Добрый вечер. Подскажите как в событии OnMauseClick, в StringGrid выделить синим цветом всю строку по которой кликнули? Чтото типа выделить строку...
0
0 / 0 / 0
Регистрация: 30.05.2009
Сообщений: 13
10.07.2011, 10:34  [ТС]
Зоти Сергей, проблема в том, что так функция не дает никаких результатов. То есть, ячейка должна закрашиваться только при условии Легенда == true, а за пределами запроса, оно проверится не может. Возможно мне нужно двойной запрос отправлять, первым определять количество строк в базе и передать это количество в программу, и при этом проверять условие на true, а вторым выводить информацию с базы?
0
 Аватар для cpp_developer
20124 / 5691 / 417
Регистрация: 09.04.2010
Сообщений: 22,546
Записей в блоге: 1
11.07.2011, 10:23
Samrisbe, помнится, была такая функция
C++
1
StringGrid->MouseToCell(X, Y, Col, Row);
Дальше - дело техники.
1
0 / 0 / 0
Регистрация: 30.05.2009
Сообщений: 13
12.07.2011, 16:41  [ТС]
Эм... что-то мне ударило в голову и решил сделать по другому - после проверки условия на истину, вызывать функцию!
Вот, что получилось:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
void __fastcall TMain::N11Click(TObject *Sender)
{
    if (ADOQuery->Active) ADOQuery->Close ();
    if (OpenDialog->Execute())
    {
        ADOQuery->ConnectionString = DefaultConnStr + OpenDialog->FileName;
        ADOQuery->SQL->Clear();
        ADOQuery->SQL->Add ("SELECT * FROM [Вхідна кореспонденція]");
        try
        {
            ADOQuery->Open ();
            SGdata->RowCount = ADOQuery->RecordCount + 1;
        }
        catch (EOleException&)
        {
            MessageBox (Handle, "Не вдалось відкрити базу даних", "Помилка", MB_ICONERROR | MB_OK);
        }
    }
    ADOQuery->First();
    while (!ADOQuery->Eof) {
        for (int i = 1; i < ADOQuery->RecordCount + 1; i++) {
                if (ADOQuery->FieldByName("Легенда")->AsString == "true" )
                {
                    //(TObject *Sender, int ACol, int ARow, TRect &Rect, TGridDrawState State);
                    SGdataDrawCell (Sender, 1, i, &Rect, State);
                }
                SGdata->Cells[0][i] = ADOQuery->FieldByName("Код")->AsString;
                SGdata->Cells[1][i] = ADOQuery->FieldByName("ЖРЗПЗ")->AsString;
                SGdata->Cells[2][i] = ADOQuery->FieldByName("від (ЖРЗПЗ)")->AsString;
                SGdata->Cells[3][i] = ADOQuery->FieldByName("Рішення")->AsString;
                SGdata->Cells[4][i] = ADOQuery->FieldByName("від (рішення)")->AsString;
                SGdata->Cells[5][i] = ADOQuery->FieldByName("Служба")->AsString;
                SGdata->Cells[6][i] = ADOQuery->FieldByName("Направлено")->AsString;
                SGdata->Cells[7][i] = ADOQuery->FieldByName("від (направлено)")->AsString;
                SGdata->Cells[8][i] = ADOQuery->FieldByName("Повернено")->AsString;
                SGdata->Cells[9][i] = ADOQuery->FieldByName("Легенда")->AsString;
                ADOQuery->Next();
        }
        ADOQuery->Next();
    }
}
 
//---------------------------------------------------------------------------
 
void __fastcall TMain::SGdataDrawCell(TObject *Sender, int ACol, int ARow, TRect &Rect,
          TGridDrawState State)
{
                        SGdata->Canvas->Brush->Color = clYellow;
                        SGdata->Canvas->FillRect(Rect);
}
//---------------------------------------------------------------------------
Но при компиляции получаю ошибочки, которые говорят о том, что скорей всего передаю неправильные параметры. Поясните пожалуйста, что туда должно передаваться. Не могу разобраться с гуглом =\
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.07.2011, 16:41
Помогаю со студенческими работами здесь

Закрашивание ячеек в StringGrid
В событии BottonOnClick -вычисление ячеек двумерной матрицы, но мне нужно еще и закрасить ячейки в зависимости от результата. У меня вышло...

Закрашивание строки цветом
Здравствуйте, подскажите пожалуйста! Мне нужно закрасить строку цветом, если у столбца &quot;status_platezha&quot; значение...

Закрашивание ячеек StringGrid с max и min элементами каждой строки матрицы
Доброго всем вечера. Дана такая задача: есть матрица произвольного размера с вещественными числами, нужно поменять максимальный и...

Stringgrid закрашивание
Есть 1 стока и 3 стобца. Нужно чтобы если в 3 столбце слово 'on' то тогда вся строка закрашивалась бы зеленым цветом. Как это сделать?...

StringGrid закрашивание ячеек
Здравствуйте! Подскажите пожалуйста как организовать закраску ячеек StringGrid-а. Необходимо, чтобы ячейка с правильно введенными в...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru