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

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в 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
mdid

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
DimonXP
ПК перезагружали?
andreybear
давайте начнем с того является ли каждое поле одновременно результатом суммы и суммируемым? onValidate не произойдет...но произойдет OnChange(пропертис только выбрать надо)если просуммировать поля 1+2+3=6 то зачем вызывать onValidate для поля где результат 6? + у вас интересный подход...усер поменял 6 на 100 и получается 1+2+3=100?
ПС
или мне мало данных для совета или уже я чего то не понимаю

Всего записей: 1298 | Зарегистр. 13-02-2006 | Отправлено: 12:56 19-03-2012
andreybear

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

Цитата:
давайте начнем с того является ли каждое поле одновременно результатом суммы и суммируемым?

Может быть и суммируемым.

Цитата:
у вас интересный подход...усер поменял 6 на 100 и получается 1+2+3=100?  

Вы же сами предложили:

Цитата:
цепляетесь к событию OnValidate этой колонки где будет лежать процедура расчета и выводить результат в EditValue

Допустим, в 4 колонке формула. 1, 2 и 3 колонки имеют соответственно следующие значения 1, 2 и 3.
Формулу необходимо разобрать, подставить значения вместо переменных, подсчитать и вывести в соответствующую запись колонки номер 4. Пользователь вводит значения, значение "расчетной" колонки необходимо пересчитать. Если правильно понял, вы предлагаете для первых трех колонок назначить обработчик на событие onChange и при каждом изменении производить перечисленные выше действия с формулой?

Всего записей: 132 | Зарегистр. 21-07-2011 | Отправлено: 13:16 19-03-2012
mdid

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
ну да...а как иначе? тем более что для колонки можно создать невидимую колонку где будет храниться формула...а в событии onChange или onValidate проверять  
  - на наличие формулы(нет формулы знач ничего не делаем)
  - есть...расчитываем
сама формула в общем то и содержит сумма каких колонок отображается(тоесть можно id1;id2;id3)
ну как то так вроде

Всего записей: 1298 | Зарегистр. 13-02-2006 | Отправлено: 14:00 19-03-2012
Czechoslovak



Junior Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
andreybear
Что-то я чего-то не понимаю....зачем что показывать....EditValue это хранимое значение ячейки, к примеру у меня есть задача правда сделанная DBTableView, но там есть колонка не привязанная БД чисто для того что бы пользователь отметил какие данные(CheckBox) надо сбросить в архив, просто виртуальное так сказать поле, берешь присваиваешь значение и все дела....

Всего записей: 175 | Зарегистр. 27-06-2007 | Отправлено: 14:07 19-03-2012
andreybear

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mdid
Попробовал.
Не подходит для случаев, когда формула включает в себя данные колонок из других таблиц. В таком случае необходимо обращаться к БД, а так как значения отправляются в БД только по кнопке сохранить (таблица не "привязана" к набору данных), то после onChange пересчет будет произведен, но в БД на тот момент будут все еще старые значения, хотя в таблице новые. Таким образом, к сожалению, пересчет для новых значений так и не произойдет.
Хотя, можно попробовать подставить в формулу соответствующие значения, которые есть в текущей таблице, затем уже подставить недостающие данные из других таблиц. И при таком подходе при первоначальной загрузке данных в таблицу также необходимо осуществлять пересчет колонок с формулами, т.к. исходные данные могут измениться к этому времени, значения будут пересчитываться по onChange для конкретной записи, а событие произойдет только тогда, когда пользователь изменит какое-нибудь значение в ячейке.
 
Добавлено:
Czechoslovak
На сколько я знаю, чтобы добраться до EditValue, которое относится к редактору ячейки (назначается на колонку в целом), необходимо "вызвать" этот редактор методом Show, например, View.Controller.EditingController.Edit.Show, если я не ошибаюсь, затем можно обратиться к свойству EditValue, затем вызвать метод Hide, чтобы скрыть редактор.
А к значению ячейки обычно так доступ получаю: View.DataController.Values[RecordIndex,ItemIndex].
Поправьте, если неправильно понял.

Цитата:
берешь присваиваешь значение и все дела....

Проблема в том, что не знаю, на какое событие повесить это присвоение.
Кстати, если закрыть глаза на различия в хранимом и отображаемом тексте и осуществлять присвоение в onGetDataText, то после того, как пользователь нажимает сохранить и кодом делается пост редактируемой записи, при переходе на другую запись возникает ошибка. Присвоение вычисленного значения выполняется так:
View.DataController.Values[RecordIndex,ItemIndex] := AValue;

Всего записей: 132 | Зарегистр. 21-07-2011 | Отправлено: 14:27 19-03-2012
simplecs

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Задавал вопрос, но ответа так и не нашел! Прошу Вас помощи еще раз:
Сделал в cxgrid группировку по какому-нибудь столбцу – нужно отразить в строке группировки итоговые значения по группе но не стандартные а свои собственные. Как написать свои собственные итоги в нижнем Footor-е и в Footor-е группы я понимаю (через OnGetText). А как мне отследить записи которые попали в тут или иную группу. Например, мне необходимо в каждой группе показать (слово «Привет» встретилось 2 раза, слово «Пока» 3 раза в столбце 1). Но как посчитать эти 2 и 3 раза в рамках группы, а не всей таблицы?
 

