View Source Turbojpeg (turbojpeg v0.4.0)
TurboJPEG
Fast JPEG encoding from raw YUV data using libjpeg-turbo
Installation
This library requires libjpeg-turbo to be installed
Arch linux
sudo pacman -S libjpeg-turbo
Ubuntu/Debian
sudo apt-get install libturbojpeg libturbojpeg0-dev
OSX
brew install libjpeg-turbo
Develement Dependencies
Arch linux
sudo pacman -S imagemagick
Ubuntu/Debian
sudo apt-get install imagemagick
OSX
brew install imagemagick
If available in Hex, the package can be installed
by adding turbojpeg
to your list of dependencies in mix.exs
:
def deps do
[
{:turbojpeg, "~> 0.4"}
]
end
Basic Usage
iex(1)> frame = File.read!("fixture/i420.yuv")
<<0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 2, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...>>
iex(2)> {:ok, jpeg} = Turbojpeg.yuv_to_jpeg(frame, 1920, 1080, 90, :I420)
{:ok, <<255, 216, 255, 224, 0, 16, 74, 70, 73, 70, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 255,
219, 0, 67, 0, 3, 2, 2, 3, 2, 2, 3, 3, 3, 3, 4, 3, 3, 4, 5, 8, 5, 5, 4, 4, 5,
10, 7, 7, 6, ...>>}
iex(3)> File.write!("test.jpg", jpeg)
:ok
Membrane Sink Usage
In this example we'll read an H264 encoded frame and save it as a JPEG image
defmodule Your.Module.Pipeline do
use Membrane.Pipeline
alias Membrane.{File, H264}
@impl true
def handle_init(_ctx, _opts) do
children = [
child(:source, %File.Source{location: "input.h264"})
|> child(:parser, H264.Parser)
|> child(:decoder, H264.FFmpeg.Decoder)
|> child(:sink, %Turbojpeg.Sink{filename: "/tmp/frame.jpeg", quality: 100})
]
{[spec: spec], %{}}
end
@impl true
def handle_element_end_of_stream(:sink, _ctx, state) do
{[terminate: :normal], state}
end
end
Copyright and License
Copyright 2023, Binary Noggin
Summary
Types
@type dimension() :: pos_integer()
@type format() :: :I420 | :I422 | :I444 | :GRAY
@type height() :: dimension()
@type quality() :: 0..100
@type width() :: dimension()
Functions
@spec get_jpeg_header(binary()) :: {:ok, Turbojpeg.JpegHeader.t()} | error()
Gets the header from a jpeg binary
Examples
iex> {:ok, header} = Turbojpeg.get_jpeg_header(jpeg)
{:ok,
%Turbojpeg.JpegHeader{
format: :I422,
width: 192,
height: 192
}
}
iex> Turbojpeg.get_jpeg_header(<<45, 48, 44, 41, 11>>)
{:error, "Not a JPEG file: starts with 0x2d 0x30"}
Converts jpeg to yuv
iex> {:ok, yuv} = Turbojpeg.jpeg_to_yuv(jpeg)
{:ok,<<..>>}
Converts yuv to jpeg images
iex> {:ok, jpeg} = Turbojpeg.yuv_to_jpeg(frame, 1920, 1080, 90, :I420)
{:ok, <<....>>}