- Tiny Multimedia Framework (tmf) ===============================
Tiny Multimedia Framework is a simple multimedia framework to implement multimedia applications. A multimedia application consists of a pipeline and a series of filters connected to each other. An application developer need to know about filter types, and how to connect them to each other.
Each filter has a number of input and output ports. Each port has a buffer type and can be connected to other ports with the same type of data. Filters with same type of ports can be connected to each other. A port put the data on its buffer and all consumers are notified.
In section 5 we explain how a multimedia application developers create an application using the APIs of the framework. In section 6 we explain how plug-in developers create a new filter using APIs of the framework.
- Folder structure ===================
Here is how the project is organized.
build
core (core package)
doc
examples (contains examples using tmf library)
filters (implementation of the filters)
basic
libav
tools (tools to be used by libav filters)
types (data types to be used by libav filters)
CMakeLists.txt
LICENCE
README.md
tmf.doxyfile
tmf.kdev4
- Installation ===============
cd build
./build.sh
# or
./build-debug.sh # for debuging
Before compilation make sure that the following libraries are installed:
- libavformat-dev
- libavcodec-dev
- libavutil-dev
- libswscale-dev
- libsdl1.2-dev
- zlib1g-dev
-
Development envirement ====================== Tiny Multimedia Framework is configured to be developed under KDevelop IDE.
kdevelop -p tmf.kdev4
The build directory:
build-kdevelop
- User manual ===========
To create an application we need to create the pipeline as well as the filters, connect filters to each other and run the pipeline. TMF provides APIs to do it.
Here is a producer/consumer example with one producer and three consumer:
Pipeline* pipe = Factory::createPipeline("Three consumer/One producer");
Filter* producer = Factory::createFilter("string_producer", "producer");
Filter* consumer1 = Factory::createFilter("string_consumer", "consumer1");
Filter* consumer2 = Factory::createFilter("string_consumer", "consumer2");
Filter* consumer3 = Factory::createFilter("string_consumer", "consumer3");
producer->setProp("limit", 10);
pipe->addFilters(producer, consumer1, consumer2, consumer3, nullptr);
pipe->connectFilters(producer, consumer1);
pipe->connectFilters(producer, consumer2);
pipe->connectFilters(producer, consumer3);
pipe->init();
pipe->run();
Factory::destroyPipeline(pipe);
- Plugin developer manual =======================
Plug-in developers must implement new filters in filter folder. A filter inherits from the Filter class. Each filter must define a set of ports and their data type. The filter then implements init()
and run()
functions.
Here is an example of a filter implementation:
class StringConsumerFilter: public Filter {
private:
// The input port with a string buffer
InputPort<string> * input;
// In order to register the filter all filters need this member
static FilterRegister<StringConsumerFilter> reg;
public:
StringConsumerFilter(const string & name) : Filter(name) {
input = createInputPort<string>("input");
}
void run() {
input->lock();
string * inputData = input->get();
log("consuming "+*inputData);
sleep(500);
if (input->getStatus() == SampleStatus::EOS)
status = FilterStatus::EOS;
input->unlock();
}
~StringConsumerFilter() {
destroyPort(input);
}
};
FilterRegister<StringConsumerFilter> StringConsumerFilter::reg("string_consumer");
For more information, examples, and documentation please see doc
and examples
folder.