Notitie
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen u aan te melden of de directory te wijzigen.
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen de mappen te wijzigen.
[De functie die is gekoppeld aan deze pagina, Windows Media Format 11 SDK, is een verouderde functie. Het is vervangen door Source Reader en Sink Writer. Bronlezer en Sink Writer zijn geoptimaliseerd voor Windows 10 en Windows 11. Microsoft raadt ten zeerste aan om nieuwe code te gebruiken bronlezer en Sink Writer- in plaats van Windows Media Format 11 SDK, indien mogelijk. Microsoft stelt voor dat bestaande code die gebruikmaakt van de verouderde API's, indien mogelijk opnieuw worden geschreven om de nieuwe API's te gebruiken.]
Meerdere bitsnelheden (MBR) wederzijdse uitsluiting is handig wanneer u inhoud voor verschillende afspeelscenario's wilt coderen. Een MBR-video-uitvoer bestaat uit één invoer die meerdere keren is gecodeerd, elk met verschillende bitsnelheidsinstellingen. Wanneer een bestand met MBR-codering wordt gelezen, bepaalt de lezer welke stream moet worden gebruikt op basis van de beschikbare bandbreedte.
De Windows Media Format SDK ondersteunt MBR-codering voor zowel video- als audiostreams. Daarnaast kunt u een speciaal type MBR-codering maken met de naam MBR-codering met meerdere videogrootten. MBR-video met meerdere videomaten functioneert identiek aan normale MBR-video, behalve dat u verschillende afbeeldingsgroottes kunt opgeven voor de videostreams in de mutuele uitsluiting.
In het volgende voorbeeld ziet u hoe u een profiel instelt voor MBR-video met meerdere videogrootten. Er wordt een nieuw profiel gemaakt met drie videostreams met verschillende bitsnelheden en grootten en bevat ze in een wederzijds uitsluitingsobject.
IWMProfileManager* pProfileMgr = NULL;
IWMProfile* pProfile = NULL;
IWMMutualExclusion* pMutex = NULL;
IWMStreamConfig* pStream = NULL;
IWMMediaProps* pMediaProps = NULL;
WM_MEDIA_TYPE* pMediaType = NULL;
DWORD cbMediaType = 0;
HRESULT hr = S_OK;
// Initialize COM.
hr = CoInitialize(NULL);
// Create a profile manager object.
hr = WMCreateProfileManager(&pProfileMgr);
// Create an empty profile.
hr = pProfileMgr->CreateEmptyProfile(WMT_VER_9_0, &pProfile);
// Give the new profile a name and description.
hr = pProfile->SetName(L"MBR_Video_3_Stream_test");
hr = pProfile->SetDescription(L"Only for use with example code.");
// Create the first stream.
hr = pProfile->CreateNewStream(WMMEDIATYPE_Video, &pStream);
// Get the media properties interface for the new stream.
hr = pStream->QueryInterface(IID_IWMMediaProps, (void**)&pMediaProps);
// Get the media-type structure.
// First, get the size of the media-type structure.
hr = pMediaProps->GetMediaType(NULL, &cbMediaType);
// Allocate memory for the structure based on the retrieved size.
pMediaType = (WM_MEDIA_TYPE*) new BYTE[cbMediaType];
// Retrieve the media-type structure.
hr = pMediaProps->GetMediaType(pMediaType, &cbMediaType);
// Change the video size to 640 x 480.
pMediaType->pbFormat->bmiHeader.biWidth = 640;
pMediaType->pbFormat->bmiHeader.biHeight = 480;
// Replace the WM_MEDIA_TYPE in the profile with the one just changed.
hr = pMediaProps->SetMediaType(pMediaType);
// Release the media properties interface and delete the structure.
pMediaProps->Release();
pMediaProps = NULL;
delete[] pMediaType;
pMediaType = NULL;
// Set the bit rate to 200.
hr = pStream->SetBitrate(200000);
// Set the stream number.
hr = pStream->SetStreamNumber(1);
// Include the new stream in the profile.
hr = pProfile->AddStream(pStream);
// Release the stream configuration interface.
pStream->Release();
pStream = NULL;
// For the remaining two streams, leave the video at its default size of
// 320 x 240 <entity type="ndash"/>- just change the bit rates.
// Repeat for a 100K stream.
hr = pProfile->CreateNewStream(WMMEDIATYPE_Video, &pStream);
hr = pStream->SetBitrate(100000);
hr = pStream->SetStreamNumber(2);
hr = pProfile->AddStream(pStream);
pStream->Release();
pStream = NULL;
// Repeat for a 56K stream.
hr = pProfile->CreateNewStream(WMMEDIATYPE_Video, &pStream);
hr = pStream->SetBitrate(56000);
hr = pStream->SetStreamNumber(3);
hr = pProfile->AddStream(pStream);
pStream->Release();
pStream = NULL;
// Now that we have three streams, create a mutual exclusion object.
hr = pProfile->CreateNewMutualExclusion(&pMutex);
// Add the three streams to the mutual exclusion.
hr = pMutex->AddStream(1);
hr = pMutex->AddStream(2);
hr = pMutex->AddStream(3);
// Configure the mutual exclusion for MBR video.
hr = pMutex->SetType(CLSID_WMMUTEX_Bitrate);
// Add the mutual exclusion to the profile.
hr = pProfile->AddMutualExclusion(pMutex);
// Release the mutual exclusion object.
pMutex->Release();
pMutex = NULL;
// TODO: Save the profile to a string, and save the string to a file.
// For more information, see To Save a Custom Profile.
// Release remaining interfaces.
pProfile->Release();
pProfile = NULL;
pProfileMgr->Release();
pProfileMgr = NULL;
Verwante onderwerpen