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

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

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Доброго времени суток. Такая проблема... Заказчик хочет, чтобы Footer (общий, не групповой) из ExpressQuantumGrid 6 размещался между данными и шапками полей, т.е. как бы первой строкой. Как это сделать?  

Всего записей: 5 | Зарегистр. 12-09-2007 | Отправлено: 14:47 08-06-2010
marser

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

Цитата:
нет , тем которые глазу видны


Код:
var
  I: Integer;
begin
  for I :=0 to <YourGridTableView>.DataController.RecordCount - 1 do
  begin
     if <YourGridTableView>.ViewData.Records[I].Visible then
        ShowMessage('Видимая запись');
  end;
end;

Добавлено
   Если поможет:
     <YourGridTableView>.Controller.TopRowIndex  // RowIndex первой видимой записи
     <YourGridTableView>.Controller.TopRowIndex + <YourGridTableView>.ViewInfo.VisibleRecordCount // RowIndex последней видимой записи

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 15:25 08-06-2010 | Исправлено: marser, 16:05 08-06-2010
DShtorm

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
1) не то RecordCount - дает все записи , включая те , что не видны
есть свойство cxGrid1DBBandedTableView1.ViewInfo.VisibleRecordCount -
которое показывает количество строк видимых в гриде ,  
вот по их значениям мне нужно пробежаться  
 
2) первая и последняя строка - я хочу проверить не изменились ли их индексы с последнего раза ...
 
жаль что событие TopRecordIndexChanged не реагирует почему-то на скрол мышью -
это было бы то что надо , тогда 2 пункт не нужен ...

Всего записей: 106 | Зарегистр. 06-06-2007 | Отправлено: 16:09 08-06-2010 | Исправлено: DShtorm, 16:26 08-06-2010
X11



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

Цитата:
Заказчик хочет, чтобы Footer (общий, не групповой) из ExpressQuantumGrid 6 размещался между данными и шапками полей,  

Обрати внимание на свойство FilterBox
 
Советую изучить ВСЕ свойства для начала хотя бы поверхностно.
 

Цитата:
дает все записи , включая те , что не видны  

чтобы пройтись по только видимым записям, исключая отфильтрованные, то как уже сказали нужно использовать FilteredRecordCount и FilteredRecordIndex[RecordIndex] и т.д.
 

Код:
  with dbgTelCount.DataController do
    begin
      BeginUpdate;
      for I := 0 to FilteredRecordCount - 1 do
        begin
               if VarIsNull(Values[FilteredRecordIndex[i], colPhonesC1.Index]) then
                 Tels := VarToStr(Values[FilteredRecordIndex[i], colPhonesC2.Index])
               else
                 Tels := VarToStr(Values[FilteredRecordIndex[i], colPhonesC1.Index]);
 


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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 16:29 08-06-2010
marser

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

Цитата:
не то RecordCount - дает все записи , включая те , что не видны

А разве условие if <YourGridTableView>.ViewData.Records[I].Visible then не работает?

Цитата:
+ первое и последнее я хочу проверить не изменились ли они с последнего раза

C последнего раза чего? Не изменилось что? RecordIndex  или значение полей первой и последней видимой записи?  

Цитата:
жаль что событие TopRecordIndexChanged не реагирует почему-то на скрол мышью
 
На все реагирует

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 16:30 08-06-2010 | Исправлено: marser, 16:33 08-06-2010
Cryogen2003



Advanced Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Добрый вечер. Чего-то совсем голову себе сломал и запутался.
Стало быть что надо:
Надо отобразить в PivotGrid следующие данные:
Сотрудник, Регион, Дата обзвона, Кол-во клиентов, которые обзвонил, Кол-во клиентов, которые захотели участвовать в той или иной программе банка, Процент качества обзвона
 
Группировка самого пивота идет по дате (Column), в Data уходят оба поля с кол-во клиентов и процент качества обзвона, в Row ФИО сотрудника и региона.  
Стало быть затык с процентов качества обзвона клиента. Считается тупо так - кол-во клиентов, которые захотели участвовать в чем-либо / кол-во клиентов, которым звонили * 100.  
Я могу посчитать это все в оракле, проблемы нет, но когда начинаешь в рилтайме переставлять поля, то понятно уже проценты не соответствуют истине в тех же группах Row.  
Стало быть, как сделать так, чтобы все было правильно?

----------
Холодильники мы

Всего записей: 745 | Зарегистр. 08-12-2004 | Отправлено: 19:45 08-06-2010
DShtorm

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

Цитата:
А разве условие if <YourGridTableView>.ViewData.Records[I].Visible then не работает?  

Это я еще не проверял . Подумал что относится к пофильтрованным данным .
а мне надо просто те что на экране есть .

Цитата:
C последнего раза чего? Не изменилось что? RecordIndex  или значение полей первой и последней видимой записи?

а если набор пересортировать , то RecordIndex 1 строки будет 1 , или как у новой строки ?
если первое то тогда- 2 вариант со значением полей ...

Цитата:
На все реагирует

У меня на 50 версии на скрол не реагирует к сожелению
 
Есть еще вопрос , как вывести чтобы в гриде были видны строки целиком  
( бывает ситуация что показывает построки данных или к примеру треть )

