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


Метод CTransformFilter.DecideBufferSize

[Функция, связанная с этой страницей DirectShow, является устаревшей функцией. Он был заменен MediaPlayer, IMFMediaEngine, и аудио/ видео захвата в Media Foundation. Эти функции оптимизированы для Windows 10 и Windows 11. Корпорация Майкрософт настоятельно рекомендует, чтобы новый код использовал MediaPlayer, IMFMediaEngine и аудио- и видеозахват в Media Foundation вместо DirectShow, когда это возможно. Корпорация Майкрософт предлагает переписать существующий код, использующий устаревшие API, чтобы по возможности использовать новые API.]

Метод DecideBufferSize задает требования к буферу выходного контакта.

Синтаксис

virtual HRESULT DecideBufferSize(
   IMemAllocator        *pAlloc,
   ALLOCATOR_PROPERTIES *ppropInputRequest
) = 0;

Параметры

pAlloc

Указатель на интерфейс IMemAllocator в распределителе выходного контакта.

ppropInputRequest

Указатель на структуру ALLOCATOR_PROPERTIES , содержащую требования к буферу из нижнего входного контакта.

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

Возвращает S_OK или другое значение HRESULT .

Комментарии

Метод CTransformOutputPin::D ecideBufferSize выходных контактов вызывает этот метод. Производный класс должен реализовывать этот метод. Дополнительные сведения см. в разделе CBaseOutputPin::D ecideBufferSize.

Требования

Требование Значение
Заголовок
Transfrm.h (включая Streams.h)
Библиотека
Strmbase.lib (розничные сборки);
Strmbasd.lib (отладочные сборки)

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

Класс CTransformFilter