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

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Вопросы по компонентам для Delphi, C++ Builder разных версий

Модерирует : ShIvADeSt

ShIvADeSt (26-06-2017 02:39): Продолжение тут
http://forum.ru-board.com/topic.cgi?forum=33&topic=14667
 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 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 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411

   

ShIvADeSt



Moderator
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Продолжение раздела http://forum.ru-board.com/topic.cgi?forum=33&topic=6607&start=0  
Ссылки приветствуются.

См. также:

Всего записей: 3956 | Зарегистр. 29-07-2003 | Отправлено: 07:33 20-06-2007 | Исправлено: XPerformer, 14:41 24-10-2013
MagistrAnatol



Silver Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Подсобите с запросом в файребирд 2,5
 
Table1
     OPER_TYPE integer,
     OPER_DATE DATE,
     FIO varchar(70),
     TABLE_ID integer,autoinc,pk
 
OPER_TYPE OPER_DATE   FIO             TABLE_ID  
1                01.01.2015   Петров        1
2                12.02.2015   Петров        2    
....
4                25.09.2015   Сидоров      180
 
 
Надо выбрать тех людей у которых OPER_TYPE in (1,2) и OPER_DATE  с OPER_TYPE 2 больше OPER_DATE  с OPER_TYPE 1 и показать все записи по етим людям с  OPER_TYPE in (1,2)    
 
 
 
Добавлено:
Часть запроса уже есть
 

Код:
select
    o1.FIO
from Table1 o1
where o1.OPER_TYPE=1  
and o1.FIO in (select o2.FIO from Table1o2 where o2.OPER_TYPE=2)
union all
 
select
    o2.FIO
from Table1 o2
where o2.OPER_TYPE=2
and o2.FIO in (select o2.FIOfrom Table1 o2 where o2.OPER_TYPE=1)

но как сравнить даты пока не ясно

Всего записей: 2120 | Зарегистр. 09-04-2003 | Отправлено: 13:58 13-06-2015
dzh2000



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

Код:
select * from TABLE1 where FIO in
  (select a.FIO from TABLE1 a, TABLE1 b
  where a.FIO = b.FIO and a.OPER_TYPE = 2 and
  b.OPER_TYPE = 1 and a.OPER_DATE > b.OPER_DATE)
  where OPER_TYPE in (1, 2)
  order by FIO, OPER_TYPE;

P.S. В теории у людей должен быть ID.
2P.S. Для текущего запроса желательны индексы по полям FIO и OPER_DATE.
 
Добавлено:
Alexey_Gawrilow

Цитата:
Как раз тот случай, когда не худший вариант.  

Данный вариант не позволит создать единообразный интерфейс, поскольку поделка от Berg'а использует свои внутренние edit'ы.
А с Virtual TreeView можно создать собственные редакторы данных.

Всего записей: 1576 | Зарегистр. 18-01-2002 | Отправлено: 15:43 13-06-2015 | Исправлено: dzh2000, 16:11 13-06-2015
MagistrAnatol



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

Всего записей: 2120 | Зарегистр. 09-04-2003 | Отправлено: 16:19 13-06-2015
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Форумчане, подскажите такой вопрос - задача такая используя какой нибудь грид сохранять/привязывать к ячейке структуру типа record и в зависимости от каких то праметров этой структуры соответствующе раскрашивать эту ячейку, например ListView умеет хранить в элементе объект, но он не подходит, нужен грид - копаю в сторону drawgrid но не знаю как привязать к ячейке record, свой класс писать нет времени, должно же быть быстрое решение?

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 15:58 14-06-2015 | Исправлено: Andryshok, 15:59 14-06-2015
Chukotka

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

Цитата:
Форумчане, подскажите такой вопрос - задача такая используя какой нибудь грид сохранять/привязывать к ячейке структуру типа record и в зависимости от каких то праметров этой структуры соответствующе раскрашивать эту ячейку
DevExpress:cxGrid
создаешь колонки, пишешь обработчики OnGetDisplayText\OnGetStyle. Данные хранишь где хочешь - массив, список, etc

