Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Использование DevExpress (часть 4)

Модерирует : ShIvADeSt

 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 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 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342

Открыть новую тему     Написать ответ в эту тему

ShIvADeSt



Moderator
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
DevExpress

Обмен опытом, обсуждение нюансов и решение проблем возникающих при использовании библиотеки компонент Developer Express




 
DLL со скинами из библиотеки dxSkins, автор Ziltoid Подробнее... линк обновлен
Продолжение, Первая часть, вторая часть, третья часть

Полезные утилиты:
DxAutoInstaller v2.1.10 Простой и удобный тул для установки девок из исходников
https://mega.nz/#!aJRQzSqI!N7RgfcG1tfF45Z3OgcmBDHT_ZcWlIgJQ5eHHgQ9VupE

Всего записей: 3956 | Зарегистр. 29-07-2003 | Отправлено: 04:48 31-12-2009 | Исправлено: G787, 21:12 29-07-2018
fortezza

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
хочю редактировать выделенные ячейки с помощью tableview (свойство locate dataset слишком долго работает), но  

Код:
cxGridDBTableView.Controller.SelectedRecords[i].Values[cxGridDBTableView.Controller.FocusedColumn.Index] := 5;

работает не так как нужно, в ячейках отображается 5, но по факту там старые значения и при сохранении или отмене dataset ничего не происходит.
Что я делаю не так и как добиться, чтобы значения (не используя locate dataset) заносились в dataset посредствам cxGridDBTableView-а.
 
 

Всего записей: 98 | Зарегистр. 20-10-2009 | Отправлено: 14:49 20-09-2010 | Исправлено: fortezza, 14:58 20-09-2010
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

Цитата:
а что тут лишнего - параметры ж надо передавать....  

передавай просто путь
сохраняем
dbgApart.StoreToIniFile(GetKvx2008UserDocsPath + 'Настройки\ExportApart.ini');
 
восстанавливаем
dbgApart.RestoreFromIniFile(GetKvx2008UserDocsPath + 'Настройки\ExportApart.ini');

----------
/не мы такие, жизнь такая/

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 15:24 20-09-2010
Man_Without_Face



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Подскажите на какое событие в cxGrid можно проанализировать датасет и записать в грид другое значение? Что то вроде такого:
 
                if cdsOX.FieldByName('discountPercent').asstring = '' then
                  cxGridOXDBTableView1DiscountPercent.editvalue := '0';
 
OnGetDataText у ячейки выдает ошибку.

Всего записей: 381 | Зарегистр. 25-01-2010 | Отправлено: 15:46 20-09-2010
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

Цитата:
передавай просто путь

У меня грид привязан к датасурсу, в не отображается таблица БД, сохранять и восстанавливать нужно только ширину и видимость колонок

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 16:01 20-09-2010
salexn1



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Man_Without_Face
Зачем на cxGrid, когда это нужно делать на DataSet: OnNewRecord, BeforeEdit и т.д., в заисимости от того когда нужно...

Всего записей: 502 | Зарегистр. 21-02-2008 | Отправлено: 16:39 20-09-2010
Man_Without_Face



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

Цитата:
OnNewRecord

- пустые строки:
                if cdsOX.FieldByName('discountSum').asstring = '' then
                   cdsOX.FieldByName('discountSum').asstring := '5';

Цитата:
BeforeEdit

- выдает ошибку: DataSet not in edit or insert mode.
 
 
 
 
Добавлено:
А если так: if cdsOX.FieldByName('price_byr').asstring = '' then
                   cxGridOXDBTableView1Price_byr.editvalue := '0';
то в одном случае переполнение стека, а в другом пустые строки.

Всего записей: 381 | Зарегистр. 25-01-2010 | Отправлено: 16:52 20-09-2010
salexn1



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Man_Without_Face
и что?    

Цитата:
if cdsOX.FieldByName('discountSum').asstring = '' then  
                   cdsOX.FieldByName('discountSum').asstring := '5';  

 
этот код не работает?
 

Цитата:
- выдает ошибку: DataSet not in edit or insert mode.  

так переведите в edit...
 
В конце концов на BeforePost можно проверять

Всего записей: 502 | Зарегистр. 21-02-2008 | Отправлено: 17:01 20-09-2010 | Исправлено: salexn1, 17:06 20-09-2010
marser

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok

Цитата:
сохранять и восстанавливать нужно только ширину и видимость колонок

Что вы мудрите? Сделайте по простому:
сохранить

Код:
for I := 0 to TableView.ColumnCount - 1 do
begin
    IniFile.WriteBool(Section, TableView.Columns[I].Name + '.Visible', TableView.Columns[I].Visible);
    IniFile.WriteInteger(Section, TableView.Columns[I].Name + '.Width', TableView.Columns[I].Width);
end;

восстановить

Код:
for I := 0 to TableView.ColumnCount - 1 do
begin
    TableView.Columns[I].Visible := IniFile.ReadBool(Section, TableView.Columns[I].Name + '.Visible', TableView.Columns[I].Visible);
    TableView.Columns[I].Width := IniFile.ReadInteger(Section, TableView.Columns[I].Name + '.Width', TableView.Columns[I].Width);
end;

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 17:25 20-09-2010 | Исправлено: marser, 17:26 20-09-2010
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

Цитата:
marser
Вот блин, свежая мысля , и то правда, СПС

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 17:58 20-09-2010
Man_Without_Face



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
salexn1
Может я неправильно выразился, я отрываю датасет с данными, и поля где определенные записи пустые, нужно вставить ноль (типы полей - строковые).

Всего записей: 381 | Зарегистр. 25-01-2010 | Отправлено: 18:23 20-09-2010
salexn1



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Man_Without_Face
т.е. вы открываете DataSet, в поле А - пустая строка и Вы хотите, чтобы вместо пустой строки выводился какой-то текст?
 
Если так, то у возможно покатит для этих целей метод поля - GetText, ну или отрисовывайте сами на гриде - метод CustomDrawCell

Всего записей: 502 | Зарегистр. 21-02-2008 | Отправлено: 18:34 20-09-2010 | Исправлено: salexn1, 18:35 20-09-2010
Man_Without_Face



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

Цитата:
т.е. вы открываете DataSet, в поле А - пустая строка и Вы хотите, чтобы вместо пустой строки выводился какой-то текст?

Да

Цитата:
GetText

В событии поля (у грида) OnGetDataText пишу:
 
procedure TfrmMain.cxGridOXDBTableView1Price_BYRGetDataText(
  Sender: TcxCustomGridTableItem; ARecordIndex: Integer; var AText: string);
begin
 if cdsOX.FieldByName('price_byr').asstring = '' then
    cxGridOXDBTableView1Column1.EditValue := '0';

end;
запускаю, полей много, прокручиваю скролл на то поле и выскакивает ошибка: StackOverflow
 
 
Добавлено:
Delphi 2007, DevExpress v48

Всего записей: 381 | Зарегистр. 25-01-2010 | Отправлено: 18:45 20-09-2010
volser

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Man_Without_Face
Нужно данные брать с самого грида через Values, а не с датасета.

Всего записей: 713 | Зарегистр. 31-03-2006 | Отправлено: 19:23 20-09-2010
Man_Without_Face



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
volser
Может я не так понял, но такого свойства нет:
cxGridOXDBTableView1Price_byr.value
 
Добавлено:
Я понимаю так:
if cxGridOXDBTableView1.DataController.Values[] = '' then
    cxGridOXDBTableView1Price_byr.EditValue := '0';
Но что в скобках?

Всего записей: 381 | Зарегистр. 25-01-2010 | Отправлено: 19:44 20-09-2010
Sufferer



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Подскажите как в cxGrid настроить группировку данных по дате в стиле Оутлока. В демке девковской это есть, а вот как это настроить я так и не понял. Перетыкал кучу свойств, а результата нет.
 

Всего записей: 271 | Зарегистр. 21-07-2001 | Отправлено: 21:27 20-09-2010
volser

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Man_Without_Face
Values[] - это индексатор, на вход которого нужно передать номер столбца и строки. Номер столбца можно взять в cxGridOXDBTableView1Price_byr или в Sender: TcxCustomGridTableItem; - если это один и тот же столбец. Номер строки ARecordIndex: Integer;.

Всего записей: 713 | Зарегистр. 31-03-2006 | Отправлено: 23:50 20-09-2010
marser

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Sufferer
cxGridTableView.OptionsView.GroupRowStyle := grsOffice11
 
 
Добавлено:
Man_Without_Face

Код:
procedure TfrmMain.cxGridOXDBTableView1Price_BYRGetDataText(  
  Sender: TcxCustomGridTableItem; ARecordIndex: Integer; var AText: string);  
begin  
  if VarIsNull(ARecord.Values[Sender.Index]) or (VarToStr(ARecord.Values[Sender.Index]) = '') then
  AText := '0';
end;

 

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 08:35 21-09-2010
Man_Without_Face



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
marser
volser
Если так:
procedure TfrmMain.cxGridOXDBTableView1Price_BYRGetDataText(
  Sender: TcxCustomGridTableItem; ARecordIndex: Integer; var AText: string);
begin
  if VarIsNull(cxGridOXDBTableView1.DataController.Values[cxGridOXDBTableView1Price_byr.Index, cxGridOXDBTableView1Price_byr.index])
  or (VarToStr(cxGridOXDBTableView1.DataController.Values[cxGridOXDBTableView1Price_byr.Index, cxGridOXDBTableView1Price_byr.index]) = '') then
  cxGridOXDBTableView1Price_byr.EditValue := '0';
end;
то в грид загружаются данные, но когда прокручиваеш скролл на то поле, вылетает ошибка: Stack overflow.
 
Добавлено:
Или почему в свойствах (properties -> currencyedit) не работает свойство NullString. Выставляю 0, но при редактировании ячейки, там все равно ' '.  
 
Добавлено:
Сделал так:
  if VarIsNull(cxGridOXDBTableView1.DataController.Values[cxGridOXDBTableView1Price_byr.Index, cxGridOXDBTableView1Price_byr.index])
  or (VarToStr(cxGridOXDBTableView1.DataController.Values[cxGridOXDBTableView1Price_byr.Index, cxGridOXDBTableView1Price_byr.index]) = '') then
  AText := '0';
в столбце появляются нули, но это аналог NullString. При сохранении пустая строка.

Всего записей: 381 | Зарегистр. 25-01-2010 | Отправлено: 09:14 21-09-2010
salexn1



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Man_Without_Face
ну конечно будет пустая! т.к. это только для просмотра!!!
 
если нужно, чтобы там были 0 - возьмите и запустите SQL один раз

Код:
 
update table set field = '0' where field is null or field = ''
 

 
ну или пробежаться по всему датасету после открытия, если с SQL напряг(тоже один раз)
 

Код:
 
while not DataSet.Eof do
begin
  if DataSet.FieldByName('aaaa').IsNull or (trim(DataSet.FieldByName('aaaa').AsString) = '')   then
begin
  DataSet.Edit;
  DataSet['aaaa'] = '0';
  DataSet.Post;
end;
  DataSet.Next;
end
 


Всего записей: 502 | Зарегистр. 21-02-2008 | Отправлено: 11:04 21-09-2010
Sufferer



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

Цитата:
Sufferer  
cxGridTableView.OptionsView.GroupRowStyle := grsOffice11

Ну это я и так понял, но это только первый шаг который ничего визуально не меняет. Что дальше-то?

Всего записей: 271 | Зарегистр. 21-07-2001 | Отправлено: 11:55 21-09-2010
Открыть новую тему     Написать ответ в эту тему

Страницы: 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 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Использование DevExpress (часть 4)


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru