Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.03.27;
Скачать: CL | DM;

Вниз

Как определить что OLE automation object закончил свою работу ?   Найти похожие ветки 

 
greysers   (2005-03-10 20:58) [0]

есть такой код :

try
 try
   MSWord := GetActiveOLEObject("Word.Application");
 except
   MSWord := CreateOleObject("Word.Application");
 end;
except
 ShowMessage("Не удается запустить Microsoft Word.");
 SysUtils.Abort;
end;

D := MSWord.Documents.Open(GetEnvVariable("TEMP") + "\mstext.html");
D.SaveAs(GetEnvVariable("TEMP") + "\mstext.rft",$00000006);
MSWord.Quit;
sleep(1000);
// какие-то действия с mstext.rft


я делаю sleep(1000), чтобы Word успел сохранить файл mstext.rft, иначе у меня не будет доступа к файлу mstext.rft и будет ошибка.
Но это не совсем правильно.
Можно ли как нибудь определить, что OLE automation object ещё что-то делает (в данном случае сохраняет в файл mstext.rft)?


 
Polevi ©   (2005-03-10 21:03) [1]

а что D.SaveAs асинхронный метод ?


 
greysers   (2005-03-10 21:09) [2]

Видимо да, у меня выдает ошибку, если сразу после MSWord.Quit делаю reText.Lines.LoadFromFile(GetEnvVariable("TEMP") + "\mstext.rft");


 
Vlad ©   (2005-03-10 21:19) [3]

MSWord.Quit;
MSWord := Unassigned;


 
greysers   (2005-03-10 21:21) [4]

> Vlad ©
спасибо , помогло



Страницы: 1 вся ветка

Текущий архив: 2005.03.27;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.059 c
10-1087825303
bsFrame
2004-06-21 17:41
2005.03.27
Масштабирование TextBox в Word


3-1109425396
Jiny
2005-02-26 16:43
2005.03.27
Как работать с MS SQL в Дельфи 7


14-1109939219
saNat
2005-03-04 15:26
2005.03.27
Индикатор языка клавиатуры


3-1109239539
Dimedrol
2005-02-24 13:05
2005.03.27
TTable + varchar(500)


3-1109686597
juice
2005-03-01 17:16
2005.03.27
Индикатор долгого SQL-запроса