summaryrefslogtreecommitdiff
path: root/slideshow/test/demoshow.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'slideshow/test/demoshow.cxx')
-rw-r--r--slideshow/test/demoshow.cxx570
1 files changed, 570 insertions, 0 deletions
diff --git a/slideshow/test/demoshow.cxx b/slideshow/test/demoshow.cxx
new file mode 100644
index 000000000000..2fb84f1f9d83
--- /dev/null
+++ b/slideshow/test/demoshow.cxx
@@ -0,0 +1,570 @@
+/*************************************************************************
+ *
+ * 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
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org 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.
+ *
+ * OpenOffice.org 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
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+#include <sal/main.h>
+#include <rtl/ref.hxx>
+#include <rtl/bootstrap.hxx>
+
+#include <cppuhelper/bootstrap.hxx>
+#include <cppuhelper/servicefactory.hxx>
+#include <cppuhelper/interfacecontainer.hxx>
+#include <cppuhelper/compbase1.hxx>
+#include <cppuhelper/compbase2.hxx>
+
+#include <comphelper/processfactory.hxx>
+#include <comphelper/broadcasthelper.hxx>
+#include <comphelper/anytostring.hxx>
+#include <cppuhelper/exc_hlp.hxx>
+
+#include <com/sun/star/lang/XMultiServiceFactory.hpp>
+#include <com/sun/star/beans/XPropertySet.hpp>
+#include <com/sun/star/rendering/XCanvas.hpp>
+#include <com/sun/star/rendering/XSpriteCanvas.hpp>
+#include <com/sun/star/presentation/XSlideShow.hpp>
+#include <com/sun/star/presentation/XSlideShowView.hpp>
+#include "com/sun/star/animations/TransitionType.hpp"
+#include "com/sun/star/animations/TransitionSubType.hpp"
+
+#include <ucbhelper/contentbroker.hxx>
+#include <ucbhelper/configurationkeys.hxx>
+
+#include <basegfx/matrix/b2dhommatrix.hxx>
+#include <basegfx/tools/canvastools.hxx>
+#include <basegfx/range/b2drectangle.hxx>
+#include <basegfx/polygon/b2dpolygon.hxx>
+#include <basegfx/polygon/b2dpolygontools.hxx>
+
+#include <cppcanvas/vclfactory.hxx>
+#include <cppcanvas/basegfxfactory.hxx>
+#include <cppcanvas/polypolygon.hxx>
+
+#include <canvas/canvastools.hxx>
+
+#include <vcl/dialog.hxx>
+#include <vcl/timer.hxx>
+#include <vcl/window.hxx>
+#include <vcl/svapp.hxx>
+
+#include <stdio.h>
+#include <unistd.h>
+
+
+using namespace ::com::sun::star;
+
+namespace {
+
+typedef ::cppu::WeakComponentImplHelper1< presentation::XSlideShowView > ViewBase;
+class View : public ::comphelper::OBaseMutex,
+ public ViewBase
+{
+public:
+ explicit View( const uno::Reference< rendering::XSpriteCanvas >& rCanvas ) :
+ ViewBase( m_aMutex ),
+ mxCanvas( rCanvas ),
+ maPaintListeners( m_aMutex ),
+ maTransformationListeners( m_aMutex ),
+ maMouseListeners( m_aMutex ),
+ maMouseMotionListeners( m_aMutex ),
+ maTransform(),
+ maSize()
+ {
+ }
+
+ void resize( const ::Size& rNewSize )
+ {
+ maSize = rNewSize;
+ const sal_Int32 nSize( std::min( rNewSize.Width(), rNewSize.Height() ) - 10);
+ maTransform = basegfx::tools::createScaleTranslateB2DHomMatrix(
+ nSize, nSize, (rNewSize.Width() - nSize) / 2, (rNewSize.Height() - nSize) / 2);
+
+ lang::EventObject aEvent( *this );
+ maTransformationListeners.notifyEach( &util::XModifyListener::modified,
+ aEvent );
+ }
+
+ void repaint()
+ {
+ awt::PaintEvent aEvent( *this,
+ awt::Rectangle(),
+ 0 );
+ maPaintListeners.notifyEach( &awt::XPaintListener::windowPaint,
+ aEvent );
+ }
+
+private:
+ virtual ~View() {}
+
+ virtual uno::Reference< rendering::XSpriteCanvas > SAL_CALL getCanvas( ) throw (uno::RuntimeException)
+ {
+ return mxCanvas;
+ }
+
+ virtual void SAL_CALL clear( ) throw (uno::RuntimeException)
+ {
+ ::basegfx::B2DPolygon aPoly( ::basegfx::tools::createPolygonFromRect(
+ ::basegfx::B2DRectangle(0.0,0.0,
+ maSize.Width(),
+ maSize.Height() )));
+ ::cppcanvas::SpriteCanvasSharedPtr pCanvas(
+ ::cppcanvas::VCLFactory::getInstance().createSpriteCanvas( mxCanvas ));
+ if( !pCanvas )
+ return;
+
+ ::cppcanvas::PolyPolygonSharedPtr pPolyPoly(
+ ::cppcanvas::BaseGfxFactory::getInstance().createPolyPolygon( pCanvas,
+ aPoly ) );
+ if( !pPolyPoly )
+ return;
+
+ if( pPolyPoly )
+ {
+ pPolyPoly->setRGBAFillColor( 0x808080FFU );
+ pPolyPoly->draw();
+ }
+ }
+
+ virtual geometry::AffineMatrix2D SAL_CALL getTransformation( ) throw (uno::RuntimeException)
+ {
+ geometry::AffineMatrix2D aRes;
+ return basegfx::unotools::affineMatrixFromHomMatrix( aRes,
+ maTransform );
+ }
+
+ virtual void SAL_CALL addTransformationChangedListener( const uno::Reference< util::XModifyListener >& xListener ) throw (uno::RuntimeException)
+ {
+ maTransformationListeners.addInterface( xListener );
+ }
+
+ virtual void SAL_CALL removeTransformationChangedListener( const uno::Reference< util::XModifyListener >& xListener ) throw (uno::RuntimeException)
+ {
+ maTransformationListeners.removeInterface( xListener );
+ }
+
+ virtual void SAL_CALL addPaintListener( const uno::Reference< awt::XPaintListener >& xListener ) throw (uno::RuntimeException)
+ {
+ maPaintListeners.addInterface( xListener );
+ }
+
+ virtual void SAL_CALL removePaintListener( const uno::Reference< awt::XPaintListener >& xListener ) throw (uno::RuntimeException)
+ {
+ maPaintListeners.removeInterface( xListener );
+ }
+
+ virtual void SAL_CALL addMouseListener( const uno::Reference< awt::XMouseListener >& xListener ) throw (uno::RuntimeException)
+ {
+ maMouseListeners.addInterface( xListener );
+ }
+
+ virtual void SAL_CALL removeMouseListener( const uno::Reference< awt::XMouseListener >& xListener ) throw (uno::RuntimeException)
+ {
+ maMouseListeners.removeInterface( xListener );
+ }
+
+ virtual void SAL_CALL addMouseMotionListener( const uno::Reference< awt::XMouseMotionListener >& xListener ) throw (uno::RuntimeException)
+ {
+ maMouseMotionListeners.addInterface( xListener );
+ }
+
+ virtual void SAL_CALL removeMouseMotionListener( const uno::Reference< awt::XMouseMotionListener >& xListener ) throw (uno::RuntimeException)
+ {
+ maMouseMotionListeners.removeInterface( xListener );
+ }
+
+ virtual void SAL_CALL setMouseCursor( ::sal_Int16 /*nPointerShape*/ ) throw (uno::RuntimeException)
+ {
+ }
+
+ uno::Reference< rendering::XSpriteCanvas > mxCanvas;
+ ::cppu::OInterfaceContainerHelper maPaintListeners;
+ ::cppu::OInterfaceContainerHelper maTransformationListeners;
+ ::cppu::OInterfaceContainerHelper maMouseListeners;
+ ::cppu::OInterfaceContainerHelper maMouseMotionListeners;
+ basegfx::B2DHomMatrix maTransform;
+ Size maSize;
+};
+
+typedef ::cppu::WeakComponentImplHelper2< drawing::XDrawPage,
+ beans::XPropertySet > SlideBase;
+class DummySlide : public ::comphelper::OBaseMutex,
+ public SlideBase
+{
+public:
+ DummySlide() : SlideBase( m_aMutex ) {}
+
+private:
+ // XDrawPage
+ virtual void SAL_CALL add( const uno::Reference< drawing::XShape >& /*xShape*/ ) throw (uno::RuntimeException)
+ {
+ }
+
+ virtual void SAL_CALL remove( const uno::Reference< drawing::XShape >& /*xShape*/ ) throw (uno::RuntimeException)
+ {
+ }
+
+ virtual ::sal_Int32 SAL_CALL getCount( ) throw (uno::RuntimeException)
+ {
+ return 0;
+ }
+
+ virtual uno::Any SAL_CALL getByIndex( ::sal_Int32 /*Index*/ ) throw (lang::IndexOutOfBoundsException, lang::WrappedTargetException, uno::RuntimeException)
+ {
+ return uno::Any();
+ }
+
+ virtual uno::Type SAL_CALL getElementType( ) throw (uno::RuntimeException)
+ {
+ return uno::Type();
+ }
+
+ virtual ::sal_Bool SAL_CALL hasElements( ) throw (uno::RuntimeException)
+ {
+ return false;
+ }
+
+ // XPropertySet
+ virtual uno::Reference< beans::XPropertySetInfo > SAL_CALL getPropertySetInfo( ) throw (uno::RuntimeException)
+ {
+ return uno::Reference< beans::XPropertySetInfo >();
+ }
+
+ virtual void SAL_CALL setPropertyValue( const ::rtl::OUString& /*aPropertyName*/,
+ const uno::Any& /*aValue*/ ) throw (beans::UnknownPropertyException, beans::PropertyVetoException, lang::IllegalArgumentException, lang::WrappedTargetException, uno::RuntimeException)
+ {
+ }
+
+ virtual uno::Any SAL_CALL getPropertyValue( const ::rtl::OUString& PropertyName ) throw (beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException)
+ {
+ typedef ::canvas::tools::ValueMap< sal_Int16 > PropMapT;
+
+ // fixed PropertyValue map
+ static PropMapT::MapEntry lcl_propertyMap[] =
+ {
+ {"Height", 100},
+ {"MinimalFrameNumber", 50},
+ {"TransitionDuration", 10},
+ {"TransitionSubtype", animations::TransitionSubType::FROMTOPLEFT},
+ {"TransitionType", animations::TransitionType::PUSHWIPE},
+ {"Width", 100}
+ };
+
+ static PropMapT aMap( lcl_propertyMap,
+ sizeof(lcl_propertyMap)/sizeof(*lcl_propertyMap),
+ true );
+
+ sal_Int16 aRes;
+ if( !aMap.lookup( PropertyName, aRes ))
+ return uno::Any();
+
+ return uno::makeAny(aRes);
+ }
+
+ virtual void SAL_CALL addPropertyChangeListener( const ::rtl::OUString& /*aPropertyName*/,
+ const uno::Reference< beans::XPropertyChangeListener >& /*xListener*/ ) throw (beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException)
+ {
+ }
+
+ virtual void SAL_CALL removePropertyChangeListener( const ::rtl::OUString& /*aPropertyName*/,
+ const uno::Reference< beans::XPropertyChangeListener >& /*aListener*/ ) throw (beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException)
+ {
+ }
+
+ virtual void SAL_CALL addVetoableChangeListener( const ::rtl::OUString& /*PropertyName*/,
+ const uno::Reference< beans::XVetoableChangeListener >& /*aListener*/ ) throw (beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException)
+ {
+ }
+
+ virtual void SAL_CALL removeVetoableChangeListener( const ::rtl::OUString& /*PropertyName*/,
+ const uno::Reference< beans::XVetoableChangeListener >& /*aListener*/ ) throw (beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException)
+ {
+ }
+};
+
+
+class DemoApp : public Application
+{
+public:
+ virtual void Main();
+ virtual USHORT Exception( USHORT nError );
+};
+
+class ChildWindow : public Window
+{
+public:
+ ChildWindow( Window* pParent );
+ virtual ~ChildWindow();
+ virtual void Paint( const Rectangle& rRect );
+ virtual void Resize();
+
+ void setShow( const uno::Reference< presentation::XSlideShow >& rShow ) { mxShow = rShow; init(); }
+
+private:
+ void init();
+
+ rtl::Reference< View > mpView;
+ uno::Reference< presentation::XSlideShow > mxShow;
+};
+
+ChildWindow::ChildWindow( Window* pParent ) :
+ Window(pParent, WB_CLIPCHILDREN | WB_BORDER| WB_3DLOOK ),
+ mpView(),
+ mxShow()
+{
+ EnablePaint( true );
+ Show();
+}
+
+ChildWindow::~ChildWindow()
+{
+ if( mxShow.is() && mpView.is() )
+ mxShow->removeView( mpView.get() );
+}
+
+void ChildWindow::init()
+{
+ try
+ {
+ if( !mpView.is() )
+ {
+ uno::Reference< rendering::XCanvas > xCanvas( GetCanvas(),
+ uno::UNO_QUERY_THROW );
+ uno::Reference< rendering::XSpriteCanvas > xSpriteCanvas( xCanvas,
+ uno::UNO_QUERY_THROW );
+ mpView = new View( xSpriteCanvas );
+ mpView->resize( GetSizePixel() );
+
+ if( mxShow.is() )
+ mxShow->addView( mpView.get() );
+ }
+ }
+ catch (const uno::Exception &e)
+ {
+ OSL_TRACE( "Exception '%s' thrown\n" ,
+ (const sal_Char*)::rtl::OUStringToOString( e.Message,
+ RTL_TEXTENCODING_UTF8 ));
+ }
+}
+
+void ChildWindow::Paint( const Rectangle& /*rRect*/ )
+{
+ try
+ {
+ if( mpView.is() )
+ mpView->repaint();
+ }
+ catch (const uno::Exception &e)
+ {
+ OSL_TRACE( "Exception '%s' thrown\n" ,
+ (const sal_Char*)::rtl::OUStringToOString( e.Message,
+ RTL_TEXTENCODING_UTF8 ));
+ }
+}
+
+void ChildWindow::Resize()
+{
+ if( mpView.is() )
+ mpView->resize( GetSizePixel() );
+}
+
+class DemoWindow : public Dialog
+{
+public:
+ DemoWindow();
+ virtual void Paint( const Rectangle& rRect );
+ virtual void Resize();
+
+private:
+ void init();
+ DECL_LINK( updateHdl, Timer* );
+
+ ChildWindow maLeftChild;
+ ChildWindow maRightTopChild;
+ ChildWindow maRightBottomChild;
+ uno::Reference< presentation::XSlideShow > mxShow;
+ AutoTimer maUpdateTimer;
+ bool mbSlideDisplayed;
+};
+
+DemoWindow::DemoWindow() :
+ Dialog((Window*)NULL),
+ maLeftChild( this ),
+ maRightTopChild( this ),
+ maRightBottomChild( this ),
+ mxShow(),
+ maUpdateTimer(),
+ mbSlideDisplayed( false )
+{
+ SetText( rtl::OUString::createFromAscii( "Slideshow Demo" ) );
+ SetSizePixel( Size( 640, 480 ) );
+ EnablePaint( true );
+
+ maLeftChild.SetPosSizePixel( Point(), Size(320,480) );
+ maRightTopChild.SetPosSizePixel( Point(320,0), Size(320,240) );
+ maRightBottomChild.SetPosSizePixel( Point(320,240), Size(320,240) );
+ Show();
+
+ maUpdateTimer.SetTimeoutHdl(LINK(this, DemoWindow, updateHdl));
+ maUpdateTimer.SetTimeout( (ULONG)30 );
+ maUpdateTimer.Start();
+}
+
+void DemoWindow::init()
+{
+ try
+ {
+ if( !mxShow.is() )
+ {
+ uno::Reference< lang::XMultiServiceFactory > xFactory(
+ ::comphelper::getProcessServiceFactory(),
+ uno::UNO_QUERY_THROW );
+
+ uno::Reference< uno::XInterface > xInt( xFactory->createInstance(
+ ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("com.sun.star.presentation.SlideShow")) ));
+
+ mxShow.set( xInt,
+ uno::UNO_QUERY_THROW );
+
+ maLeftChild.setShow( mxShow );
+ maRightTopChild.setShow( mxShow );
+ maRightBottomChild.setShow( mxShow );
+ }
+
+ if( mxShow.is() && !mbSlideDisplayed )
+ {
+ uno::Reference< drawing::XDrawPage > xSlide( new DummySlide );
+ mxShow->displaySlide( xSlide,
+ uno::Reference< animations::XAnimationNode >(),
+ uno::Sequence< beans::PropertyValue >() );
+ mxShow->setProperty( beans::PropertyValue(
+ rtl::OUString::createFromAscii("RehearseTimings"),
+ 0,
+ uno::makeAny( sal_True ),
+ beans::PropertyState_DIRECT_VALUE ));
+ mbSlideDisplayed = true;
+ }
+ }
+ catch (const uno::Exception &e)
+ {
+ OSL_TRACE( "Exception '%s' thrown\n" ,
+ (const sal_Char*)::rtl::OUStringToOString( e.Message,
+ RTL_TEXTENCODING_UTF8 ));
+ }
+}
+
+IMPL_LINK( DemoWindow, updateHdl, Timer*, EMPTYARG )
+{
+ init();
+
+ double nTimeout;
+ if( mxShow.is() )
+ mxShow->update(nTimeout);
+
+ return 0;
+}
+
+void DemoWindow::Paint( const Rectangle& /*rRect*/ )
+{
+ init();
+}
+
+void DemoWindow::Resize()
+{
+ // TODO
+}
+
+USHORT DemoApp::Exception( USHORT nError )
+{
+ switch( nError & EXC_MAJORTYPE )
+ {
+ case EXC_RSCNOTLOADED:
+ Abort( String::CreateFromAscii( "Error: could not load language resources.\nPlease check your installation.\n" ) );
+ break;
+ }
+ return 0;
+}
+
+void DemoApp::Main()
+{
+ bool bHelp = false;
+
+ for( USHORT i = 0; i < GetCommandLineParamCount(); i++ )
+ {
+ ::rtl::OUString aParam = GetCommandLineParam( i );
+
+ if( aParam.equalsAscii( "--help" ) ||
+ aParam.equalsAscii( "-h" ) )
+ bHelp = true;
+ }
+
+ if( bHelp )
+ {
+ printf( "demoshow - life Slideshow testbed\n" );
+ return;
+ }
+
+ // bootstrap UNO
+ uno::Reference< lang::XMultiServiceFactory > xFactory;
+ try
+ {
+ uno::Reference< uno::XComponentContext > xCtx = ::cppu::defaultBootstrap_InitialComponentContext();
+ xFactory = uno::Reference< lang::XMultiServiceFactory >( xCtx->getServiceManager(),
+ uno::UNO_QUERY );
+ if( xFactory.is() )
+ ::comphelper::setProcessServiceFactory( xFactory );
+ }
+ catch( uno::RuntimeException& )
+ {
+ throw;
+ }
+ catch( uno::Exception& )
+ {
+ OSL_ENSURE( false,
+ rtl::OUStringToOString(
+ comphelper::anyToString( cppu::getCaughtException() ),
+ RTL_TEXTENCODING_UTF8 ).getStr() );
+ }
+
+ if( !xFactory.is() )
+ {
+ OSL_TRACE( "Could not bootstrap UNO, installation must be in disorder. Exiting.\n" );
+ exit( 1 );
+ }
+
+ // Create UCB.
+ uno::Sequence< uno::Any > aArgs( 2 );
+ aArgs[ 0 ] <<= rtl::OUString::createFromAscii( UCB_CONFIGURATION_KEY1_LOCAL );
+ aArgs[ 1 ] <<= rtl::OUString::createFromAscii( UCB_CONFIGURATION_KEY2_OFFICE );
+ ::ucbhelper::ContentBroker::initialize( xFactory, aArgs );
+
+ DemoWindow pWindow;
+ pWindow.Execute();
+
+ // clean up UCB
+ ::ucbhelper::ContentBroker::deinitialize();
+}
+}
+
+DemoApp aApp;