Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 649

•  TDictionary Custom Sort  6 651

•  Fast Watermark Sources  6 432

•  3D Designer  9 371

•  Sik Screen Capture  6 759

•  Patch Maker  7 156

•  Айболит (remote control)  7 163

•  ListBox Drag & Drop  6 016

•  Доска для игры Реверси  97 614

•  Графические эффекты  7 344

•  Рисование по маске  6 632

•  Перетаскивание изображений  5 499

•  Canvas Drawing  5 883

•  Рисование Луны  5 608

•  Поворот изображения  5 111

•  Рисование стержней  3 686

•  Paint on Shape  2 914

•  Генератор кроссвордов  3 811

•  Головоломка Paletto  3 062

•  Теорема Монжа об окружностях  3 867

•  Пазл Numbrix  2 547

•  Заборы и коммивояжеры  3 267

•  Игра HIP  2 238

•  Игра Go (Го)  2 171

•  Симулятор лифта  2 550

•  Программа укладки плитки  2 186

•  Генератор лабиринта  2 686

•  Проверка числового ввода  2 331

•  HEX View  2 667

•  Физический маятник  2 303

 
скрыть

Не работает передача данных по OLE в русский Excel



Автор: Nomadic

Мёpтвый диск не жyжжит,
Мёpтвый сидиpом не поёт,
Мёpтвый компьютеp игpy запyскать не идёт,
Только мёpтвый компьютеp игpy запyскать не идёт...

A: (SM): Дело в том что в VCL твои команды OLE2 передаются Excel'у в русском контексте (не знаю, как это правильно назвать). Для исправления необходимо найти в файле OLEAUTO.pas в функции GetIDsOfNames строчку


if Dispatch.GetIDsOfNames(GUID_NULL, @NameRefs, NameCount,
LOCALE_SYSTEM_DEFAULT, DispIDs) <> 0 then

и заменить ее на


if Dispatch.GetIDsOfNames(GUID_NULL, @NameRefs, NameCount,
((LANG_ENGLISH+SUBLANG_DEFAULT*1024)+SORT_DEFAULT* 65536 ),
DispIDs) <> 0 then

После этого у меня Excel стал понимать нормальные английские команды :)). Необходимая комбинация для установки английского языка взята из C-шных хедеров.