summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKurt Zenker <kz@openoffice.org>2006-12-13 15:08:48 +0000
committerKurt Zenker <kz@openoffice.org>2006-12-13 15:08:48 +0000
commitd0a88886322bee241f511c71ebbc27e907688a7f (patch)
tree68598e354b3e09784020684ba1332b218b1ef7d8
parent8b1c4d3ebb1765e41149900fcd74dc1683d7a990 (diff)
INTEGRATION: CWS presfixes09 (1.1.2); FILE ADDED
2006/05/12 21:56:16 thb 1.1.2.1: #i49357# slideshow demo application
-rw-r--r--slideshow/test/demoshow.cxx552
1 files changed, 552 insertions, 0 deletions
diff --git a/slideshow/test/demoshow.cxx b/slideshow/test/demoshow.cxx
new file mode 100644
index 000000000000..d148f33fda73
--- /dev/null
+++ b/slideshow/test/demoshow.cxx
@@ -0,0 +1,552 @@
+/*************************************************************************
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * $RCSfile: demoshow.cxx,v $
+ *
+ * $Revision: 1.2 $
+ *
+ * last change: $Author: kz $ $Date: 2006-12-13 16:08:48 $
+ *
+ * The Contents of this file are made available subject to
+ * the terms of GNU Lesser General Public License Version 2.1.
+ *
+ *
+ * GNU Lesser General Public License Version 2.1
+ * =============================================
+ * Copyright 2005 by Sun Microsystems, Inc.
+ * 901 San Antonio Road, Palo Alto, CA 94303, USA
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License version 2.1, as published by the Free Software Foundation.
+ *
+ * This library 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 for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ *
+ ************************************************************************/
+
+#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 <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>
+
+
+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;
+ maTransform.identity();
+ const sal_Int32 nSize( std::min( rNewSize.Width(),
+ rNewSize.Height() ) - 10 );
+ maTransform.scale( nSize, nSize );
+ maTransform.translate( (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)
+ {
+ }
+
+ struct PropValEntry
+ {
+ const char* pName;
+ const sal_Int32 nVal;
+ };
+
+ 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 SmoketestApp : 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 SmoketestWindow : public Dialog
+{
+public:
+ SmoketestWindow();
+ 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;
+};
+
+SmoketestWindow::SmoketestWindow() :
+ Dialog((Window*)NULL),
+ maLeftChild( this ),
+ maRightTopChild( this ),
+ maRightBottomChild( this ),
+ mxShow(),
+ maUpdateTimer(),
+ mbSlideDisplayed( false )
+{
+ SetText( rtl::OUString::createFromAscii( "Slideshow smoketest" ) );
+ 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, SmoketestWindow, updateHdl));
+ maUpdateTimer.SetTimeout( (ULONG)30 );
+ maUpdateTimer.Start();
+}
+
+void SmoketestWindow::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( SmoketestWindow, updateHdl, Timer*, EMPTYARG )
+{
+ init();
+
+ double nTimeout;
+ if( mxShow.is() )
+ mxShow->update(nTimeout);
+
+ return 0;
+}
+
+void SmoketestWindow::Paint( const Rectangle& rRect )
+{
+ init();
+}
+
+void SmoketestWindow::Resize()
+{
+ // TODO
+}
+
+USHORT SmoketestApp::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 SmoketestApp::Main()
+{
+ // 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::Exception& )
+ {
+ }
+
+ 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 );
+ ::ucb::ContentBroker::initialize( xFactory, aArgs );
+
+ SmoketestWindow pWindow;
+ pWindow.Execute();
+
+ // clean up UCB
+ ::ucb::ContentBroker::deinitialize();
+}
+}
+
+SmoketestApp aApp;