Общие принципы создания контроллеров автоматизации MS Office
Операционная система (ОС) Windows — не исключение
из этого правила и предоставляет множество механизмов такой поддержки.
Работа ОС Windows предусматривает передачу и обработку сообщений как
между ОС и приложением, так и между приложениями, а также использо-
вание динамических библиотек. Этот механизм был использован еще в пер-
вых версиях Windows и отразился на методах разработки приложений для
этой ОС. Основой программирования в первых версиях Windows стало про-
граммирование объектов, потому что любая программа этой ОС представля-
ла собой объект. С развитием операционной системы развивались и меха-
низмы взаимодействия программ. Развитие шло от обмена сообщениями,
использования DLL (Dynamic Link Library, динамически подключаемые
библиотеки процедур и функций) и механизма DDE (Dynamic Data Exchange,
динамический обмен данными) к современным технологиям, основан-
ным на OLE (Object Linking and Embedding, связывание и внедрение объек-
тов), COM (Component Object Model, компонентная модель объектов),
DCOM (Distributed Component Object Model, распределенная компонентная
модель объектов). Этот переход был обоснован тем, что стало недостаточ-
ным использование только функций и процедур, предоставляемых внешни-
ми программами и библиотеками. На первый план вышла необходимость
управления целыми объектами, которые представляют собой приложения
или документы и расположены как в одном адресном пространстве управ-
ляющей программы, так и вне этого пространства или даже на другом ком-
пьютере локальной сети. Такая постановка задачи повлекла за собой рево-
люционные изменения как в структуре ОС Windows, так и в программах,
предназначенных для разработки приложений. Приложения MS Office пред-
ставляют собой объекты-серверы, которые могут управляться внешними
программами, и здесь не последнюю роль играют механизмы СОМ и OLE.
Модель СОМ предоставляет возможность создания многократно используе-
мых объектов в различных приложениях, поддерживающих этот интерфейс.
Объектами СОМ являются приложения-серверы, специальным образом
оформленные и зарегистрированные в системе. Они могут быть представле-
ны в формате ЕХЕ- или DLL-модулей. Эти серверы могут загружаться и
выполняться как в адресном пространстве вызывающего приложения, так и
в виде самостоятельного процесса, или на другом компьютере сети (распре-
деленная модель СОМ — DCOM). Они должны быть написаны на любом
языке, поддерживающем интерфейс СОМ.
Развитие технологии СОМ продолжает ее подмножество — технология OLE
Automation (автоматизация OLE). Ее отличие в том, что она позволяет ис-
пользовать возможности СОМ не только языкам-компиляторам, но и ин-
терпретаторам, и обеспечивает связь с вызываемыми методами на стадии
выполнения приложения. Такой способ вызова называется поздним связыва-
нием. Методы при таком способе вызова выполняются медленнее, причем
заранее нельзя проверить правильность написания объектов и их методов.
Преимуществом такого метода является независимость выбора среды разра-
ботки от объекта, который нужно программировать.
Среда Delphi поддерживает вызовы методов серверов автоматизации.
Примечание Сервер автоматизации представляет собой программу, которая может управ-
ляться внешней программой — контроллером автоматизации. Сервером в
данном случае является Word или Excel, а контроллер разрабатывается про-
граммистом.
Для этого используются переменные типа Variant, которые содержат ссылки
на объекты автоматизации. На этапе выполнения программы серверу авто-
матизации передается команда в виде строки, предварительно записанной в
переменную типа Variant. Рассмотрим в качестве примера следующий фраг-
мент программы:
Загрузка Internet Explorer
Uses ComObj;
Var IE:variant;
procedure TMainForm.ButtonlClick(Sender: TObject);
begin
IE:=CreateOleObject('InternetExplorer.Application');
IE.Visible:=true; // Нужно выбрать один из операторов
IE.Visible:=false; //и проверить, как это работает
***
end;
Переменная IE типа Variant не имеет никаких свойств и методов, но, тем не
менее, программа откомпилируется и будет выполняться. Если мы вместо
свойства Visible напишем любое другое свойство, которое не поддерживает
IE, то компилятор ошибки не выдаст, а на стадии выполнения произойдет
ошибка. Это особенности позднего связывания — свойства и методы прове-
ряются в самом приложении-сервере на стадии выполнения. Можно доба-
вить, что весь этот механизм работает за счет COM API. В данной книге нет
смысла подробно рассматривать вызовы его функций и процедур. Наша за-
дача — научиться создавать и использовать контроллеры автоматизации (что
это такое, рассказано чуть позже) для приложений MS Office Word и Excel,
которые наиболее часто используются как приложения для пользователей и
как серверы для создания приложений. Используя контроллеры автомати-
зации, в приложениях, созданных в среде Delphi, можно так же просто, как
при обычной работе с Word и Excel, создавать документы со всеми возмож-
ными элементами. Таблицы, надписи, текст, диаграммы и другие компо-
ненты полноценных документов появятся в таком виде, как будто они соз-
даны пользователем. Далее в книге все примеры будут описывать в основ-
ном только работу с Word и Excel и позднее связывание.
Перейдем непосредственно к контроллерам автоматизации. Из уже сказан-
ного понятно, что контроллер автоматизации— это программа, которая
"умеет" управлять приложениями MS Office и процессом создания докумен-
тов в среде Word и Excel. Для того чтобы все это работало корректно, про-
грамма-контроллер должна выполнить следующие функции:
1. Проверить, запущено приложение (Word, Excel) или нет.
2. Если приложение не запущено, запустить его.
3. Выполнить ряд необходимых манипуляций с приложением, документом.
4. Закрыть документ и приложение.
5. Очистить память.
Как уже сказано, доступ к документам и приложениям можно осуществлять
через объекты, стоящие на вершине объектной модели приложений MS Office.
Через них мы получаем доступ к внутренней структуре документов и
приложений, поэтому при создании контроллеров автоматизации мы можем
использовать только их. В табл. 3.1 и 3.2 приведены эти объекты и дана их
краткая характеристика.
Таблица 3.1. Объекты MS Word
Таблица 3.2. Объекты MS Excel
Мы подошли к вопросам создания контроллеров автоматизации в среде
Delphi. В следующей главе мы рассмотрим инструменты среды Delphi.
Тарифы на курьерскую доставку документов по России. http://fox-express.ru/services/ если вам необходимо что то передать или перевезти важные документы.
Опубликовал Kest
September 14 2009 07:59:23 ·
0 Комментариев ·
8774 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.