Всего записей: 106 | Зарегистр. 06-06-2007 | Отправлено: 20:36 08-06-2010 | Исправлено: DShtorm, 20:37 08-06-2010
marser

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

Цитата:
а если набор пересортировать , то RecordIndex 1 строки будет 1 , или как у новой строки ?

DataController.RecordIndex - Номер записи (начинается с 0). Cовпадает с номером записи в DataSet.
DataController.RоwIndex - Номер строки  (начинается с 0) в гриде, как вы видите на экране.
После сортировки, группировки RowIndex изменяется, RecordIndex остается прежним.  
Если отсутствует сортировка, группировка, фильтрация RowIndex = RecordIndex.
Получить RowIndex из RecordIndex: DataController.GetRowIndexByRecordIndex(ARecordIndex: Integer).
Получить RecordIndex из RowIndex: DataController.GetRowInfo(ARowIndex: Integer).RecordIndex

Цитата:
У меня на 50 версии на скрол не реагирует к сожелению

У меня 49 версия. 50 глючная.

Цитата:
Есть еще вопрос , как вывести чтобы в гриде были видны строки целиком

OptionsView.CellAutoHeight := True

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 21:48 08-06-2010 | Исправлено: marser, 22:52 08-06-2010
fortezza

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
подскажите как добраться к TableView-ам грида?
Хочу обновлять только наборы данных подключенные к тэйблвьювам грида видимомого в данный момент.  
делаю так:

Код:
    for dsInd := 0 to VetArrivalForm.ComponentCount - 1 do
      if (VetArrivalForm.Components[dsInd] is TcxGrid) then
        if (VetArrivalForm.Components[dsInd] as TcxGrid).CanFocusEx then
          (VetArrivalForm.Components[dsInd] as TcxGrid).?????????

как дальше?

Всего записей: 98 | Зарегистр. 20-10-2009 | Отправлено: 12:24 09-06-2010
X11



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

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 12:40 09-06-2010
fortezza

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

Цитата:
есть же ActiveView

X11, если я буду использовать ActiveView, то как добраться до датасорс?
           (VetArrivalForm.Components[dsInd] as TcxGrid).ActiveView.DataController.?
 
 
вообще конечно лучше обновлять все вьювы, поэтому мой код выше наверное должен выглядеть как то так:

Код:
    for dsInd := 0 to VetArrivalForm.ComponentCount - 1 do
      if (VetArrivalForm.Components[dsInd] is TcxGrid) then
        if (VetArrivalForm.Components[dsInd] as TcxGrid).CanFocusEx then
          for dsInd2 := 0 to (VetArrivalForm.Components[dsInd2] as TcxGrid).Levels.Count - 1 do
            (VetArrivalForm.Components[dsInd] as TcxGrid).Levels[dsInd2].DataRelation.DataController.??????
 

Всего записей: 98 | Зарегистр. 20-10-2009 | Отправлено: 13:22 09-06-2010
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
а про привидение типов слышал?
TcxGridDBTableView((Grid as TcxGrid).ActiveView). ....;

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 13:35 09-06-2010
fortezza

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

Цитата:
а про привидение типов слышал?  
TcxGridDBTableView((Grid as TcxGrid).ActiveView). ....;

слышала. Ура! все получилось. спасибо!

Всего записей: 98 | Зарегистр. 20-10-2009 | Отправлено: 13:52 09-06-2010
Cryogen2003



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

----------
Холодильники мы

Всего записей: 745 | Зарегистр. 08-12-2004 | Отправлено: 13:55 09-06-2010
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
К сожалению я PivotGrid девовский даже в глаза не видел за ненадобностью

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 14:02 09-06-2010
Cryogen2003



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

----------
Холодильники мы

Всего записей: 745 | Зарегистр. 08-12-2004 | Отправлено: 14:05 09-06-2010
Man_Without_Face



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Как стать при загрузке формы на последнюю запись грида? (именно грида а не датасета). Спасибо.
 
Добавлено:
Чтобы последняя строка была выделена, как будто на нее нажали...

Всего записей: 381 | Зарегистр. 25-01-2010 | Отправлено: 13:20 10-06-2010
afiget



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Man_Without_Face
View1.DataController.GotoLast;

Всего записей: 545 | Зарегистр. 31-12-2005 | Отправлено: 13:33 10-06-2010
Man_Without_Face



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

Цитата:
Чтобы последняя строка была выделена, как будто на нее нажали...

CellSelect := false; MultiSelct := true; Может эти опции не дают стать нормально?
 
 

Всего записей: 381 | Зарегистр. 25-01-2010 | Отправлено: 13:54 10-06-2010
marser

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

Цитата:
afiget Спасибо но...тоже самое что и по датасету стать.  
 
Цитата:Чтобы последняя строка была выделена, как будто на нее нажали...  
 
CellSelect := false; MultiSelct := true; Может эти опции не дают стать нормально?

CellSelect, MultiSelct не должны мешать. Проверь DataController.DataModeController.GridMode := False. В какой момент вызываете метод DataController.GotoLast?

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 08:45 11-06-2010 | Исправлено: marser, 08:46 11-06-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