org.gstreamer.message.BufferingMessage Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gstreamer-java Show documentation
Show all versions of gstreamer-java Show documentation
Java binding for the Gstreamer framework
/*
* Copyright (C) 2008 Wayne Meissner
* Copyright (C) 2004 Wim Taymans
*
* This file is part of gstreamer-java.
*
* This code is free software: you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License version 3 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* version 3 for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with this work. If not, see .
*/
package org.gstreamer.message;
import org.gstreamer.GstObject;
import org.gstreamer.Message;
import org.gstreamer.lowlevel.GstMessageAPI;
import org.gstreamer.lowlevel.GstNative;
import com.sun.jna.Pointer;
/**
* This message can be posted by an element that
* needs to buffer data before it can continue processing. {@code percent} should be a
* value between 0 and 100. A value of 100 means that the buffering completed.
*
* When percent} is < 100 the application should PAUSE a PLAYING pipeline. When
* percent is 100, the application can set the pipeline (back) to PLAYING.
* The application must be prepared to receive BUFFERING messages in the
* PREROLLING state and may only set the pipeline to PLAYING after receiving a
* message with percent set to 100, which can happen after the pipeline
* completed prerolling.
*/
public class BufferingMessage extends Message {
private static interface API extends GstMessageAPI {
Pointer ptr_gst_message_new_buffering(GstObject src, int percent);
}
private static final API gst = GstNative.load(API.class);
/**
* Creates a new Buffering message.
* @param init internal initialization data.
*/
public BufferingMessage(Initializer init) {
super(init);
}
/**
* Creates a new Buffering message.
* @param src The object originating the message.
*/
public BufferingMessage(GstObject src, int percent) {
this(initializer(gst.ptr_gst_message_new_buffering(src, percent)));
}
/**
* Gets the buffering percentage.
*
* @return the percentage that is being buffered.
*/
public int getPercent() {
int[] percent = { 0 };
gst.gst_message_parse_buffering(this, percent);
return percent[0];
}
}