2016-11-11 15:39:33 +03:00
|
|
|
/*
|
2018-02-24 04:23:41 +03:00
|
|
|
* Copyright 2015-2018, Dario Casalinuovo. All rights reserved.
|
2016-11-11 15:39:33 +03:00
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _MEDIA_CONNECTION_H
|
|
|
|
#define _MEDIA_CONNECTION_H
|
|
|
|
|
|
|
|
#include <BufferGroup.h>
|
|
|
|
#include <MediaDefs.h>
|
|
|
|
|
2016-11-24 02:19:06 +03:00
|
|
|
#include <MediaClient.h>
|
|
|
|
#include <MediaClientDefs.h>
|
|
|
|
|
2016-11-11 15:39:33 +03:00
|
|
|
|
|
|
|
namespace BPrivate { namespace media {
|
|
|
|
|
2017-01-17 00:49:49 +03:00
|
|
|
class BMediaClientNode;
|
|
|
|
|
2016-11-11 15:39:33 +03:00
|
|
|
|
|
|
|
// The BMediaConnection class is the swiss knife of BMediaClient.
|
|
|
|
// It represents a connection between two nodes and allow to create complex
|
|
|
|
// nodes without dealing with the unneeded complexity. Two local connections,
|
|
|
|
// can be binded, this means that when you will receive a buffer A as input,
|
2016-12-06 18:47:16 +03:00
|
|
|
// the BufferReceived function will be called so that you can process the BBuffer,
|
2016-11-11 15:39:33 +03:00
|
|
|
// and once the function returns the output will be automatically forwarded
|
2016-12-06 18:47:16 +03:00
|
|
|
// to the connection B SendBuffer method.
|
2017-02-18 22:40:38 +03:00
|
|
|
// It's not possible to mix a BMediaInput with a BMediaOutput in the same class.
|
2016-11-11 15:39:33 +03:00
|
|
|
class BMediaConnection {
|
|
|
|
public:
|
2016-11-24 02:19:06 +03:00
|
|
|
const media_connection& Connection() const;
|
2016-12-06 23:05:15 +03:00
|
|
|
BMediaClient* Client() const;
|
|
|
|
|
2016-11-24 02:19:06 +03:00
|
|
|
media_connection_id Id() const;
|
|
|
|
const char* Name() const;
|
|
|
|
|
2016-11-11 15:39:33 +03:00
|
|
|
bool HasBinding() const;
|
|
|
|
BMediaConnection* Binding() const;
|
|
|
|
|
2016-12-17 21:07:23 +03:00
|
|
|
bool IsConnected() const;
|
|
|
|
|
2018-02-24 17:24:23 +03:00
|
|
|
// If the connection is connected get the other endpoint,
|
|
|
|
// return media_connection::null otherwise.
|
|
|
|
media_connection Endpoint();
|
|
|
|
|
2018-02-27 04:49:50 +03:00
|
|
|
// Represents the buffer size, implement it to return the buffer size
|
|
|
|
// you decided for this connection.
|
|
|
|
// TODO: Do we want this (and ChainSize) moved on the output side?
|
|
|
|
// Or perhaps provide an implementation based on the buffer group
|
|
|
|
// for the consumer?
|
|
|
|
// Problem is: the consumer has not easy access to the buffer group,
|
|
|
|
// so we way want to add a special messaging between clients after
|
|
|
|
// connection, so that inputs know the buffer size and chain size.
|
2018-02-26 01:37:07 +03:00
|
|
|
virtual size_t BufferSize() const = 0;
|
2018-02-27 04:49:50 +03:00
|
|
|
// Implement it to specify the size of your chain of buffers.
|
|
|
|
//virtual int32 ChainSize() const = 0;
|
2016-11-11 15:39:33 +03:00
|
|
|
|
2016-11-26 19:24:10 +03:00
|
|
|
// Disconnect this connection. When a connection is disconnected,
|
|
|
|
// it can be reused as brand new.
|
2016-11-11 15:39:33 +03:00
|
|
|
status_t Disconnect();
|
|
|
|
|
|
|
|
// Once you are done with this connection you release it, it automatically
|
|
|
|
// remove the object from the BMediaClient and free all used resources.
|
|
|
|
// This will make the connection to disappear completely, so if you
|
2016-11-26 19:24:10 +03:00
|
|
|
// want to preserve it for future connections just Disconnect() it.
|
2016-11-11 15:39:33 +03:00
|
|
|
status_t Release();
|
|
|
|
|
|
|
|
protected:
|
2016-12-06 23:05:15 +03:00
|
|
|
BMediaConnection(
|
2018-03-02 05:18:26 +03:00
|
|
|
media_connection_kinds kinds,
|
|
|
|
const char* name = NULL);
|
2017-01-18 21:34:07 +03:00
|
|
|
virtual ~BMediaConnection();
|
2016-11-11 15:39:33 +03:00
|
|
|
|
2018-02-27 04:43:34 +03:00
|
|
|
private:
|
2016-11-26 19:13:02 +03:00
|
|
|
// Those callbacks are shared between BMediaInput and BMediaOutput
|
|
|
|
virtual void Connected(const media_format& format);
|
|
|
|
virtual void Disconnected();
|
2016-11-11 15:39:33 +03:00
|
|
|
|
2017-01-17 03:59:24 +03:00
|
|
|
void _ConnectionRegistered(BMediaClient* owner,
|
2016-11-29 03:19:45 +03:00
|
|
|
media_connection_id id);
|
|
|
|
|
2017-01-17 03:59:24 +03:00
|
|
|
const media_source& _Source() const;
|
|
|
|
const media_destination& _Destination() const;
|
2016-11-11 15:39:33 +03:00
|
|
|
|
2016-11-24 02:19:06 +03:00
|
|
|
media_connection fConnection;
|
2016-11-11 15:39:33 +03:00
|
|
|
|
|
|
|
BMediaClient* fOwner;
|
|
|
|
|
|
|
|
// A connection might be binded so that it will automatically
|
|
|
|
// forward or receive the data from/to a local BMediaConnection,
|
|
|
|
// see BMediaClient::Bind.
|
|
|
|
BMediaConnection* fBind;
|
|
|
|
|
2016-11-24 02:19:06 +03:00
|
|
|
bool fConnected;
|
|
|
|
|
2016-11-11 15:39:33 +03:00
|
|
|
virtual void _ReservedMediaConnection0();
|
|
|
|
virtual void _ReservedMediaConnection1();
|
|
|
|
virtual void _ReservedMediaConnection2();
|
|
|
|
virtual void _ReservedMediaConnection3();
|
|
|
|
virtual void _ReservedMediaConnection4();
|
|
|
|
virtual void _ReservedMediaConnection5();
|
|
|
|
virtual void _ReservedMediaConnection6();
|
|
|
|
virtual void _ReservedMediaConnection7();
|
|
|
|
virtual void _ReservedMediaConnection8();
|
|
|
|
virtual void _ReservedMediaConnection9();
|
|
|
|
virtual void _ReservedMediaConnection10();
|
|
|
|
uint32 fPadding[64];
|
|
|
|
|
|
|
|
friend class BMediaClient;
|
|
|
|
friend class BMediaClientNode;
|
2016-11-26 19:13:02 +03:00
|
|
|
|
|
|
|
friend class BMediaInput;
|
|
|
|
friend class BMediaOutput;
|
2016-11-11 15:39:33 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2016-12-11 21:13:46 +03:00
|
|
|
class BMediaInput : public virtual BMediaConnection {
|
2016-11-26 19:13:02 +03:00
|
|
|
protected:
|
2018-03-02 05:18:26 +03:00
|
|
|
BMediaInput(const char* name = NULL);
|
2017-01-18 21:34:07 +03:00
|
|
|
virtual ~BMediaInput();
|
|
|
|
|
2016-11-26 19:13:02 +03:00
|
|
|
// Callbacks
|
2018-03-01 19:05:10 +03:00
|
|
|
virtual status_t AcceptFormat(media_format* format) = 0;
|
|
|
|
|
2017-02-18 22:40:38 +03:00
|
|
|
virtual void HandleBuffer(BBuffer* buffer);
|
2016-11-26 19:13:02 +03:00
|
|
|
|
2018-02-27 04:43:34 +03:00
|
|
|
virtual void Connected(const media_format& format);
|
|
|
|
virtual void Disconnected();
|
|
|
|
|
2016-11-25 19:29:17 +03:00
|
|
|
private:
|
|
|
|
|
2016-11-26 19:30:49 +03:00
|
|
|
virtual void _ReservedMediaInput0();
|
|
|
|
virtual void _ReservedMediaInput1();
|
|
|
|
virtual void _ReservedMediaInput2();
|
|
|
|
virtual void _ReservedMediaInput3();
|
|
|
|
virtual void _ReservedMediaInput4();
|
|
|
|
virtual void _ReservedMediaInput5();
|
|
|
|
virtual void _ReservedMediaInput6();
|
|
|
|
virtual void _ReservedMediaInput7();
|
|
|
|
virtual void _ReservedMediaInput8();
|
|
|
|
virtual void _ReservedMediaInput9();
|
|
|
|
virtual void _ReservedMediaInput10();
|
|
|
|
uint32 fPadding[32];
|
|
|
|
|
2016-11-25 19:29:17 +03:00
|
|
|
friend class BMediaClientNode;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2016-12-11 21:13:46 +03:00
|
|
|
class BMediaOutput : public virtual BMediaConnection {
|
2016-11-26 19:13:02 +03:00
|
|
|
protected:
|
2018-03-02 05:18:26 +03:00
|
|
|
BMediaOutput(const char* name = NULL);
|
2017-01-18 21:34:07 +03:00
|
|
|
virtual ~BMediaOutput();
|
|
|
|
|
2016-11-26 19:13:02 +03:00
|
|
|
// Callbacks
|
2018-03-01 19:05:10 +03:00
|
|
|
virtual status_t PrepareToConnect(media_format* format) = 0;
|
|
|
|
virtual status_t FormatProposal(media_format* format) = 0;
|
2018-02-26 01:40:35 +03:00
|
|
|
|
2016-12-06 18:47:16 +03:00
|
|
|
// When a connection is not binded with another, and you really don't want
|
|
|
|
// to use BMediaGraph it's your job to send the buffer to the connection
|
|
|
|
// you want. You might want to ovverride it so that you can track something,
|
|
|
|
// in this case be sure to call the base version. Be sure to know what
|
|
|
|
// you are doing.
|
2016-11-26 19:13:02 +03:00
|
|
|
virtual status_t SendBuffer(BBuffer* buffer);
|
|
|
|
|
2018-02-27 04:43:34 +03:00
|
|
|
virtual void Connected(const media_format& format);
|
2018-02-27 03:29:20 +03:00
|
|
|
virtual void Disconnected();
|
|
|
|
|
2016-11-25 19:29:17 +03:00
|
|
|
private:
|
|
|
|
|
2018-02-24 18:13:34 +03:00
|
|
|
// TODO: possibly unneeded.
|
|
|
|
void _SetEnabled(bool enabled);
|
|
|
|
bool _IsEnabled() const;
|
|
|
|
|
2016-12-17 20:59:23 +03:00
|
|
|
bool fEnabled;
|
2017-01-15 16:43:33 +03:00
|
|
|
size_t fFramesSent;
|
2016-11-26 19:13:02 +03:00
|
|
|
|
2018-02-27 03:29:20 +03:00
|
|
|
BBufferGroup* fBufferGroup;
|
|
|
|
|
2016-11-26 19:30:49 +03:00
|
|
|
virtual void _ReservedMediaOutput0();
|
|
|
|
virtual void _ReservedMediaOutput1();
|
|
|
|
virtual void _ReservedMediaOutput2();
|
|
|
|
virtual void _ReservedMediaOutput3();
|
|
|
|
virtual void _ReservedMediaOutput4();
|
|
|
|
virtual void _ReservedMediaOutput5();
|
|
|
|
virtual void _ReservedMediaOutput6();
|
|
|
|
virtual void _ReservedMediaOutput7();
|
|
|
|
virtual void _ReservedMediaOutput8();
|
|
|
|
virtual void _ReservedMediaOutput9();
|
|
|
|
virtual void _ReservedMediaOutput10();
|
|
|
|
uint32 fPadding[32];
|
|
|
|
|
2016-11-25 19:29:17 +03:00
|
|
|
friend class BMediaClientNode;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2016-11-11 15:39:33 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
using namespace BPrivate::media;
|
|
|
|
|
|
|
|
#endif
|