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

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



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

Цитата:
Не срабатывает когда вы кликаете на кнопку? Редактирование грида/поля разрешено?

Да, уже разрешил. Жаль, что нельзя с OptionsData.Editing := False
 
Как узнать в событии нажатия на кнопку, на какой колонке был клик?

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 13:47 10-11-2010
f3ka

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
X11
может <YourGridTableView>.Controller.EditingController.EditingItem?

Всего записей: 497 | Зарегистр. 02-03-2007 | Отправлено: 14:19 10-11-2010
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
А относительно кнопки, получается, нельзя?
 
Добавлено:
Просто если я включаю режим редактирования OptionsData.Editing := True, то двойной клик по гриду не срабатывает.
Т.е. приходится выбирать между рабочим даблкликом или рабочими кнопками.

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 14:22 10-11-2010
vladman

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

Цитата:
Да, уже разрешил. Жаль, что нельзя с OptionsData.Editing := False

Можно.

Код:
procedure <YourForm.<YourcxGridDBTableView>MouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState; X, Y:
    Integer);
var
  Ht: TcxCustomGridHitTest;
  P: TPoint;
  R : TRect;
begin
  GetCursorPos(P);
  P := TcxGridSite(Sender).ScreenToClient(P);
  Ht := TcxGridSite(Sender).Viewinfo.GetHitTest(P);
  If (Ht is TcxGridRecordCellHitTest) and
   (TcxGridRecordCellHitTest(Ht).Item.Properties is TcxButtonEditProperties) then
    with TcxGridTableDataCellViewInfo(TcxGridRecordCellHitTest(Ht).ViewInfo) do
    begin
      R := TcxEditButtonViewInfo(TcxCustomEditViewInfo(EditViewInfo).ButtonsInfo[0]).Bounds;
      if PtInRect(R, Point(X, Y)) then
       begin
         TcxCustomEditViewInfo(EditViewInfo).ButtonsInfo[0].Data.State := ebsPressed;
         cxGrid1DBTableView1.Site.InvalidateRect(R,False);
         TcxButtonEditProperties(EditViewInfo.EditProperties).OnButtonClick(Sender,0);
       end;
    end;
end;

 
Добавлено:
X11

Цитата:
Как узнать в событии нажатия на кнопку, на какой колонке был клик?  

Сохраняйте TcxGridRecordCellHitTest(Ht).Item из обработчика выше и анализируйте его в <YourcxGridDBTableView><YourField>PropertiesButtonClick

Всего записей: 708 | Зарегистр. 13-11-2002 | Отправлено: 18:16 10-11-2010
ChaserTheBest

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Установил quantumgrid 7. В гриде у одного поля указываю Properties - TextEdit чтобы вводить однострочный текст. Запускаю программу - в этом поле написано (MEMO) и редактировать это поле нельзя. ReadOnly - false.
Если в Properties ничего не указывать, то при запуске программы в этом поле отображается то, что реально ввели, и можно редактировать, но мне надо установить ограничение на длину строки и текст должен быть однострочным.
что делать?

Всего записей: 3 | Зарегистр. 05-11-2010 | Отправлено: 16:47 11-11-2010
bossi4ek

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Добрый день.  
 
Возникла проблемка с cxgrid. Подскажите как программно добавлять строки у вложенную таблицу ... ?????
 
Что бы при нажатии на "+" открывалась такая же табл. только вложенная с определенным количеством строк.

Всего записей: 4 | Зарегистр. 11-11-2010 | Отправлено: 17:29 11-11-2010
vladman

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

Цитата:
Что бы при нажатии на "+" открывалась такая же табл. только вложенная с определенным количеством строк.

нарисуйте что вы хотите, а то не понятно что такое
Цитата:
добавлять строки у вложенную таблицу


Всего записей: 708 | Зарегистр. 13-11-2002 | Отправлено: 00:41 12-11-2010
ChaserTheBest

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

Цитата:
Установил quantumgrid 7. В гриде у одного поля указываю Properties - TextEdit чтобы вводить однострочный текст. Запускаю программу - в этом поле написано (MEMO) и редактировать это поле нельзя. ReadOnly - false.
Если в Properties ничего не указывать, то при запуске программы в этом поле отображается то, что реально ввели, и можно редактировать, но мне надо установить ограничение на длину строки и текст должен быть однострочным.
что делать?

база - sqlite. может из-за этого что-то?

Всего записей: 3 | Зарегистр. 05-11-2010 | Отправлено: 15:14 12-11-2010
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
bossi4ekСоздать еще один level в cxGrid и привязать его к датасету, причем указать в cxGrid поля для свзи.
P.S. Строки нужно добавлять не в грид, а в датасет, возможно у вас какой нибудь мемори дата. + гляньте сэмплы девэпресс и все поймете
 
 
Добавлено:
ChaserTheBest Создайте в базе sql lite поле с типом string, а не text и не будет у вас memo,  или varchar и задайте его длину, а вообще рекомендую вам почитать про sql lite, сам недавно начал ее пользовать - в ней много особенностей

Всего записей: 651 | Зарегистр. 03-06-2009 | Отправлено: 15:22 12-11-2010 | Исправлено: Andryshok, 15:29 12-11-2010
ChaserTheBest

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