Всего записей: 428 | Зарегистр. 01-11-2006 | Отправлено: 16:07 14-06-2015
Andryshok



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

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 16:16 14-06-2015
X11



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

Цитата:
например ListView умеет хранить в элементе объект

 
а cxGrid умеет хранить грид в гриде, хоть что угодно в гриде, там есть popup, ExtLookup И т.д.

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 16:18 14-06-2015
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
X11 ! cxGrid должен быть привязан к датасету поэтому не годится, memorydata использовать тоже не годится. Вобщем знает кто нибудь как запихнуть в ячейку drawgrid record , указатель на объект?

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 16:32 14-06-2015
Samotek

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

Цитата:
Вобщем знает кто нибудь как запихнуть в ячейку drawgrid record , указатель на объект?  

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

Всего записей: 2448 | Зарегистр. 18-05-2005 | Отправлено: 16:48 14-06-2015 | Исправлено: Samotek, 16:49 14-06-2015
X11



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
создай доп. колонку, непривязанную к НД

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

Всего записей: 3253 | Зарегистр. 24-11-2005 | Отправлено: 17:08 14-06-2015
Chukotka

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

Цитата:
cxGrid должен быть привязан к датасету поэтому не годится, memorydata использовать тоже не годится. Вобщем знает кто нибудь как запихнуть в ячейку drawgrid record , указатель на объект?  

Samotek тебе уже написал - ничего не нужно привязывать, в том вся и прелесть. Ты указываешь количество записей в таблице, а потом - отрисовываешь так как тебе нужно в обработчиках.
ЗЫ. Доеду до дома, скину пример кода

Всего записей: 428 | Зарегистр. 01-11-2006 | Отправлено: 17:34 14-06-2015 | Исправлено: Chukotka, 18:14 14-06-2015
Samotek

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
Кстати неплохой вариант тебе раньше предложили - делаешь массив своих записей, в специальную колонку датасета - индекс массива. в обработчике получения параметров ячейки используя соответствующий индекс получаешь доступ к своим записям в массиве. Нормальное дело... Правда, если у тебя не редактируемый датасет, то надо в своей записи создавать дополнительные ключевые поля со значениями из записи датасета и в методе отображения ячейки находить по этому ключу соответствующую запись в массиве.

Всего записей: 2448 | Зарегистр. 18-05-2005 | Отправлено: 20:47 14-06-2015 | Исправлено: Samotek, 20:52 14-06-2015
Chukotka

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

Код:
 
const
  MaxCoolRecs = 100;
type
  TMyCoolRec = record
    a, b: integer;
  end;
type
  Form1 = class(TFom)
  private
    FRecs: array[0..MaxCoolRecs-1] of TMyCoolRec;
  end;
 
implementation
 
procedure TForm1.FormCreate(Sender: TObject);
begin
  GridView.DataController.RecordCount := MaxCoolRecs;
end;
 
procedure TForm1.GridViewColumn1GetDisplayText(Sender: TcxCustomGridTableItem;
  ARecord: TcxCustomGridRecord; var AText: string);
begin
  AText := Format('%d', [FRecs[ARecord.RecordIndex]]);
end;
 
procedure TForm1.GridViewColumn4CustomDrawCell(Sender: TcxCustomGridTableView;
  ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo;
  var ADone: Boolean);
begin
  case Random(10) of
    0..1: ACanvas.Brush.Color := clYellow;
    2..5: ACanvas.Brush.Color := clRed;
    6..7: ACanvas.Brush.Color := clLime;
    else ACanvas.Brush.Color := clNavy;
  end;
end;
 
 


Всего записей: 428 | Зарегистр. 01-11-2006 | Отправлено: 21:10 14-06-2015
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Спасибо парни за советы, да - вариант с индексом массива неплох, но это не совсем то что нужно было - нужна таблица так в двух словах и не объяснишь, решил проблему использованием TWebBrowser и HTML кодом - получил нужную мне таблицу с раскраской.
Проблема номер 2 - TwebBrowser не понимает свойста css - border-radius, нарыл что по дефолту он использует старую версию IE , может подскажет кто как бороть это?

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 22:48 14-06-2015
Chukotka

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

