IDiaEnumFrameData
Перечисляет различные элементы данных кадра, содержащихся в источнике данных.
IDiaEnumFrameData : IUnknown
Методы в том порядке Vtable
В следующей таблице показаны методы IDiaEnumFrameData.
Метод |
Описание |
---|---|
Извлекает IEnumVARIANT Interface версия данного перечислителя. |
|
Извлекает число элементов данных кадра. |
|
Получает элемент данных кадра посредством индекса. |
|
Получает заданное число элементов данных кадра в последовательности перечисления. |
|
Пропустить заданное число элементов данных кадра в последовательности перечисления. |
|
Сбросить последовательность перечисления в начало. |
|
Создает перечислитель с тем же состоянием перечисления, что и текущий перечислитель. |
|
Возвращает кадр является относительным виртуальным адресом (RVA). |
|
Возвращает кадр является виртуальным адресом (VA). |
Заметки
Замечания для вызывающих объектов
Для получения этого интерфейса из IDiaSession::getEnumTables метод. См. пример.
Пример
В этом примере показано, как получить ( GetEnumFrameData (функция) и использует ShowFrameData функция) IDiaEnumFrameData интерфейс. См. IDiaFrameData интерфейс пример PrintFrameData функция.
IDiaEnumFrameData* GetEnumFrameData(IDiaSession *pSession)
{
IDiaEnumFrameData* pUnknown = NULL;
REFIID iid = __uuidof(IDiaEnumFrameData);
IDiaEnumTables* pEnumTables = NULL;
IDiaTable* pTable = NULL;
ULONG celt = 0;
if (pSession->getEnumTables(&pEnumTables) != S_OK)
{
wprintf(L"ERROR - GetTable() getEnumTables\n");
return NULL;
}
while (pEnumTables->Next(1, &pTable, &celt) == S_OK && celt == 1)
{
// There is only one table that matches the given iid
HRESULT hr = pTable->QueryInterface(iid, (void**)&pUnknown);
pTable->Release();
if (hr == S_OK)
{
break;
}
}
pEnumTables->Release();
return pUnknown;
}
void ShowFrameData(IDiaSession *pSession)
{
IDiaEnumFrameData* pEnumFrameData = GetEnumFrameData(pSession);;
if (pEnumFrameData != NULL)
{
IDiaFrameData* pFrameData;
ULONG celt = 0;
while(pEnumFrameData->Next(1, &pFrameData, &celt) == S_OK &&
celt == 1)
{
PrintFrameData(pFrameData);
pFrameData->Release();
}
pEnumFrameData->Release();
}
}
Требования
заголовок: Dia2.h
Библиотеки: diaguids.lib
Библиотеки DLL: msdia80.dll