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

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

09.07.2011, 14:10. Показов 2444. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru