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

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в 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
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
wbsg, да вроде не нужен, если совсем уж подробно раскрывать тему:
 
Есть у меня в таблице поля которые хранят id других таблиц. обычно на них вешают lookupcombobox. Но я хочу реализовать это по-другому. Для этого мне надо три поля: 1 - id, 2 - code (существует не для всех таблиц), 3 - name. В DataSet использую left join чтобы выбрать значения для полей code и name. Пользователь всегда видит только столбец поля name, но может отобразить и скрытые другие поля - id и code (правой кнопкой по столбцу - это первый случай когда нужны ссылки на столбцы). Далее на каждой из трех колонок есть cxButtonEdit при клике на который вызывается форма с фокусом на нужной записи (это второй случай когда нужны ссылки - т.е. на каком поле не щелкнул пользователь передастся значение поля id), выбрав в этом окне нужное значение двойным щелчком форма закрывается и передает 3 соответствующих значения для 3-х столбцов (3 случай кагда нужны ссылки).
Сейчас для меня это очень удобно и по скорости инициализации Grid-а и колонок и по возможностям сортировки и фильтрации (в отличии от lookup), неудобно только по реализации (для этого я пока что использую массивы + функции для их обработки).
 
Компоненты я ни разу не создавала, и не представляю как это делать для колонок cxGrid, ведь при этом похоже придется переопределить так же сам cxGrid. Поэтому пока интересует вариант без создания компонента. Конкретно код, который я писала выше. Используя такой код и вручную добавляя колонки в грид,  у меня например не получается в определенный момент времени определить является ли колонка  TcxGridDBMultiColumn или нет (и если да - обратиться к его ссылкам на столбцы), потому что на (Sender is TcxGridDBMultiColumn) всегда выдается false. Не могу сейчас вглублятся в особенности Delphi, может быть конструкцию (... is T...) в моем случае использовать нельзя, а может быть есть другие причины.
 
Вообщем, слушаю ваши идеи.

Всего записей: 98 | Зарегистр. 20-10-2009 | Отправлено: 11:07 25-05-2011
marser

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

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

Cоздайте record

Код:
PRec = ^TRec;
TRec = record
   Column1 : TcxGridDBColumn;  
   Column2 : TcxGridDBColumn;  
end;  

И храните указатель на этот record в свойстве колонки Tag: cxGridDBColumn.Tag := Integer(PRec).  

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 11:11 25-05-2011 | Исправлено: marser, 11:13 25-05-2011
fortezza

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
marser, по-моему это то что нужно. Сейчас попробую.

Всего записей: 98 | Зарегистр. 20-10-2009 | Отправлено: 11:15 25-05-2011
marser

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
fortezza
Я только идею написал. Если подробнее, то

Код:
type
 PRec = ^TRec;  
 TRec = record  
    Column1 : TcxGridDBColumn;  
    Column2 : TcxGridDBColumn;  
  end;
var
  Rec1: PRec;
.....
New(Rec1);
Rec1.Column1 := cxGridDBColumn1;
Rec1.Column2 := cxGridDBColumn2;
cxGridDBColumn3.Tag := Integer(Rec1);
........
// Обратится к Column1, Column2
// PRec(cxGridDBColumn3.Tag)^.Column1  
// PRec(cxGridDBColumn3.Tag)^.Column2
.........  
Dispose(Rec1);

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 11:26 25-05-2011 | Исправлено: marser, 11:45 25-05-2011
fortezza

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

Всего записей: 98 | Зарегистр. 20-10-2009 | Отправлено: 11:45 25-05-2011
mdid

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

Всего записей: 1298 | Зарегистр. 13-02-2006 | Отправлено: 17:29 25-05-2011 | Исправлено: mdid, 17:29 25-05-2011
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Никак. Неправильную ты привязку сделал. Откуда в гриде будет значение, если кверя пустая?
 
В датасете живёт число 1, а за счёт квери грид показывает не 1, а то ,что соответствует этой цифре. Читай про lookup поля в датасетах.

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 17:36 25-05-2011
marser

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mdid
1. Сделайте в Properties.ListSource.DataSet запрос всех товаров, причем так, чтобы было поле с признаком "это остатки товаров".
2. Добавте колонку в Properties.ListСolumns c полем "это остатки товаров". Установите фиксированную ширину колонки равной нулю (чтобы её сделать невидимой).  
3. Используя колонку с полем "это остатки товаров", на событии Properties.OnInitPopup, установите фильтр Properties.Grid.DataController.Filter так, чтобы показывались только остатки товаров.

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 19:52 25-05-2011 | Исправлено: marser, 20:07 25-05-2011
mdid

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

Код:
 
  GetNomenclature; <-заполнили лукап товаром
  for I:=0 to DataSource1.DataSet.RecordCount - 1 do begin
    cxGrid1TableView1.DataController.FocusedRecordIndex:=
      cxGrid1TableView1.DataController.AppendRecord;
 
    gr_Title.EditValue:=DataSource1.DataSet.FieldByName('Title').AsVariant;<- присваиваем наименование
 
 

по идее уже тут не должно работать
 
Добавлено:
marser
да у мя просто процедура на серваке подсчет ведет и из за такой ерунды не хочется переписывать

Всего записей: 1298 | Зарегистр. 13-02-2006 | Отправлено: 20:02 25-05-2011
marser

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mdid
У Вас в gr_Title.Properties.KeyFieldNames поле, содержащие наименование? Забавно!
Если так, то нужно использовать СomboBoх.

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 20:24 25-05-2011 | Исправлено: marser, 21:49 25-05-2011
fortezza

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mdid, если правильно тебя поняла, то я решила этот вопрос таким образом: в основном квери сделала left join с той таблицей которая отображается у тебя в лукап  и вывела в гриде ещё одну колонку с наименованием (или чем там тебе нужно), сделала ее скрытой. на колонке, где у меня весит лукап, в событии OnGetDisplayText такой код:
 
  if VarToStr(ARecord.Values[лукап_колонка.Index]) = '' then
    AText := VarToStr(ARecord.Values[колонка_с_текстом.Index]);
 
таким образом текст у меня никуда не девается, но в лукапе только актуальные значения.
 
p.s. если использовать left join на квери должен висеть апдейтер

Всего записей: 98 | Зарегистр. 20-10-2009 | Отправлено: 08:18 26-05-2011
marser

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mdid
Я никак понять не могу. Если у Вас Properties.KeyFieldNames = Properties.ListFieldNames, то зачем лукап? Что там лукапить? Объясните мне, бестолковому.

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 09:27 26-05-2011 | Исправлено: marser, 09:31 26-05-2011
mixerr

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Разбираюсь с ASPxGridView, В ASP.net заполняю ASPxGridView с помощью коллекции. По нажатию кнопки создается экземпляр коллекции и в ней добавляются значения, далее ASPxGridView1.DataSource = result; /*rezult - коллекция*/   ASPxGridView1.DataBind();. В таблице выводятся значения, но по нажатию кнопок page внизу ASPxGridView, срабатывает сообщение loaging и далее пустой список, даже если вернуться на 1 страницу. Вроде как теряется коллекция, то же самое с сортировкой по нажатию на заголовок. Подскажите что не так?

Всего записей: 1 | Зарегистр. 26-05-2011 | Отправлено: 14:34 26-05-2011
volser

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mixerr
Грузите данные не по кнопке, а в методе Page_Load.

Всего записей: 713 | Зарегистр. 31-03-2006 | Отправлено: 21:01 27-05-2011
indapublic



BANNED
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Доброго дня всем.
Ситуация:
 
Есть собственные классы
 
TcxLookupComboBoxPropertiesExtended = class(TcxLookupComboBoxProperties)
TcxLookupComboBoxExtended = class(TcxLookupComboBox)
TcxEditRepositoryLookupComboBoxExtendedItem = class(TcxEditRepositoryLookupComboBoxItem)
 
Контрол ведет себя хорошо, все работает.
Необходимо добавить стиль в репозиторий TcxEditRepository.
В рантайме создаю элемент класса TcxEditRepositoryLookupComboBoxExtendedItem и заполняю - все хорошо.
 
Вопрос:
Когда я в дизайн-тайме добавляю элемент в репозиторий - выводятся стандартные классы DevExpress. Каким образом я могу добавить свой класс в тот список?
 
 

Всего записей: 200 | Зарегистр. 05-02-2008 | Отправлено: 17:04 28-05-2011 | Исправлено: indapublic, 17:10 28-05-2011
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Как у строки cxVerticalGrid сделать Caption многострочным?
 
Добавлено:
Сколько версий прошло уже, а до сих пор не исправили баг с двойным срабатыванием события OnFocusedRecordChanged при первом открытии датасета в cxGrid`е

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 09:51 31-05-2011
BlackVetal



Advanced Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
X11
по идеи должно быть свойство "Высота" у строки, а в appearance в свойствах текста выстаить переносы

Всего записей: 1094 | Зарегистр. 13-11-2005 | Отправлено: 13:30 31-05-2011
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
AutoHeight не помогает
 
Добавлено:
Разве что так

Код:
cxVerticalGrid1EditorRow1.Properties.Caption := 'Первая строка' + #13#10 + 'вторая строка';

 
Но тогда нужно самому рассчитывать, где ставить переносы

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 13:41 31-05-2011
G1zm0



Newbie
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Бодрого времени суток товарищи, прошу помощи вашей о знатоки :
пишу и использую D2010, DevExpX55
столкнулся с  проблемой такого плана : cxEditRepository есть DateEdit, но у этого DateEdit нету свойства .Date а оно очень надо

Всего записей: 20 | Зарегистр. 01-06-2011 | Отправлено: 07:24 01-06-2011
marser

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

Цитата:
cxEditRepository есть DateEdit, но у этого DateEdit нету свойства .Date а оно очень надо

Зачем? Напишите подробнее, что Вы хотите сделать?

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 08:11 01-06-2011
Открыть новую тему     Написать ответ в эту тему

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