The Android OpenCORE multimedia framework stripped down to just the H.264 decoder to make it easier to integrate.
C++ C Objective-C Prolog
Latest commit 8c52e59 Jan 12, 2013 @fhunleth Merge pull request #1 from njoubert/master
Allowing the hollowcore h264 decoder to build on 64bit mac osx
Permalink
Failed to load latest commit information.
avc_h264
include/hollowcore-h264
oscl
.gitignore
ChangeLog
NOTICE
README.md
hollowcore-h264.pro

README.md

HollowCore H.264 decoder

This is a completely stripped down version of the Android OpenCORE multimedia framework so that only the software H.264 decoder remains. It is an attempt to make it easier to integrate an H.264 decoder with a C/C++ application. To that end, all externally needed header files are in the /include directory and the code produces one small shared library.

Currently, the project builds using qmake. To build, run:

qmake hollowcore.pro make

Usage

See include/avc_h264/avcdec_api.h for the main calls to the decoder. The general flow in your application is the following:

  1. Read data from a file or stream
  2. Parse that data into NAL units using PVAVCAnnexBGetNALUnit() or other mechanism
  3. Check the NAL type and call PVAVCDecodeSlice for slices and IDR, PVAVCDecSeqParamSet for SPS, and PVAVCDecPicParamSet for PPS NALs
  4. Call PVAVCDecGetOutput to get the decoded frames out

Limitations

The decoder has the same limitations as the original Android OpenCore decoder. The one that most often affects me is the lack of support for CABAC entropy encoding. SEI metadata support is also minimal.