IDiaEnumFrameData
Provede výčet různých prvků dat rámce obsažených ve zdroji dat.
IDiaEnumFrameData : IUnknown
Metody v pořadí virtuální tabulka
Následující tabulka obsahuje metody IDiaEnumFrameData.
Metoda |
Description |
---|---|
Načte IEnumVARIANT Interface verzi tohoto čítače výčtu. |
|
Vyhledá číslo rámce datové prvky. |
|
Načítá datový prvek rámeček z indexu. |
|
Načte zadaný počet prvků dat rámce v posloupnosti výčtu. |
|
Přeskočí zadaný počet prvků dat rámce v posloupnosti výčtu. |
|
Obnoví počáteční sekvenci výčtu. |
|
Vytvoří čítače výčtu, který obsahuje stejného státu jako aktuální čítač výčtu. |
|
Rámeček vrátí relativní virtuální adresu (RVA). |
|
Vrátí rámečku virtuální adresu (VA). |
Poznámky
Poznámky pro volající
Získání rozhraní z IDiaSession::getEnumTables metoda.Viz příklad podrobnosti.
Příklad
Tento příklad ukazuje, jak získat ( GetEnumFrameData funkce) a ( ShowFrameData funkci) IDiaEnumFrameData rozhraní.Najdete IDiaFrameData rozhraní pro příklad PrintFrameData funkce.
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();
}
}
Požadavky
Záhlaví: Dia2.h
Knihovny: diaguids.lib
Knihovna DLL: msdia80.dll