| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:09:17 +00:00
										 |  |  |  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:09:17 +00:00
										 |  |  |  * Copyright 2008 by Sun Microsystems, Inc. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:09:17 +00:00
										 |  |  |  * OpenOffice.org - a multi-platform office productivity suite | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:09:17 +00:00
										 |  |  |  * $RCSfile: randomwipe.cxx,v $ | 
					
						
							|  |  |  |  * $Revision: 1.7 $ | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:09:17 +00:00
										 |  |  |  * This file is part of OpenOffice.org. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:09:17 +00:00
										 |  |  |  * 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. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:09:17 +00:00
										 |  |  |  * 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). | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-11 00:09:17 +00:00
										 |  |  |  * 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. | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  ************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-17 07:40:49 +00:00
										 |  |  | // MARKER(update_precomp.py): autogen include statement, do not remove
 | 
					
						
							|  |  |  | #include "precompiled_slideshow.hxx"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-13 14:44:34 +00:00
										 |  |  | #include <canvas/debug.hxx>
 | 
					
						
							|  |  |  | #include <basegfx/matrix/b2dhommatrix.hxx>
 | 
					
						
							|  |  |  | #include <basegfx/numeric/ftools.hxx>
 | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  | #include "randomwipe.hxx"
 | 
					
						
							| 
									
										
										
										
											2005-03-10 12:52:07 +00:00
										 |  |  | #include "tools.hxx"
 | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-13 14:44:34 +00:00
										 |  |  | namespace slideshow { | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  | namespace internal { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | RandomWipe::RandomWipe( sal_Int32 nElements, bool randomBars ) | 
					
						
							|  |  |  |     : m_positions( new ::basegfx::B2DPoint[ nElements ] ), | 
					
						
							|  |  |  |       m_nElements( nElements ), | 
					
						
							|  |  |  |       m_rect( createUnitRect() ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::basegfx::B2DHomMatrix aTransform; | 
					
						
							|  |  |  |     if (randomBars) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         double edge = (1.0 / nElements); | 
					
						
							|  |  |  |         for ( sal_Int32 pos = nElements; pos--; ) | 
					
						
							|  |  |  |             m_positions[ pos ].setY( ::basegfx::pruneScaleValue( pos * edge ) ); | 
					
						
							|  |  |  |         aTransform.scale( 1.0, ::basegfx::pruneScaleValue(edge) ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else // dissolve effect
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         sal_Int32 sqrtElements = static_cast<sal_Int32>( | 
					
						
							|  |  |  |             sqrt( static_cast<double>(nElements) ) ); | 
					
						
							|  |  |  |         double edge = (1.0 / sqrtElements); | 
					
						
							|  |  |  |         for ( sal_Int32 pos = nElements; pos--; ) { | 
					
						
							|  |  |  |             m_positions[ pos ] = ::basegfx::B2DPoint( | 
					
						
							|  |  |  |                 ::basegfx::pruneScaleValue( (pos % sqrtElements) * edge ), | 
					
						
							|  |  |  |                 ::basegfx::pruneScaleValue( (pos / sqrtElements) * edge ) ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         const double pedge = ::basegfx::pruneScaleValue(edge); | 
					
						
							|  |  |  |         aTransform.scale( pedge, pedge ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     m_rect.transform( aTransform ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // mix up:
 | 
					
						
							|  |  |  |     for ( sal_Int32 i = (nElements / 2); i--; ) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2005-03-10 12:52:07 +00:00
										 |  |  |         const sal_Int32 pos1 = getRandomOrdinal(nElements); | 
					
						
							|  |  |  |         const sal_Int32 pos2 = getRandomOrdinal(nElements); | 
					
						
							|  |  |  |         const ::basegfx::B2DPoint point( m_positions[ pos1 ] ); | 
					
						
							| 
									
										
										
										
											2004-11-26 18:07:54 +00:00
										 |  |  |         m_positions[ pos1 ] = m_positions[ pos2 ]; | 
					
						
							|  |  |  |         m_positions[ pos2 ] = point; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::basegfx::B2DPolyPolygon RandomWipe::operator () ( double t ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ::basegfx::B2DPolyPolygon res; | 
					
						
							|  |  |  |     for ( sal_Int32 pos = static_cast<sal_Int32>(t * m_nElements); pos--; ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         ::basegfx::B2DHomMatrix aTransform; | 
					
						
							|  |  |  |         ::basegfx::B2DPoint const & point = m_positions[ pos ]; | 
					
						
							|  |  |  |         aTransform.translate( point.getX(), point.getY() ); | 
					
						
							|  |  |  |         ::basegfx::B2DPolygon poly( m_rect ); | 
					
						
							|  |  |  |         poly.transform( aTransform ); | 
					
						
							|  |  |  |         res.append( poly ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return res; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | } |