
org.gstreamer.interfaces.XOverlayBase 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 (0.10 compatible)
The newest version!
/*
* Copyright (C) 2009 Levente Farkas
* Copyright (C) 2009 Tamas Korodi
* Copyright (C) 2008 Wayne Meissner
* Copyright (C) 2003 Ronald Bultje
*
* 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.interfaces;
import static org.gstreamer.lowlevel.GstXOverlayAPI.GSTXOVERLAY_API;
import org.gstreamer.Element;
import com.sun.jna.NativeLong;
/**
* Interface for elements providing tuner operations
*/
public class XOverlayBase extends GstInterface {
/**
* Wraps the {@link Element} in a XOverlay interface
*
* @param element the element to use as a XOverlay
* @return a XOverlay for the element
*/
public static XOverlayBase wrap(Element element) {
return new XOverlayBase(element);
}
/**
* Creates a new XOverlay instance
*
* @param element the element that implements the tuner interface
*/
protected XOverlayBase(Element element) {
super(element, GSTXOVERLAY_API.gst_x_overlay_get_type());
}
/**
* Sets the native window for the {@link Element} to use to display video.
*
* @param handle A native handle to use to display video.
*/
public void setWindowHandle(long handle) {
GSTXOVERLAY_API.gst_x_overlay_set_window_handle(this, new NativeLong(handle));
}
/**
* Sets the native window for the {@link Element} to use to display video.
*
* @param handle A native handle to use to display video.
* @deprecated use {@link #setWindowHandle(long)} instead
*/
@Deprecated
public void setWindowID(long handle) {
setWindowHandle(handle);
}
/**
* Tell an overlay that it has been exposed. This will redraw the current frame
* in the drawable even if the pipeline is PAUSED.
*/
public void expose() {
GSTXOVERLAY_API.gst_x_overlay_expose(this);
}
/**
* Tell an overlay that it should handle events from the window system.
* These events are forwared upstream as navigation events. In some window
* system, events are not propagated in the window hierarchy if a client is
* listening for them. This method allows you to disable events handling
* completely from the XOverlay.
*/
public void handleEvent(boolean handle_events) {
GSTXOVERLAY_API.gst_x_overlay_handle_events(this, handle_events);
}
/**
* Configure a subregion as a video target within the window set by
* {@link #setWindowHandle(long)}. If this is not used or not supported
* the video will fill the area of the window set as the overlay to 100%.
* By specifying the rectangle, the video can be overlayed to a specific
* region of that window only. After setting the new rectangle one should
* call {@link #expose()} to force a redraw. To unset the region pass -1
* for the width and height parameters.
*
* This method is needed for non fullscreen video overlay in UI toolkits
* that do not support subwindows.
*
* @param overlay
* @param x
* @param y
* @param width
* @param height
*/
public boolean setRenderRectangle(XOverlayBase overlay, int x, int y, int width, int height) {
return GSTXOVERLAY_API.gst_x_overlay_set_render_rectangle(this, x, y, width, height);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy