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

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

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
reenoip
И какая же по-вашему строка кода запускает диалог? И что исполняется до, а что после закрытия?  
 
Добавлено:
serg87i
Даже не ужас. Ужас-ужас.

Цитата:
Может есть другие способы экспорта из таблиц не обязательно через грид?

Мильён разных способов. Только надо задачу описать конкретнее, а то, пардон, бисер метать - надоедает.

Всего записей: 1036 | Зарегистр. 17-05-2003 | Отправлено: 11:00 03-02-2013
serg87i

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Задача выгрузить данные из базы. Есть запрос, нужен экспорт в XLSX. Спс.

Всего записей: 9 | Зарегистр. 02-02-2013 | Отправлено: 13:42 03-02-2013
makz

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
serg87i
Если без самого excel надо обойтись, то например _http://www.tmssoftware.com/site/flexcel.asp, а если excel есть, то можно через OLE.

Всего записей: 1036 | Зарегистр. 17-05-2003 | Отправлено: 14:39 03-02-2013
X11



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

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

 
Наберите в гугле: cxGrid цикл по выделенным записям
 
Добавлено:

Цитата:
Может есть другие способы экспорта из таблиц не обязательно через грид?

 
Есть. Однозначно есть.

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 11:12 04-02-2013
reenoip



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

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

Так если бы я знал - разве б я спрашивал?
 
 
 
 
 
 
А как вот это можно перевести с "С++" на "Delphi"?
 

Код:
//Setting the BarEditItem's value to "Checked"
    cxBarEditItem1->EditValue = ((TcxCheckBoxProperties*)cxBarEditItem1->Properties)->ValueChecked;
 
    //Setting the BarEditItem's value to "Unchecked"
    cxBarEditItem1->EditValue = ((TcxCheckBoxProperties*)cxBarEditItem1->Properties)->ValueUnchecked;

Всего записей: 1768 | Зарегистр. 10-03-2006 | Отправлено: 14:25 04-02-2013
makz

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

Код:
procedure TForm1.Button1Click(Sender: TObject);  
begin  
with SaveDialog1, cxGrid1 do begin
FileName:=DateToStr(Date);
if execute then  
ExportGridToExcel(FileName, cxGrid1, true, true, true, 'xls');  
end;  
end;

 
 
    cxBarEditItem1.EditValue := TcxCheckBoxProperties(cxBarEditItem1.Properties).ValueChecked;  
   
 

Всего записей: 1036 | Зарегистр. 17-05-2003 | Отправлено: 15:54 04-02-2013 | Исправлено: makz, 15:57 04-02-2013
reenoip



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
makz
благодарю.
 
Только скажи, пожалуйста, как ты это узнал? А то у меня открыт хэлп по этому компоненту, и я его перед тем, как сюда написать, вывернул наизнанку, но всё равно не смог найти искомое (плохо ищу?). Выходит, я либо не так ищу, либо файл у меня устаревший.
 
 

 
Добавлено:

Цитата:
procedure TForm1.Button1Click(Sender: TObject);  
begin  
with SaveDialog1, cxGrid1 do begin  
FileName:=DateToStr(Date);  
if execute then  
ExportGridToExcel(FileName + '.', cxGrid1, true, true, true, 'xls');  
end;  
end;

makz
это,кстати, то, что нужно, но я чуть-чуть изменил имя (выделил жирным), а то у меня год "съедался", почему-то, в итоге имя файла выглядело как "04.02.xls" вместо "04.02.2013.xls".
 
Огромное спасибо за помощь!

Всего записей: 1768 | Зарегистр. 10-03-2006 | Отправлено: 16:40 04-02-2013
makz

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
reenoip
Знание некоторых принципов, восполняет незнание многих фактов. Ничего я не знал - это перевод того что ты просил перевести.

Всего записей: 1036 | Зарегистр. 17-05-2003 | Отправлено: 18:24 04-02-2013
reenoip



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Понятно. В любом случае, спасибо ещё раз за помощь.
 
 
 
 
 
 
 
Новый вопрос: как мне в cxGrid русифицировать "summary"?
 
   
 
Все остальные компоненты русифицированы нормально (через подключение ресурсов), и сам грид в целом тоже, но "шапки" без перевода. Посмотрел *.ini (служивший в качестве исходника для *.rc), пропущенных строк не обнаружил, в итоге попробовал подключить его (мало ли, вдруг *.rc как-то криво скомпилировался, а в *.ini всё пучком), но - безрезультатно.
 
Добавлено:
Т.е. мне бы русифицировать COUNT. Или это "by design"?
 
Добавлено:
И вдогонку: как мне экспортировать это хозяйство из cxGrid в сгруппированном виде (т.е. как на рисунке)? А то сейчас при попытке экспорта в тот же *.xls таблица уходит в развёрнутом виде.

Всего записей: 1768 | Зарегистр. 10-03-2006 | Отправлено: 13:25 05-02-2013
X11



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