Цитата:
ChaserTheBest Создайте в базе sql lite поле с типом string, а не text и не будет у вас memo,  или varchar и задайте его длину, а вообще рекомендую вам почитать про sql lite, сам недавно начал ее пользовать - в ней много особенностей  

да в нем типов-то 4 штуки только. для текста только TEXT подходит
http://www.sqlite.org/datatype3.html

Всего записей: 3 | Зарегистр. 05-11-2010 | Отправлено: 15:37 12-11-2010
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
ChaserTheBest
Вот вам для размышления
1. http://www.sql.ru/forum/actualthread.aspx?tid=413363
2. http://www.phpclub.ru/detail/article/sqlight
Почитайте внимательно

Всего записей: 651 | Зарегистр. 03-06-2009 | Отправлено: 15:48 12-11-2010
JohnSilver182



BANNED
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Hi  
А вот по умолчание в  cxGrid   текущяя ячейка  выделена контуром ,  остальные синим фоном .  А как  Инвертировать этот  стиль ??  

Всего записей: 829 | Зарегистр. 03-06-2009 | Отправлено: 22:45 13-11-2010
bossi4ek

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

Всего записей: 4 | Зарегистр. 11-11-2010 | Отправлено: 23:35 13-11-2010 | Исправлено: bossi4ek, 23:58 13-11-2010
vladman

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

Цитата:
А вот по умолчание в  cxGrid   текущяя ячейка  выделена контуром ,  остальные синим фоном .  А как  Инвертировать этот  стиль ??  

А попробовать  <Your>cxGridDBTableView.OptionsSelection.InvertSelect := False;
 
Добавлено:
bossi4ek

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

Сделайте ORDER BY по внешнему ключу-связке в датасете для второго левела.

Всего записей: 708 | Зарегистр. 13-11-2002 | Отправлено: 00:06 14-11-2010
bossi4ek

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

Цитата:
Сделайте ORDER BY по внешнему ключу-связке в датасете для второго левела.

 
Данные беру не с БД, а с dxMemData ... или может я не так понял ? ... где это сделать ????

Всего записей: 4 | Зарегистр. 11-11-2010 | Отправлено: 00:25 14-11-2010
vladman

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

Цитата:
Данные беру не с БД, а с dxMemData

Поле, по которому идет связка второго уровня с первым отсортируйте, т.е. установите свойство <Your>dxMemData.SortedField

Всего записей: 708 | Зарегистр. 13-11-2002 | Отправлено: 01:07 14-11-2010
bossi4ek

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
vladman Спс, помогло ... теперь буду знать )

Всего записей: 4 | Зарегистр. 11-11-2010 | Отправлено: 01:30 14-11-2010
JohnSilver182



BANNED
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
vladman  - Шаман !!!
 
 
Добавлено:
А вот инкрементный  поиск в cxGrid всегда показывает  искомую строку Внизу экрана .  А можно это как переделать ??  Вверху например .....

Всего записей: 829 | Зарегистр. 03-06-2009 | Отправлено: 13:17 15-11-2010
MagistrAnatol



Silver Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Господа толкните идею - есть мастер-детал таблицы:
select f1,f2 from table1 - мастер
select f3,f4 from table2 where f4=:f2  детал
но при таком построении запросов в гриде видны детал  записи только текущей строки мастера, чтобы были видны все детайл записи всех мастеров надо в запросе для детайл таблицы убрать условие where f4=:f2 у мастер - детал строить через грид - не проблема - но !!!! при таком запросе  select f3,f4 from table2 при добавлении новой записи в с связку мастер-детайл не через грид , а через модальную форму с дб контролами для мастера  и детал грид я вижу все записи детайл таблицы? ((
Использую фибсы - автокомит отключен( просьба не предлагать включить и все будет норм.)
Пробывал задать фильтр для детайл таблицы по ключевому полю мастера - почему-то не добавляются записи в детал таблицу
Как быть? точнее что делать чтобы не видеть всех записей детайла?
 
Добавлено:
да, и ещо я использую генератор для нового значения поля, как при вставке новой записи увидеть ето знечение в cxTextDBEdit ?

Всего записей: 2127 | Зарегистр. 09-04-2003 | Отправлено: 16:28 15-11-2010
vladman

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

Цитата:
Господа толкните идею - есть мастер-детал таблицы:

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

Где вы видите эти все записи? В модальной форме?
А причем тут автокоммит? Как без коммита транзакции ваш грид вообще будет знать о добавлении новой записи, тем более через модальную форму с дб контролами?
 
Добавлено:
MagistrAnatol

Цитата:
использую генератор для нового значения поля, как при вставке новой записи увидеть ето знечение в cxTextDBEdit ?

Как вариант, воспользоваться методом TFIBDatabase.Gen_Id(const GeneratorName: string; Step: Int64; aTransaction: TFIBTransaction = nil): Int64.
Например:

Код:
procedure <YourForm.<YourDataSet>NewRecord(DataSet: TDataSet);
begin
  <YourDataSet>['<YourPrimaryKeyFieldName>'].AsInteger := <Your>Database.Gen_Id('YourPrimaryKeyField_GEN_ID', 1);
end;

Всего записей: 708 | Зарегистр. 13-11-2002 | Отправлено: 23:09 15-11-2010 | Исправлено: vladman, 23:20 15-11-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