Microsoft DirectX 8.1 (C++) |
This class implements the IAMStreamControl interface for input and output pins. It provides control over starting and stopping an individual pin on the filter. A pin that supports IAMStreamControl should inherit from this base class. The following is a typical declaration for an input pin:
class CMyInputPin : public CBaseInputPin, public CBaseStreamControl
Be sure to override NonDelegatingQueryInteface to expose IAMStreamControl. For more information, see How to Implement IUnknown.
This class requires the pin and the owning filter to notify the class when various events occur, such as the filter joining the graph or receiving a new reference clock. You should call the following class methods:
The CBaseStreamControl class uses the filter graph's reference clock to determine which samples the filter should be deliver, and which it should discard. In your pin's IMemInputPin::Receive method, call the CBaseStreamControl::CheckStreamState method with a pointer to the incoming media sample. If the method returns the value STREAM_FLOWING, deliver the sample downstream. Otherwise, discard it.
Public Methods
Methods | Description |
CBaseStreamControl | Constructor method. |
~CBaseStreamControl | Destructor method. |
CheckStreamState | Determines whether a media sample should be delivered or discarded. |
Flushing | Notifies the base class that the pin has started or stopped flushing. |
NotifyFilterState | Notifies the pin when the filter’s state changes. |
SetFilterGraph | Specifies the event sink for stream control events. |
SetSyncSource | Notifies the base class of the current reference clock. |
IAMStreamControl Methods
Method | Description |
GetInfo | Retrieves information about the current stream-control settings, including the start and stop times. |
StartAt | Informs the pin when to start delivering data. |
StopAt | Informs the pin when to stop delivering data. |