Средства разработки приложений


Перехват событий Excel - часть 2


void WorkbookBeforeClose(object Wb, ref bool Cancel);

DispId(0x623)]
void WorkbookBeforeSave(object Wb, bool SaveAsUI, ref bool Cancel);

DispId(0x624)]
void WorkbookBeforePrint(object Wb, ref bool Cancel);

DispId(0x625)]
void WorkbookNewSheet(object Wb, object Sh);

DispId(0x626)]
void WorkbookAddinInstall(object Wb);

DispId(0x627)]
void WorkbookAddinUninstall(object Wb);

DispId(0x612)]
void WindowResize(object Wb, object Wn);

DispId(0x614)]
void WindowActivate(object Wb, object Wn);

DispId(0x615)]
void WindowDeactivate(object Wb, object Wn);

DispId(0x73e)]
void SheetFollowHyperlink(object Sh, object Target);

DispId(0x86d)]
void SheetPivotTableUpdate(object Sh, object Target);

DispId(2160)]
void WorkbookPivotTableCloseConnection(object Wb, object Target);

DispId(0x871)]
void WorkbookPivotTableOpenConnection(object Wb, object Target); }

Таким образом наш класс - приемник событий должен реализовывать этот интерфейс и регистрировать себя используя IConnectionPointContainer и IConnectionPoint. Библиотека базовых классов .NET уже определяет managed-версии интерфейсов: для IConnectionPointContainer это UCOMIConnectionPointContainer, а для IConnectionPoint - UCOMIConnectionPoint, которые определены в пространстве имен - System.Runtime.InteropServices.

Регистрация класса-приемника событий будет выглядеть так:

// Объявляем ссылки на IConnectionPointContainer UCOMIConnectionPointContainer icpc;
// и на IConnectionPoint
UCOMIConnectionPoint icp;

// Получаем ссылку на Excel
FExcel = Marshal.GetActiveObject("Excel.Application");

// Получаем ссылку на интерфейс IConnectionPointContainer
icpc = FExcel as UCOMIConnectionPointContainer;

// Получаем «точку подключения»
Guid guid = new Guid("00024413-0000-0000-C000-000000000046");
icpc.FindConnectionPoint(ref guid, out icp);

// Регистрируем класс - приемник событий, который реализует
// интерфейс с GUID ["00024413-0000-0000-C000-000000000046"]
// При этом наш класс получает уникальный идентификатор
// cookie, который нужно сохранить, чтобы иметь
// возможность отключиться от источника событий
icp.Advise(ExcelEventSink, out cookie);

Для отключения от событий достаточно вызвать метод Unadvise(), и передать ему в качестве параметра идентификатор cookie, который мы получили при регистрации нашего класса-приемника событий методом Advise:

icp.Unadvise(cookie);


Начало  Назад  Вперед