/******************************************************************************* / / File: BufferConsumer.h / / Description: A BBufferConsumer is anything that wants to receive buffers in the Media Kit / / Copyright 1997-98, Be Incorporated, All Rights Reserved / *******************************************************************************/ #if !defined(_BUFFER_CONSUMER_H) #define _BUFFER_CONSUMER_H #include #include class BBuffer; class BBufferGroup; class BRegion; namespace BPrivate { namespace media { class BMediaRosterEx; }} class _buffer_id_cache; class BBufferConsumer : public virtual BMediaNode { protected: /* this has to be at the top to force a vtable */ virtual ~BBufferConsumer(); public: media_type ConsumerType(); /* for encoding a region into the format needed for clipping requests */ static status_t RegionToClipData( const BRegion * region, int32 * format, int32 * ioSize, void * data); protected: explicit BBufferConsumer( media_type consumer_type /* = B_MEDIA_UNKNOWN_TYPE */); static void NotifyLateProducer( const media_source & what_source, bigtime_t how_much, bigtime_t performance_time); status_t SetVideoClippingFor( const media_source & output, const media_destination & destination, const int16 * shorts, int32 short_count, const media_video_display_info & display, void * user_data, int32 * change_tag, void * _reserved_ = 0); // change_tag value will be passed to RequestCompleted() status_t SetOutputEnabled( const media_source & source, const media_destination & destination, bool enabled, void * user_data, int32 * change_tag, void * _reserved_ = 0); // change_tag value will be passed to RequestCompleted() status_t RequestFormatChange( const media_source & source, const media_destination & destination, const media_format & to_format, void * user_data, int32 * change_tag, void * _reserved_ = 0); // change_tag value will be passed to RequestCompleted() status_t RequestAdditionalBuffer( // new in 4.1 const media_source & source, BBuffer * prev_buffer, void * _reserved = NULL); status_t RequestAdditionalBuffer( // new in 4.1 const media_source & source, bigtime_t start_time, void * _reserved = NULL); status_t SetOutputBuffersFor( // new in 4.1 const media_source & source, const media_destination & destination, BBufferGroup * group, void * user_data, int32 * change_tag, // passed to RequestCompleted() bool will_reclaim = false, void * _reserved_ = 0); status_t SendLatencyChange( const media_source & source, const media_destination & destination, bigtime_t my_new_latency, uint32 flags = 0); protected: virtual status_t HandleMessage( int32 message, const void * data, size_t size); /* Someone, probably the producer, is asking you about this format. Give */ /* your honest opinion, possibly modifying *format. Do not ask upstream */ /* producer about the format, since he's synchronously waiting for your */ /* reply. */ virtual status_t AcceptFormat( const media_destination & dest, media_format * ioFormat) = 0; virtual status_t GetNextInput( int32 * cookie, media_input * out_input) = 0; virtual void DisposeInputCookie( int32 cookie) = 0; virtual void BufferReceived( BBuffer * buffer) = 0; virtual void ProducerDataStatus( const media_destination & for_whom, int32 status, bigtime_t at_performance_time) = 0; virtual status_t GetLatencyFor( const media_destination & for_whom, bigtime_t * out_latency, media_node_id * out_timesource) = 0; virtual status_t Connected( const media_source & producer, /* here's a good place to request buffer group usage */ const media_destination & where, const media_format & with_format, media_input * out_input) = 0; virtual void Disconnected( const media_source & producer, const media_destination & where) = 0; /* The notification comes from the upstream producer, so he's already cool with */ /* the format; you should not ask him about it in here. */ virtual status_t FormatChanged( const media_source & producer, const media_destination & consumer, int32 change_tag, const media_format & format) = 0; /* Given a performance time of some previous buffer, retrieve the remembered tag */ /* of the closest (previous or exact) performance time. Set *out_flags to 0; the */ /* idea being that flags can be added later, and the understood flags returned in */ /* *out_flags. */ virtual status_t SeekTagRequested( const media_destination & destination, bigtime_t in_target_time, uint32 in_flags, media_seek_tag * out_seek_tag, bigtime_t * out_tagged_time, uint32 * out_flags); private: BBufferConsumer(); /* private unimplemented */ BBufferConsumer( const BBufferConsumer & clone); BBufferConsumer & operator=( const BBufferConsumer & clone); // these functions are deprecated from the 4.0 API static status_t SetVideoClippingFor( const media_source & output, const int16 * shorts, int32 short_count, const media_video_display_info & display, int32 * change_tag); // change_tag value will be passed to RequestCompleted() static status_t RequestFormatChange( const media_source & source, const media_destination & destination, media_format * io_to_format, // the "o" part is unused from 4.1 int32 * change_tag); // change_tag value will be passed to RequestCompleted() static status_t SetOutputEnabled( const media_source & source, bool enabled, int32 * change_tag); // change_tag value will be passed to RequestCompleted() /* Mmmh, stuffing! */ status_t _Reserved_BufferConsumer_0(void *); /* SeekTagRequested */ virtual status_t _Reserved_BufferConsumer_1(void *); virtual status_t _Reserved_BufferConsumer_2(void *); virtual status_t _Reserved_BufferConsumer_3(void *); virtual status_t _Reserved_BufferConsumer_4(void *); virtual status_t _Reserved_BufferConsumer_5(void *); virtual status_t _Reserved_BufferConsumer_6(void *); virtual status_t _Reserved_BufferConsumer_7(void *); virtual status_t _Reserved_BufferConsumer_8(void *); virtual status_t _Reserved_BufferConsumer_9(void *); virtual status_t _Reserved_BufferConsumer_10(void *); virtual status_t _Reserved_BufferConsumer_11(void *); virtual status_t _Reserved_BufferConsumer_12(void *); virtual status_t _Reserved_BufferConsumer_13(void *); virtual status_t _Reserved_BufferConsumer_14(void *); virtual status_t _Reserved_BufferConsumer_15(void *); friend class BMediaNode; friend class BBufferProducer; friend class BMediaRoster; friend class BPrivate::media::BMediaRosterEx; media_type fConsumerType; _buffer_id_cache * fBufferCache; BBufferGroup *fDeleteBufferGroup; uint32 _reserved_buffer_consumer_[14]; }; #endif /* _BUFFER_CONSUMER_H */