Чтобы импортировать компонент ActiveX в среду .NET, утилита
AxImp.exe
вызывается из командной строки. Команда состоит из двух частей:
1. Имени
AxImp
.
2. Абсолютного или относительного пути доступа к файлу ActiveX (
*.осх
), который должен быть импортирован.
Для примера рассмотрим снимок экрана, приведенный ниже. Здесь импортируется элемент управления ActiveX Win32 MAPI и определяется расположение файла
.осх
(
C:\windows\system\msmapi32.осх
):
Как
можно видеть, программа
AxImp.exe
выводит два файла.
Первый выходной файл
MSMAPI.dll
является прокси для сборки. Он позволяет ссылаться на компонент ActiveX, как если бы это был неграфический объект, с помощью его методов и свойств таким же образом, каким используются методы и свойства неграфического класса.
Второй файл
AxMSMAPI.dll
является элементом управления Windows. Он позволяет использовать графический аспект импортированного элемента управления ActiveX как элемент управления Windows в проектах Forms Windows .NET.
При использовании
AxImp
желательно убедиться, что для этих двух выходных файлов предоставляются явные и уникальные имена, так как, по крайней мере, в бета-версии SDK .NET
AxImp.exe
имеет потенциальную возможность перезаписывать входные файлы без предупреждения.
Ссылка на сборку прокси ActiveX
Как сказано выше, вывод сборки прокси утилитой AxImp.exe позволяет ссылаться на компонент ActiveX программным путем без использования графических аспектов. Для этого необходимо просто добавить ссылку на прокси сборки с помощью вкладки Reference в IDE VS.NET после того, как AxImp.exe сделает свою работу:
После создания ссылки на сборку прокси можно использовать в коде программы компонент ActiveX. В примере ниже используется прокси
MSMAPI32.осх
для отправки почтового сообщения:
public static int Main {
MAPISession objSession=new MAPISession;
MAPIMessages objMessage=new MAPIMessages;
objSession.Password="password";
objSession.UserName="me@mydomain.com";
objSession.SignOn;
objMessage.SessionID=objSession.SessionID;
objMessage.Compose;
objMessage.MsgSubject="MAPI Contol Test";
objMessage.MsgNoteText="The message body.";
objMessage.RecipAddress="you@yourdomain.com";
objMessage.ResolveName;
objMessage.Send(null);
objSession.SignOff;
return 0;
}
Размещение элемента управления ActiveX в WinForm
Также достаточно просто разместить элемент управления ActiveX в форме Windows. Чтобы сделать это, сначала запустим диалоговое окно Customize Toolbox из IDE VS.NET, щелкнув правой кнопкой мыши в панели инструментов IDE и выбрав соответствующий пункт в контекстном меню. Когда появится диалоговое окно, надо перейти на вкладку .NET Framework Components и найти созданный утилитой
AxImp.exe
файл элемента управления Windows. После закрытия диалогового окна Customize Toolbox импортированный элемент управления появится в панели управления IDE и можно будет добавить его в Windows Form
таким же образом, каким добавляются любые другие элементы управления Windows.
Использование компонентов .NET в COM
Также, как используются компоненты COM и элементы управления ActiveX в коде .NET, можно применять компоненты .NET в стандартном коде Windows. Только несколько свойств сборок .NET недоступны через COM, включая параметризованные конструкторы, статические методы и константные поля. Кроме того, доступ к перегруженным методам .NET из COM требует дополнительной работы.
RegAsm.exe
Применение компонентов COM в коде .NET требует другой утилиты, которая существует в SDK .NET, являющейся аналогом программы импорта библиотеки типов, которую мы видели ранее. Название этой утилиты —
RegAsm.exe
.
Название утилиты
RegAsm
(Register Assembly) обозначает ее функцию, она отвечает за ввод информации о типе компонента .NET в системный реестр, чтобы службы COM могли к нему обратиться. После регистрации компонента .NET с помощью RegAsm, стандартные клиенты Windows могут сделать позднее соединение с классами компонента. Процесс регистрации компонента должен быть сделан только один раз. После регистрации все клиенты COM могут к нему обращаться.
В качестве примера рассмотрим следующий код. Он принадлежит классу в библиотеке классов .NET. Функция получает просто число в качестве аргумента ввода и возвращает факториал этого числа:
namespace Factorial {
using System;
public class Factorial {
// Этот метод вычисляет факториал числа
public int ComputeFactorial(int n) {
int intFactorial=n;
for (int i = 1; i<n; i++) {
intFactorial*=i;
}
return intFactorial;
}
}
}
После компиляции класса примера в сборку .NET можно зарегистрировать эту сборку в службах COM с помощью
RegAsm.exe
:
Теперь, когда сборка зарегистрирована в службах COM с помощью
RegAsm
, можно выполнить позднее связывание со сборкой .NET через службы COM. С целью демонстрации создадим простой сценарий VB, который это делает. (Сценарий VB можно создать с помощью текстового редактора, такого как Notepad; введите просто следующий код и сохраните файл с расширением
.vbs
. Предполагая, что Windows Script Host установлен, файл при вызове будет выполняться как сценарий. Помните, что сценарий VB выполняет позднее связывание для компонентов COM.)
Option Explicit
Dim objFactorial
Dim lngResult
Dim lngInputValue
Set objFactorial=CreateObject("Factorial.Factorial")
Однако, прежде чем это можно будет использовать, необходимо установить сборку в глобальный кэш. Для этого сначала создадим устойчивое имя сборки с помощью следующей команды: