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.cxx580
1 files changed, 0 insertions, 580 deletions
diff --git a/slideshow/test/demoshow.cxx b/slideshow/test/demoshow.cxx
deleted file mode 100644
index 0bf6f34a6..000000000
--- a/slideshow/test/demoshow.cxx
+++ /dev/null
@@ -1,580 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*************************************************************************
- *
- * 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/matrix/b2dhommatrixtools.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)
- {
- }
-
- virtual awt::Rectangle SAL_CALL getCanvasArea( ) throw (uno::RuntimeException)
- {
- return awt::Rectangle(0,0,maSize.Width(),maSize.Height());
- }
-
- 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 sal_uInt16 Exception( sal_uInt16 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(RTL_CONSTASCII_USTRINGPARAM( "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( (sal_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 );
- uno::Reference< drawing::XDrawPages > xDrawPages;
- mxShow->displaySlide( xSlide,
- uno::Reference< drawing::XDrawPagesSupplier >(),
- uno::Reference< animations::XAnimationNode >(),
- uno::Sequence< beans::PropertyValue >() );
- mxShow->setProperty( beans::PropertyValue(
- rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("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();
-
- if( mxShow.is() )
- double nTimeout;
- mxShow->update(nTimeout);
-
- return 0;
-}
-
-void DemoWindow::Paint( const Rectangle& /*rRect*/ )
-{
- init();
-}
-
-void DemoWindow::Resize()
-{
- // TODO
-}
-
-sal_uInt16 DemoApp::Exception( sal_uInt16 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( sal_uInt16 i = 0; i < GetCommandLineParamCount(); i++ )
- {
- ::rtl::OUString aParam = GetCommandLineParam( i );
-
- if( aParam.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "--help" ) ) ||
- aParam.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "-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_FAIL( 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(RTL_CONSTASCII_USTRINGPARAM( UCB_CONFIGURATION_KEY1_LOCAL ));
- aArgs[ 1 ] <<= rtl::OUString(RTL_CONSTASCII_USTRINGPARAM( UCB_CONFIGURATION_KEY2_OFFICE ));
- ::ucbhelper::ContentBroker::initialize( xFactory, aArgs );
-
- DemoWindow pWindow;
- pWindow.Execute();
-
- // clean up UCB
- ::ucbhelper::ContentBroker::deinitialize();
-}
-}
-
-DemoApp aApp;
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */