Поделиться через


Функция OleCreateLinkToFileEx (ole2.h)

Расширяет функциональные возможности OleCreateLinkToFile за счет поддержки более эффективного создания экземпляров объектов в контейнерах, требующих кэширования нескольких форматов презентаций или данных, а не одного формата, поддерживаемого OleCreateLinkToFile.

Синтаксис

HRESULT OleCreateLinkToFileEx(
  [in]  LPCOLESTR       lpszFileName,
  [in]  REFIID          riid,
  [in]  DWORD           dwFlags,
  [in]  DWORD           renderopt,
  [in]  ULONG           cFormats,
  [in]  DWORD           *rgAdvf,
  [in]  LPFORMATETC     rgFormatEtc,
  [in]  IAdviseSink     *lpAdviseSink,
  [out] DWORD           *rgdwConnection,
  [in]  LPOLECLIENTSITE pClientSite,
  [in]  LPSTORAGE       pStg,
  [out] LPVOID          *ppvObj
);

Параметры

[in] lpszFileName

Указатель на имя файла, на который создается ссылка.

[in] riid

Ссылка на идентификатор интерфейса возвращаемого объекта.

[in] dwFlags

Этот параметр может иметь значение 0 или OLECREATE_LEAVERUNNING (0x00000001).

[in] renderopt

Значение, взятое из перечисления OLERENDER .

[in] cFormats

Если параметр renderopt OLERENDER_FORMAT, указывает количество структур FORMATETC в массиве rgFormatEtc , которое должно быть по крайней мере одной. Во всех остальных случаях этот параметр должен быть равен нулю.

[in] rgAdvf

Если параметр renderopt OLERENDER_FORMAT, указывает на массив элементов DWORD , каждый из которых представляет собой сочетание значений из перечисления ADVF . Каждый элемент этого массива передается в качестве параметра advf в вызов метода IOleCache::Cache или IDataObject::D Advise в зависимости от того, имеет ли pAdviseSinkзначение NULL или отличное от NULL (см. ниже). Во всех остальных случаях этот параметр должен иметь значение NULL.

[in] rgFormatEtc

При OLERENDER_FORMAT renderopt указывает на массив структур FORMATETC . Если pAdviseSink имеет значение NULL, каждый элемент этого массива передается в качестве параметра pFormatEtc вызову IOleCache::Cache объекта. При этом данные и кэш презентаций, управляемые внутрипроцессным обработчиком объектов (обычно обработчик по умолчанию), заполняется данными представления или другими кэшируемыми данными. Если pAdviseSink не равно NULL, каждый элемент этого массива передается в качестве параметра pFormatEtc в вызов IDataObject::D Advise. Это позволяет вызывающей (как правило, контейнеру OLE) выполнять собственное кэширование или обработку данных, полученных от объекта .

[in] lpAdviseSink

Если параметр renderopt OLERENDER_FORMAT, может быть допустимым указателем IAdviseSink , указывающим пользовательское кэширование или обработку данных, или значением NULL, указывающим кэширование форматов данных по умолчанию.

[out] rgdwConnection

Расположение для возврата массива значений dwConnection , возвращаемых при регистрации интерфейса IAdviseSink для каждого консультативного подключения с помощью IDataObject::D Advise, или NULL , если возвращенные консультативные подключения не требуются. Этот параметр должен иметь значение NULL, если pAdviseSink имеет значение NULL.

[in] pClientSite

Указатель на основной интерфейс, через который объект будет запрашивать службы из своего контейнера. Этот параметр может иметь значение NULL. В этом случае вызывающий объект должен как можно скорее установить клиентский сайт с помощью IOleObject::SetClientSite.

[in] pStg

Указатель на хранилище, используемое для объекта , и все данные по умолчанию или установленное для него кэширование презентации.

[out] ppvObj

Адрес выходной переменной указателя, которая получает указатель интерфейса, запрошенный в riid. После успешного возврата *ppvObj содержит запрошенный указатель интерфейса на вновь созданный объект.

Возвращаемое значение

Эта функция возвращает S_OK об успешном выполнении. Ниже перечислены другие возможные значения.

Код возврата Описание
E_NOINTERFACE
Указанный идентификатор интерфейса недопустим.
E_INVALIDARG
Один или несколько параметров являются недопустимыми.

Комментарии

Следующий вызов OleCreateLinkToFile:

OleCreateLinkToFile(lpszFileName, riid, renderopt, pFormatEtc, pClientSite, pStg, ppvObj);

Эквивалентен следующему вызову OleCreateLinkToFileEx:

DWORD    advf = ADVF_PRIMEFIRST;
    OleCreateLinkToFileEx(lpszFileName, riid, renderopt, 1, &advf, pFormatEtc, NULL, NULL, pClientSite, pStg, ppvObj);

Существующие функции создания экземпляров (OleCreate, OleCreateFromFile, OleCreateFromData, OleCreateLink, OleCreateLinkToFile и OleCreateLinkFromData) создают только один кэш презентации или формата данных в расположении кэша по умолчанию (в потоках "\001OlePresXXX" переданного IStorage) во время создания экземпляра. Кроме того, эти кэши необходимо создавать, когда объект переходит в состояние выполнения. Поскольку большинству приложений требуется кэширование по крайней мере двух презентаций (экран и принтер) и может потребоваться кэширование данных в формате или расположении, отличном от обработчика, приложения обычно должны запускать и завершать работу сервера объектов несколько раз, чтобы создавать кэши данных во время создания объекта, т. е. вставлять объект, вставлять объект из файла и вставлять объект.

Расширенная версия этих функций создания решает эту проблему. OleCreateEx, OleCreateFromFileEx, OleCreateFromDataEx, OleCreateLinkEx, OleCreateLinkToFileEx и OleCreateLinkFromDataEx содержат следующие новые параметры: dwFlags для указания дополнительных параметров, cFormats для указания количества форматов кэширования, rgAdvf из перечисления ADVF , для указания флагов рекомендаций для каждого кэшируемого формата, pAdviseSink Чтобы указать, требуется ли кэширование представления (обработчик по умолчанию) или данных (не обработчик по умолчанию), rgdwConnection возвращает IDataObject::D Advise cookie и rgFormatEtc, массив форматов, а не один формат.

Контейнеры, требующие кэширования нескольких презентаций от их имени обработчиком объекта, могут просто вызывать эти функции и указывать количество форматов в cFormats, флаги ADVF для каждого формата в rgAdvf и набор форматов в rgFormatEtc. Эти контейнеры передают значение NULL для pAdviseSink.

Контейнеры, выполняющие собственное кэширование данных или презентаций, выполняют те же действия, но передают pAdviseSink, отличный от NULL. Они выполняют собственное кэширование или обработку объекта или данных во время IAdviseSink::OnDataChange. Как правило, такие контейнеры никогда не устанавливают консультативные подключения с ADVF_NODATA, хотя им это не мешает.

Эти новые функции предназначены для составных документов OLE. С помощью этих функций приложения могут избежать повторных шагов запуска и инициализации, необходимых текущим функциям. Они предназначены для приложений-контейнеров составных документов OLE, использующих кэширование данных и представления по умолчанию, а также для приложений, которые обеспечивают собственное кэширование и передачу данных из базовой поддержки IDataObject::D Advise .

Требования

Требование Значение
Минимальная версия клиента Windows 2000 Professional [только классические приложения]
Минимальная версия сервера Windows 2000 Server [только классические приложения]
Целевая платформа Windows
Header ole2.h
Библиотека Ole32.lib
DLL Ole32.dll

См. также раздел

ADVF

FORMATETC

IAdviseSink::OnDataChange

IDataObject::D Advise

IOleCache::Cache

IOleObject::SetClientSite

IStorage

OLERENDER

OleCreate

OleCreateLinkToFile