Цитата:
Спасибо парни за советы, да - вариант с индексом массива неплох, но это не совсем то что нужно было - нужна таблица так в двух словах и не объяснишь, решил проблему использованием TWebBrowser и HTML кодом - получил нужную мне таблицу с раскраской.
Ух ты, что сказать... Неожиданно. Ну что сказать, хозяин-барин.

Всего записей: 428 | Зарегистр. 01-11-2006 | Отправлено: 23:20 14-06-2015
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Сам спросил сам отвечаю, чтобы изменить версию IE в TWebBrowser нужно лезть в реестр, в данной процедуре меняется версия на 11  

Код:
 
procedure TMainF.DoSetIeVersion;
var
   Reg : TRegistry;
begin
  Reg := TRegistry.Create;
  try
    Reg.RootKey := HKEY_CURRENT_USER;
    Reg.OpenKey('SOFTWARE\Microsoft\Internet Explorer\Main\FeatureControl\FEATURE_BROWSER_EMULATION', true);
    Reg.WriteInteger(Имя файла приложения, 1101);
    Reg.CloseKey;
 
  finally
    Reg.Free;
  end;
end;
 

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 00:27 15-06-2015
xpin2013



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
Познавательно. Для IE7 не обнаружил FEATURE_BROWSER_EMULATION, ни в локальной машине ни у пользователя. А ещё бы кто понимал, что такое реестр пользователя у программиста Delphi, у которого рабочим местом считается комп с обвязкой D2010...XE7, а в реальности D7...XE7. Некоторым "админам" даже на лбу написать бы.
 
Про использование IE по-быстрому, не спорю. Но вообще, я понимаю когда IE используют, например потому что отсутствует нормальное решение для GIF картинки, спустя 15 лет как формат не моден (взять хотя бы 2006 год). Но просто так, я бы не рекомендовал, думаю есть немало пользователей, у которых TWebBrowser просто может свой CLSID не обнаружить.
 
Добавлено:
ps
да и "раз такая пьянка". думаю не 1101, а 11001 - вроде по 3 знака там.

Всего записей: 291 | Зарегистр. 16-01-2014 | Отправлено: 10:42 15-06-2015 | Исправлено: xpin2013, 10:47 15-06-2015
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
xpin2013 Ну -порядок действий:
1 - Ставится нужная версия IE на машину пользователя
2 - В софтине добавляется ключ в указанную ветку реестра указывающий какую версию ie использовать именно для вашего приложения.

Цитата:
А ещё бы кто понимал, что такое реестр пользователя у программиста Delphi, у которого рабочим местом считается комп с обвязкой D2010...XE7, а в реальности D7...XE7
- не совсем понимаю о чем вы.

Цитата:
я бы не рекомендовал, думаю есть немало пользователей, у которых TWebBrowser просто может свой CLSID не обнаружить
- в поставку ПО включаете инсталляк IE нужной версии, и все. Решение не потому что gif картинки а потому что нужно использовать все прелести css. Ранее писал в команде одно корпорптивное ПО - для веденеия журналов использовали именно TwebBrowser - работает по всей моей стране - ни укого трабл из-за с TwebBrowser не возникало, хорошо тем что это "родное решение дельфи" можно конечно geсko прикрутить, но пока мне не нужно.
 
 
 

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 10:56 15-06-2015 | Исправлено: Andryshok, 10:57 15-06-2015
protoror



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
не проще ли dcef использовать, и ничего устанавливать не надо и border radius из коробки?

Всего записей: 494 | Зарегистр. 23-11-2009 | Отправлено: 11:14 15-06-2015
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
protoror Embedding Chromium (CEF1) in Delphi, tested on Delphi 2010, XE, XE2, Delphi 7.  Не годится, потому как нет времени для теста его ,под нужную версию не тестилось.

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 11:20 15-06-2015
   

Страницы: 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 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Вопросы по компонентам для Delphi, C++ Builder разных версий
ShIvADeSt (26-06-2017 02:39): Продолжение тут
http://forum.ru-board.com/topic.cgi?forum=33&topic=14667


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru