glstereomix

glstereomix

Types and Values

Description

Combine 2 input streams to produce a stereoscopic output stream. Input views are taken from the left pad and right pad respectively, and mixed according to their timelines.

If either input stream is stereoscopic, the approproriate view (left or right) is taken from each stream and placed into the output.

The multiview representation on the output is chosen according to the downstream caps.

Examples

1
2
3
4
5
6
gst-launch-1.0 -v videotestsrc pattern=ball name=left \
    videotestsrc name=right glstereomix name=mix \
    left. ! vid/x-raw,width=640,height=480! glupload ! mix.  \
    right. ! video/x-raw,width=640,height=480! glupload ! mix.  \
    mix. ! video/x-raw'(memory:GLMemory)',multiview-mode=side-by-side ! \
    queue ! glimagesink output-multiview-mode=side-by-side

Mix 2 different videotestsrc patterns into a side-by-side stereo image and display it.

1
2
3
4
5
6
7
8
gst-launch-1.0 -ev v4l2src name=left \
    videotestsrc name=right \
    glstereomix name=mix \
    left. ! video/x-raw,width=640,height=480 ! glupload ! glcolorconvert ! mix.  \
    right. ! video/x-raw,width=640,height=480 ! glupload ! mix.  \
    mix. ! video/x-raw'(memory:GLMemory)',multiview-mode=top-bottom ! \
    glcolorconvert ! gldownload ! queue ! x264enc ! h264parse ! \
    mp4mux ! progressreport ! filesink location=output.mp4

Mix the input from a camera to the left view, and videotestsrc to the right view, and encode as a top-bottom frame packed H.264 video.

Functions

Types and Values

struct GstGLStereoMix

struct GstGLStereoMix {
  GstGLMixer mixer;

  GLuint out_tex_id;

  GstGLViewConvert *viewconvert;
  GstGLStereoDownmix downmix_mode;

  GstVideoInfo mix_info;

  GPtrArray *input_frames;
  GstBuffer *primary_out;
  GstBuffer *auxilliary_out;
};