Всего записей: 27 | Зарегистр. 20-10-2010 | Отправлено: 17:45 19-03-2012
andreybear

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mdid
Czechoslovak
Спасибо за помощь, сделал так, как описал в предыдущем посте.

Всего записей: 132 | Зарегистр. 21-07-2011 | Отправлено: 06:27 20-03-2012
mdid

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
simplecs
у вас же идет группировка по какому то признаку..отфильтруйте количество по этому признаку и будет вам счастье..

Всего записей: 1298 | Зарегистр. 13-02-2006 | Отправлено: 11:53 20-03-2012
simplecs

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mdid
Да, но для этого мне необходимо фильтровать данные не по всей таблицы а только впределах каждой из групп (т.е. знать где начинается каждая группа а где заканчивается. А я не знаю как?

Всего записей: 27 | Зарегистр. 20-10-2010 | Отправлено: 13:40 20-03-2012
mdid

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
simplecs
к сожалению ответа на этот вопрос я сам не нашел(дет год назад мне это же надо было)...ситуацию решил так..держал какой то MemTable от EhLib(так как он правильно показывает количество отфильтрованного а девовский Mem только общее количество)  и там по событию фильтровал...так же можно обычными запросами получать данные....если найдете решение девовскими методами...отпишитесь плиз

Всего записей: 1298 | Зарегистр. 13-02-2006 | Отправлено: 13:51 20-03-2012
simplecs

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Здравствуйте! Вопрос по cxgrid.  
У меня есть созданный в режиме разработки Summary-> Default For Groups.
Я произвожу для них собственные расчеты. Как мне программно обратиться к Summary для первой группы, второй и т.д. чтобы внести в них расчетные данные. Скажем в Summary для первой группы внести «1а», для Summary второй группы внести «2а» и.т.д. Какое свойство cxgrid за это отвечает?
Спасибо!

Всего записей: 27 | Зарегистр. 20-10-2010 | Отправлено: 17:34 20-03-2012
marser

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

Цитата:
А как мне отследить записи которые попали в тут или иную группу. Например, мне необходимо в каждой группе показать (слово «Привет» встретилось 2 раза, слово «Пока» 3 раза в столбце 1). Но как посчитать эти 2 и 3 раза в рамках группы, а не всей таблицы?

У TcxCustomGridRecord есть свойство ParentRecord. На практике не проверял, но у меня есть такое предположение.
Допустим, есть три записи Record1, Record2 и Record3, принадлежащие к одной группе. Если сфокусировать на заголовок группы, то DataController.FocusedRecordIndex соответствует, например, записи Record1. При этом Record1.ParentRecord := nil или указывает на рекорд вышестоящей группы, Record2.ParentRecord := Record1 и Record3.ParentRecord := Record1

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 21:33 20-03-2012 | Исправлено: marser, 21:36 20-03-2012
simplecs

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Здравствуйте!
В общем, я тут парил народ с вопросами на прошлых страницах с группировкой. ВСем спасибо за ответы!
Проблему я решил!!! Решение выкладываю. Кому-то покажется элементарным, а  кому-то, возможно, будет полезно!
Задача состояла вот в чем: необходимо было в cxgrid при проведении группировки , по нажатию на кнопку заменять исходный Summary – который считается в cxgrid на свой собственный. И рассчитывать его по каждой группе. К посту прикладываю пример, в котором данные группируются, а после щелчка по кнопке, программа считает по каждой группе среднее значение по столбцу 1 и умножает его для прикола на 100. Заметьте, что среднее я считаю сам, без всяких встроенных функций. Аналогично считаются и все прочие суммы разности и т.д. в т.ч. сколько раз встречается то или иное слово!!!
 
Надеюсь, кому-то это будет полезно. Так как сам просидел не один день!
Всем спасибо и удачи!
 
Ссылка на файл примера: http://ifolder.ru/29416787
 
 
Текст программы (если ссылка загнется)..
 
 
 
 
 
 

Всего записей: 27 | Зарегистр. 20-10-2010 | Отправлено: 21:57 20-03-2012 | Исправлено: simplecs, 22:06 20-03-2012
mdid

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
есть грид и тип колонки TcxEditButtons со стилем vsButtonsOnly...как заставить грид не прятать кнопки? а то при потере фокуса кнопка исчезает?

Всего записей: 1298 | Зарегистр. 13-02-2006 | Отправлено: 18:22 22-03-2012
neznayka3

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
В TdxBarEdit TcxBarEditItem не работает ONChange, текст пропадает после потери фокуса.

Всего записей: 385 | Зарегистр. 07-06-2007 | Отправлено: 18:22 22-03-2012
mdid

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
neznayka3
это уже обсасывалось..код в OnCurChange
EditValue:=CurEditValue;

Всего записей: 1298 | Зарегистр. 13-02-2006 | Отправлено: 18:36 22-03-2012
X11



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

Цитата:
есть грид и тип колонки TcxEditButtons со стилем vsButtonsOnly...как заставить грид не прятать кнопки? а то при потере фокуса кнопка исчезает?

 
У колонки см. свойство Options.ShowEditButtons

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 18:52 22-03-2012
k94kwk1

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Подробнее...
 
Здравствуйте!
Вот я протестировал БД на следующее: допустим я редактирую в cxgrid какую-нить запись. Вношу значение, а потом сразу после его ввода заглядываю в БД а  его там нет. Только после того, как перейду на другую запись – это значения появляется в БД. Мне же необходимо чтобы значение в БД обновлялось сразу же после его ввода так как от значения этой ячейки у меня могут зависеть другие, находящихся в той же записи, расчет которых идет сразу же после обновления первой при помощи SQL запроса. Единственный вариант, который получился это:
    cxGrid1DBTableView1.BeginUpdate;
    cxGrid1DBTableView1.DataController.Post;
     cxGrid1DBTableView1.EndUpdate;
Но если я правильно понимаю то при выполнении «.Post»; - идет перезаписываание всех данных а не ТОЛЬКО выбранной записи (я кстати прав или нет)? Что  занимает1-2 сек. А это долговато для меня. Мне бы сохранить в БД только то что было изменено.
 
Я пробовал также   TcxCustomDateEdit(sender).PostEditValue – но в БД данные  опять появляются только при  перемещении записи, а мне необходимо сразу же.
Есть ли идеи?
 
И второй маленький вопрос : во многих repository items есть свйоство ImmediatePost – вот как по названию оно должно отвечать за сохранение данных в БД сразу же….но что-то этого не происходит…..
 [/more]

Всего записей: 28 | Зарегистр. 11-03-2012 | Отправлено: 23:13 22-03-2012 | Исправлено: k94kwk1, 23:14 22-03-2012
andreybear

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

Цитата:
Вот я протестировал БД на следующее: допустим я редактирую в cxgrid какую-нить запись. Вношу значение, а потом сразу после его ввода заглядываю в БД а  его там нет. Только после того, как перейду на другую запись – это значения появляется в БД.

Все правильно, пост производится при переходе на другую запись.

Цитата:
Но если я правильно понимаю то при выполнении «.Post»; - идет перезаписываание всех данных а не ТОЛЬКО выбранной записи (я кстати прав или нет)? Что  занимает1-2 сек. А это долговато для меня. Мне бы сохранить в БД только то что было изменено.  

Только измененная запись постится. Но 1-2 сек. это долговато!

Цитата:
Есть ли идеи?  

У меня подобная задача, обсуждалась чуть выше, в том числе на этой странице.

Цитата:
Мне же необходимо чтобы значение в БД обновлялось сразу же после его ввода так как от значения этой ячейки у меня могут зависеть другие, находящихся в той же записи, расчет которых идет сразу же после обновления первой при помощи SQL запроса.  

Если расчет по данным из этой же таблицы, то не вижу смысла выполнять расчет на сервере, рассчитывайте на клиенте. Изменилось значение, тут же пересчитали значения в других ячейках, относящихся к изменяемой записи.

Цитата:
И второй маленький вопрос : во многих repository items есть свйоство ImmediatePost – вот как по названию оно должно отвечать за сохранение данных в БД сразу же….но что-то этого не происходит…..  

В справке написано:

Цитата:
If the property value is set to True, the editor automatically saves the edited value to the bound field’s Value property as soon as the value has been changed.

Если не ошибаюсь, значение сохраняется в поле набора данных, связанном с редактором, а в БД отправляется после Post.

Всего записей: 132 | Зарегистр. 21-07-2011 | Отправлено: 05:24 23-03-2012 | Исправлено: andreybear, 05:34 23-03-2012
k94kwk1

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
andreybear
 
Цитата:
Если расчет по данным из этой же таблицы, то не вижу смысла выполнять расчет на сервере, рассчитывайте на клиенте. Изменилось значение, тут же пересчитали значения в других ячейках, относящихся к изменяемой записи.

 
 
Так оно так! Но мне необходимо посчитать во всей таблице (так как в программе есть итоговая строка) число элементов типа "А", в столбце 1, число элементов типа "Б" в столбце "1" и число элементов типа "С" в столбце "1". Честно говоря не очень представляю себе как это можно сделать на клиенте. Разве что в цикле перебрать все записи, а если их много? Вот я и шарахую сразу после внесения данных в ячейку  SQL запрос с аргументами для подсчета числа элементов типа "А", "Б" и "С" в таблице в целом, чтобы пересчитать итоги. Разве можно как-то по другому?
 
В любом случае спасибо Вам за ответ!

Всего записей: 28 | Зарегистр. 11-03-2012 | Отправлено: 07:26 23-03-2012 | Исправлено: k94kwk1, 07:30 23-03-2012
Открыть новую тему     Написать ответ в эту тему

Страницы: 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