Цитата:
 как мне экспортировать это хозяйство из cxGrid в сгруппированном виде

 
Справка поможет.
А посмотреть параметры ExportGridToExcel не получается?

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 14:43 05-02-2013
Pint pot

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Доброго времени суток.
 
Вопрос мой связан с компонентом TcxDBTreeList (v. 5.58).
Имеется рабочее приложение, в котором используется TcxDBTreeList. По появившемуся желанию заказчика, должна быть реализована возможность выделения и последующего копирования данных в буфер (затем в Excel) отдельной группы ячеек. То есть стандартным образом можно выделять только целыми нодами-записями по всем имеющимся полям.  
Я спрашивал на сайте техподдержки http://www.devexpress.com/Support/Center/Question/Details/Q470423 "как быть?" Мне указали на то, что это возможно реализовать только вручную.
 
Прошу помочь, желательно рабочим кодом-примером (!), как, например, отлавливать событие клика мышкой по ячейке (или выделение области ячеек мышкой с зажатой левой кнопкой мыши, или комбинации Shift + Arrow) и по нему выделять отдельные ячейки или хотя бы как-то маркировать их (менять цвет текста или фона, например).
 

Всего записей: 8 | Зарегистр. 24-01-2013 | Отправлено: 16:07 05-02-2013 | Исправлено: Pint pot, 16:16 05-02-2013
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Я бы отобразил чекбоксы и пусть юзер сам решает с помощью чекбоксов, что ему нужно копировать.
В дереве реализовано так, что если отмечаешь узел, то автоматически отмечаются и все дочерние подузлы.

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 16:28 05-02-2013
makz

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
reenoip
В Default For Groups например написать <Кол-во:##> в св-ве Format.

Всего записей: 1036 | Зарегистр. 17-05-2003 | Отправлено: 16:38 05-02-2013
reenoip



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
makz
спасибо огромное!!!
 
Добавлено:
Как правильно программным путём отменять группировку колонок "group by box" в cxGrid?
 
Пока, к сожалению, самостоятельно смог додуматься лишь до такого извращения:

Код:
cxGrid1DBTableView1***.GroupIndex1:=-1;

... и следом (чтобы колонка из грида не пропала) добавлять:

Код:
cxGrid1DBTableView1***.Visible:=true;

 
Наверняка же должен существовать более элегантный способ. Кто знает - подскажите, пожалуйста.

Всего записей: 1768 | Зарегистр. 10-03-2006 | Отправлено: 17:08 05-02-2013
Pint pot

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Никто ничего больше не подскажет? Мне необходимо реализовать требование именно описанным способом. То есть операция выделения группы ячеек должна выглядеть как выделение группы ячеек в MS Excel.  
 
Вот как оно выглядит сейчас в TreeList. И надо сделать так как это получается на картинке с Grid-ом. То есть выбирать ячейки с данными за интересующие показываемые годы.
http://s2.uploads.ru/ty8eD.png
http://s2.uploads.ru/W1xRT.png
 
Кто-нибудь работал с событиями типа onCustomDrawDataCell у TcxDBTreeList?

Всего записей: 8 | Зарегистр. 24-01-2013 | Отправлено: 22:52 05-02-2013
eddoc



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

Цитата:
Как правильно программным путём отменять группировку колонок "group by box" в cxGrid?  


Чем глубже я познаю девок, тем больше прихожу к выводу, что компоненты должны прежде всего облегчать жизнь кодеру, а не наоборот.
 

Всего записей: 328 | Зарегистр. 25-11-2007 | Отправлено: 23:23 05-02-2013
X11



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

Цитата:
Как правильно программным путём отменять группировку колонок "group by box" в cxGrid?

 
 
посмотри .DataController.Groups..... нет дельфи под рукой и справку глянь

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 00:34 06-02-2013
marser

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Pint pot
В обработчике события OnMouseDown, используя cxTreeList.HitTest, запоминаете индексы Node и Column. В обработчике события OnCustomDrawDataCell проверяете совпадение индексов (if (AViewInfo.Node.AbsoluteIndex = ...) and (AViewInfo.Column.ItemIndex = ...)) и раскрашиваете нужные ячейки (ACanvas.Brush.Color := ..., ACanvas.Font.Color := ...)

Всего записей: 398 | Зарегистр. 29-03-2007 | Отправлено: 08:13 06-02-2013
X11



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

Цитата:
Как правильно программным путём отменять группировку колонок "group by box" в cxGrid?  

 
<YourTableView>.DataController.Groups.ClearGrouping;
 
Добавлено:
Да, а ещё есть <YourTableView>.DataController.ClearSorting(False);

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 12:01 06-02-2013
Pint pot

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
marser
 
Спасибо за указание нужного направления! Это то, что надо

Всего записей: 8 | Зарегистр. 24-01-2013 | Отправлено: 16:55 06-02-2013
Открыть новую тему     Написать ответ в эту тему

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