Skip to content

Simple C++ (with python wrapper) h264 stream decoder

License

Notifications You must be signed in to change notification settings

thirumalaim/h264_decoder

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Simple H264 Decoder

This is a simple C++ h264 stream decoder. It is quite fast and more importantly, does not require any other libs to compile/use. The idea is to be easy to use and import to your project, without all the problems of seting up a larger lib like ffstream, gstreamer or libvlc. You just need to compile, add the Decoder.h header (which contains all the interface that you need) and link the libmeerkat_h264_decoder lib.

The idea came from a project that imported the h264 decoder to JavaScript called Broadway, which is quite amazing. They used the decoder code from the Android project, but they did an abstraction layer on top (you'll see on all the functions calls that start with broadway). We've used this abstraction layer to make things even easier, but with some small changes for our purpose.

We also added a python wrapper for this lib, which is quite easy to use and (not so much to) compile. However you'll need OpenCV 3.1, Boost and Python 3. We used some code of pyboostcvconverter and numpy-opencv-converter, but also had to do some manual changes to fix some memory leak problems when using it with OpenCV 3.0.

Hope you like it :)

Meerkat team

Warnings

This was done on a real tight deadline, so it is quite possible that you find some problems/limitations when using this code. We encourage you to open a new Issue relating your problems, so that everyone will be aware of. And better yet, you may do a pull request.

If you submit a pull request, please try to follow the code style of each particular file. There are code in here that originated from several repositories/authors, but we don't think it is a good idea to mix different coding styles in the same file.

Compilation

To compile the main lib:

$ mkdir build
$ cd build
$ cmake ..
$ make

To compile the test program (it needs OpenCV to generate a RGB image and plot on the screen):

$ cd test
$ mkdir build
$ cd build
$ cmake ..
$ make

Usage example:

$ ./h264_test ../../data/video_full.avi

About

Simple C++ (with python wrapper) h264 stream decoder

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 88.2%
  • C++ 11.2%
  • Other 0.6%