|
Copyright 2002-2003 Sun Microsystems, Inc.; Nokia Corporation. See the Copyright Notice and Specification License for more details. |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
VideoControl
controls the display of video.
A Player
which supports the playback of video
must provide a VideoControl
via its
getControl
and getControls
method.
Field Summary | |
static int |
USE_DIRECT_VIDEO
This defines a mode on how the video is displayed. |
Fields inherited from interface javax.microedition.media.control.GUIControl |
USE_GUI_PRIMITIVE |
Method Summary | |
int |
getDisplayHeight()
Return the actual height of the current render video. |
int |
getDisplayWidth()
Return the actual width of the current render video. |
int |
getDisplayX()
Return the X-coordinate of the video with respect to the GUI object where the video is displayed. |
int |
getDisplayY()
Return the Y-coordinate of the video with respective to the GUI object where the video is displayed. |
byte[] |
getSnapshot(java.lang.String imageType)
Get a snapshot of the displayed content. |
int |
getSourceHeight()
Return the height of the source video. |
int |
getSourceWidth()
Return the width of the source video. |
java.lang.Object |
initDisplayMode(int mode,
java.lang.Object arg)
Initialize the mode on how the video is displayed. |
void |
setDisplayFullScreen(boolean fullScreenMode)
Set the size of the render region for the video clip to be fullscreen. |
void |
setDisplayLocation(int x,
int y)
Set the location of the video with respect to the canvas where the video is displayed. |
void |
setDisplaySize(int width,
int height)
Resize the video image. |
void |
setVisible(boolean visible)
Show or hide the video. |
Field Detail |
public static final int USE_DIRECT_VIDEO
initDisplayMode
.
USE_DIRECT_VIDEO
mode can only be used
on platforms with LCDUI support.
When USE_DIRECT_VIDEO
is specified for
initDisplayMode
, the arg
argument must not be null and must be a
javax.microedition.lcdui.Canvas
or a subclass of it.
In this mode, the video is directly
rendered onto the canvas. The region where the video
is rendered can be set by the setDisplayLocation
method. By default, the location is (0, 0).
Drawing any graphics or rendering other video at the same
region on the canvas may not be supported.
initDisplayMode
returns null
in this mode.
Here is one sample usage scenario:
javax.microedition.lcdui.Canvas canvas;
// canvas must be created before being used in the following code.
try {
Player p = Manager.createPlayer("http://mymachine/abc.mpg");
p.realize();
VideoControl vc;
if ((vc = (VideoControl)p.getControl("VideoControl")) != null) {
vc.initDisplayMode(VideoControl.USE_DIRECT_VIDEO, canvas);
vc.setVisible(true);
}
p.start();
} catch (MediaException pe) {
} catch (IOException ioe) {
}
Value 1 is assigned to USE_DIRECT_VIDEO
.
Method Detail |
public java.lang.Object initDisplayMode(int mode, java.lang.Object arg)
Two modes are defined:
USE_GUI_PRIMITIVE
(inherited from GUIControl)
USE_DIRECT_VIDEO
initDisplayMode
in interface GUIControl
mode
- The video mode that determines how video is
displayed. It can be USE_GUI_PRIMITIVE
,
USE_DIRECT_VIDEO
or an implementation-
specific mode.arg
- The exact semantics of this argument is
specified in the respective mode definitions.
java.lang.IllegalStateException
- Thrown if
initDisplayMode
is called again after it has
previously been called successfully.
java.lang.IllegalArgumentException
- Thrown if
the mode
or arg
argument is invalid. mode
must be
USE_GUI_PRIMITIVE
,
USE_DIRECT_VIDEO
, or a custom mode
supported by this implementation.
arg
must conform to the
conditions defined by the
respective mode definitions.
Refer to the mode definitions for the required type
of arg
.public void setDisplayLocation(int x, int y)
This method only works when the USE_DIRECT_VIDEO
mode is set. In USE_GUI_PRIMITIVE
mode,
this call will be ignored.
The location is specified in pixel values relative to the upper left hand corner of the GUI object.
By default, video appears at location (0,0).
The location can be given in negative values or can be greater than the actual size of the canvas. When that happens, the video should be clipped to the boundaries of the canvas.
x
- The x coordinate (in pixels) of the video location.y
- The y coordinate (in pixels) of the video location.
java.lang.IllegalStateException
- Thrown if
initDisplayMode
has not been called.public int getDisplayX()
The return value is undefined if initDisplayMode
has not been called.
public int getDisplayY()
The return value is undefined if initDisplayMode
has not been called.
public void setVisible(boolean visible)
If USE_GUI_PRIMITIVE
is set, the video by
default is shown when the GUI primitive is displayed.
If USE_DIRECT_VIDEO
is set, the video by
default is not shown when the canvas is displayed
until setVisible(true)
is called. If
the canvas is removed from the screen, the video
will not be displayed.
visible
- Show the video if true, hide it otherwise.
java.lang.IllegalStateException
- Thrown if
initDisplayMode
has not been called.public void setDisplaySize(int width, int height) throws MediaException
If the video mode is set to USE_DIRECT_VIDEO
,
setting the size of the video will not
affect the size of the GUI object that the video is
displayed.
If the video is scaled to beyond the size of the
GUI object, the video will be clipped.
If the video mode is set to USE_GUI_PRIMITIVE
,
Scaling the video will also scale the GUI object.
The actual scaling algorithm is left up to the underlying implementation. If the dimensions of the requested display size are smaller than the dimensions of the video clip, some implementations may choose to merely clip the video while other implementations may resize the video.
If the dimensions of the requested display size are bigger than the dimensions of the video clip, some implementations may resize the video while others may leave the video clip in the original size and just enlarge the display region. It is left up to the implementation where the video clip is placed in the display region in this instance (i.e., it can be in the center of the window or in a corner of the window).
width
- Desired width (in pixels) of the display windowheight
- Desired height (in pixels) of the display window
java.lang.IllegalArgumentException
- Thrown if the
given width
and height
are
non-positive values.
java.lang.IllegalStateException
- Thrown if
initDisplayMode
has not been called.
MediaException
- Thrown if resizing is not supported or
the operation failed due to hardware or software limitations.public void setDisplayFullScreen(boolean fullScreenMode) throws MediaException
fullScreenMode
- Indicates whether or not to render
in full screen mode
MediaException
- Thrown if resizing to full screen size
is not supported.
java.lang.IllegalStateException
- Thrown if
initDisplayMode
has not been called.public int getSourceWidth()
public int getSourceHeight()
public int getDisplayWidth()
java.lang.IllegalStateException
- Thrown if
initDisplayMode
has not been called.public int getDisplayHeight()
java.lang.IllegalStateException
- Thrown if
initDisplayMode
has not been called.public byte[] getSnapshot(java.lang.String imageType) throws MediaException
imageType
.
Supported formats can be queried from System.getProperty
with
video.snapshot.encodings
as the key.
The first format in the supported list is the default capture format.
imageType
- Format and resolution of the returned image.
If null
is given, the default capture format is used.
java.lang.IllegalStateException
- Thrown if
initDisplayMode
has not been called.
MediaException
- Thrown if the requested format is
not supported or the Player
does not support
snapshots.
java.lang.SecurityException
- Thrown if the caller does
not have the security permission to take the snapshot.
|
Copyright 2002-2003 Sun Microsystems, Inc.; Nokia Corporation. See the Copyright Notice and Specification License for more details. |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |