2000-09-18 16:07:07 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2005-09-08 21:55:41 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2005-09-08 21:55:41 +00:00
|
|
|
* $RCSfile: drawutil.cxx,v $
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2006-07-21 13:53:11 +00:00
|
|
|
* $Revision: 1.7 $
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2006-07-21 13:53:11 +00:00
|
|
|
* last change: $Author: kz $ $Date: 2006-07-21 14:53:11 $
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2005-09-08 21:55:41 +00:00
|
|
|
* The Contents of this file are made available subject to
|
|
|
|
* the terms of GNU Lesser General Public License Version 2.1.
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
|
|
|
*
|
2005-09-08 21:55:41 +00:00
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2005 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2005-09-08 21:55:41 +00:00
|
|
|
* 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.
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2005-09-08 21:55:41 +00:00
|
|
|
* 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.
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2005-09-08 21:55:41 +00:00
|
|
|
* 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
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
2006-07-21 13:53:11 +00:00
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
|
|
#include "precompiled_sc.hxx"
|
|
|
|
|
2000-09-18 16:07:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
// INCLUDE ---------------------------------------------------------------
|
|
|
|
|
|
|
|
#include <vcl/outdev.hxx>
|
|
|
|
|
|
|
|
#include "drawutil.hxx"
|
|
|
|
#include "document.hxx"
|
|
|
|
#include "global.hxx"
|
2001-04-18 09:42:15 +00:00
|
|
|
#include "viewdata.hxx"
|
2000-09-18 16:07:07 +00:00
|
|
|
|
|
|
|
// STATIC DATA -----------------------------------------------------------
|
|
|
|
|
|
|
|
// -----------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
inline Fraction MakeFraction( long nA, long nB )
|
|
|
|
{
|
|
|
|
return ( nA && nB ) ? Fraction(nA,nB) : Fraction(1,1);
|
|
|
|
}
|
|
|
|
|
2004-06-04 10:59:44 +00:00
|
|
|
void ScDrawUtil::CalcScale( ScDocument* pDoc, SCTAB nTab,
|
|
|
|
SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow,
|
2000-09-18 16:07:07 +00:00
|
|
|
OutputDevice* pDev,
|
|
|
|
const Fraction& rZoomX, const Fraction& rZoomY,
|
|
|
|
double nPPTX, double nPPTY,
|
|
|
|
Fraction& rScaleX, Fraction& rScaleY )
|
|
|
|
{
|
|
|
|
long nPixelX = 0;
|
|
|
|
long nTwipsX = 0;
|
|
|
|
long nPixelY = 0;
|
|
|
|
long nTwipsY = 0;
|
2004-06-04 10:59:44 +00:00
|
|
|
for (SCCOL i=nStartCol; i<nEndCol; i++)
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
2001-04-18 09:42:15 +00:00
|
|
|
USHORT nWidth = pDoc->GetColWidth(i,nTab);
|
|
|
|
nTwipsX += (long) nWidth;
|
|
|
|
nPixelX += ScViewData::ToPixel( nWidth, nPPTX );
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
2004-08-20 08:15:38 +00:00
|
|
|
ScCoupledCompressedArrayIterator< SCROW, BYTE, USHORT> aIter(
|
|
|
|
pDoc->GetRowFlagsArray( nTab), nStartRow, nEndRow-1, CR_HIDDEN, 0,
|
|
|
|
pDoc->GetRowHeightArray( nTab));
|
|
|
|
for ( ; aIter; ++aIter )
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
2004-08-20 08:15:38 +00:00
|
|
|
USHORT nHeight = *aIter;
|
2001-04-18 09:42:15 +00:00
|
|
|
nTwipsY += (long) nHeight;
|
|
|
|
nPixelY += ScViewData::ToPixel( nHeight, nPPTY );
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
MapMode aHMMMode( MAP_100TH_MM, Point(), rZoomX, rZoomY );
|
|
|
|
Point aPixelLog = pDev->PixelToLogic( Point( nPixelX,nPixelY ), aHMMMode );
|
|
|
|
|
2001-10-16 13:43:14 +00:00
|
|
|
// Fraction(double) ctor can be used here (and avoid overflows of PixelLog * Zoom)
|
|
|
|
// because ReduceInaccurate is called later anyway.
|
|
|
|
|
|
|
|
if ( aPixelLog.X() && nTwipsX )
|
|
|
|
rScaleX = Fraction( ((double)aPixelLog.X()) *
|
|
|
|
((double)rZoomX.GetNumerator()) /
|
|
|
|
((double)nTwipsX) /
|
|
|
|
((double)HMM_PER_TWIPS) /
|
|
|
|
((double)rZoomX.GetDenominator()) );
|
|
|
|
else
|
|
|
|
rScaleX = Fraction( 1, 1 );
|
|
|
|
|
|
|
|
if ( aPixelLog.Y() && nTwipsY )
|
|
|
|
rScaleY = Fraction( ((double)aPixelLog.Y()) *
|
|
|
|
((double)rZoomY.GetNumerator()) /
|
|
|
|
((double)nTwipsY) /
|
|
|
|
((double)HMM_PER_TWIPS) /
|
|
|
|
((double)rZoomY.GetDenominator()) );
|
|
|
|
else
|
|
|
|
rScaleY = Fraction( 1, 1 );
|
|
|
|
|
|
|
|
// 17 bits of accuracy are needed to always hit the right part of
|
|
|
|
// cells in the last rows
|
|
|
|
rScaleX.ReduceInaccurate( 17 );
|
|
|
|
rScaleY.ReduceInaccurate( 17 );
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|