summaryrefslogtreecommitdiff
path: root/avmedia/source/java/FrameGrabber.java
diff options
context:
space:
mode:
Diffstat (limited to 'avmedia/source/java/FrameGrabber.java')
-rw-r--r--avmedia/source/java/FrameGrabber.java34
1 files changed, 17 insertions, 17 deletions
diff --git a/avmedia/source/java/FrameGrabber.java b/avmedia/source/java/FrameGrabber.java
index 1a0deda4ce57..a3ad559aa9ae 100644
--- a/avmedia/source/java/FrameGrabber.java
+++ b/avmedia/source/java/FrameGrabber.java
@@ -1,7 +1,7 @@
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
- *
+ *
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
@@ -51,7 +51,7 @@ public class FrameGrabber implements com.sun.star.lang.XServiceInfo,
public FrameGrabber( com.sun.star.lang.XMultiServiceFactory aFactory, String aURL )
{
maFactory = aFactory;
-
+
try
{
maPlayer = javax.media.Manager.createRealizedPlayer( new java.net.URL( aURL ) );
@@ -71,39 +71,39 @@ public class FrameGrabber implements com.sun.star.lang.XServiceInfo,
catch( java.lang.Exception e )
{
}
-
+
if( maPlayer != null )
{
maFrameGrabbingControl = (javax.media.control.FrameGrabbingControl) maPlayer.getControl(
"javax.media.control.FrameGrabbingControl" );
}
}
-
+
// -------------------------------------------------------------------------
public com.sun.star.graphic.XGraphic implImageToXGraphic( java.awt.Image aImage )
{
com.sun.star.graphic.XGraphic aRet = null;
-
+
if( maFactory != null && aImage != null )
{
if( aImage instanceof java.awt.image.BufferedImage )
{
java.io.File aTempFile = null;
-
+
try
{
aTempFile = java.io.File.createTempFile( "sv0", ".png" );
-
+
if( aTempFile.canWrite() )
{
javax.imageio.ImageIO.write( (java.awt.image.BufferedImage) aImage, "png", aTempFile );
-
+
com.sun.star.graphic.XGraphicProvider aProvider =
(com.sun.star.graphic.XGraphicProvider) UnoRuntime.queryInterface(
com.sun.star.graphic.XGraphicProvider.class,
maFactory.createInstance("com.sun.star.graphic.GraphicProvider") );
-
+
if( aProvider != null )
{
com.sun.star.beans.PropertyValue[] aArgs = new com.sun.star.beans.PropertyValue[ 1 ];
@@ -125,15 +125,15 @@ public class FrameGrabber implements com.sun.star.lang.XServiceInfo,
catch( com.sun.star.uno.Exception aExcp )
{
}
-
+
if( aTempFile != null )
aTempFile.delete();
}
}
-
+
return aRet;
}
-
+
// -----------------
// - XFrameGrabber -
// -----------------
@@ -141,24 +141,24 @@ public class FrameGrabber implements com.sun.star.lang.XServiceInfo,
public synchronized com.sun.star.graphic.XGraphic grabFrame( double fMediaTime )
{
com.sun.star.graphic.XGraphic aRet = null;
-
+
if( maFrameGrabbingControl != null )
{
if( fMediaTime >= 0.0 && fMediaTime <= maPlayer.getDuration().getSeconds() )
{
maPlayer.setMediaTime( new javax.media.Time( fMediaTime ) );
-
+
javax.media.Buffer aBuffer = maFrameGrabbingControl.grabFrame();
-
+
if( aBuffer != null && aBuffer.getFormat() instanceof javax.media.format.VideoFormat )
{
- aRet = implImageToXGraphic( new javax.media.util.BufferToImage(
+ aRet = implImageToXGraphic( new javax.media.util.BufferToImage(
(javax.media.format.VideoFormat) aBuffer.getFormat() ).
createImage( aBuffer ) );
}
}
}
-
+
return aRet;
}