update dev300-m58
[ooovba.git] / sdext / source / pdfimport / misc / pdfihelper.cxx
blob63a47779caec91f96abd204664cd674218a2a823
1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: pdfihelper.cxx,v $
11 * $Revision: 1.2 $
13 * This file is part of OpenOffice.org.
15 * OpenOffice.org is free software: you can redistribute it and/or modify
16 * it under the terms of the GNU Lesser General Public License version 3
17 * only, as published by the Free Software Foundation.
19 * OpenOffice.org is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU Lesser General Public License version 3 for more details
23 * (a copy is included in the LICENSE file that accompanied this code).
25 * You should have received a copy of the GNU Lesser General Public License
26 * version 3 along with OpenOffice.org. If not, see
27 * <http://www.openoffice.org/license.html>
28 * for a copy of the LGPLv3 License.
30 ************************************************************************/
32 // MARKER(update_precomp.py): autogen include statement, do not remove
33 #include "precompiled_sdext.hxx"
35 #include "pdfihelper.hxx"
37 #include <rtl/ustrbuf.hxx>
38 #include <basegfx/numeric/ftools.hxx>
40 using namespace pdfi;
41 using namespace com::sun::star;
43 rtl::OUString pdfi::getColorString( const rendering::ARGBColor& rCol )
45 rtl::OUStringBuffer aBuf( 7 );
46 const sal_uInt8 nRed ( sal::static_int_cast<sal_Int8>( basegfx::fround( rCol.Red * 255.0 ) ) );
47 const sal_uInt8 nGreen( sal::static_int_cast<sal_Int8>( basegfx::fround( rCol.Green * 255.0 ) ) );
48 const sal_uInt8 nBlue ( sal::static_int_cast<sal_Int8>( basegfx::fround( rCol.Blue * 255.0 ) ) );
49 aBuf.append( sal_Unicode('#') );
50 if( nRed < 10 )
51 aBuf.append( sal_Unicode('0') );
52 aBuf.append( sal_Int32(nRed), 16 );
53 if( nGreen < 10 )
54 aBuf.append( sal_Unicode('0') );
55 aBuf.append( sal_Int32(nGreen), 16 );
56 if( nBlue < 10 )
57 aBuf.append( sal_Unicode('0') );
58 aBuf.append( sal_Int32(nBlue), 16 );
60 // TODO(F3): respect alpha transparency (polygons etc.)
61 OSL_ASSERT(rCol.Alpha == 1.0);
63 return aBuf.makeStringAndClear();
66 rtl::OUString pdfi::unitMMString( double fMM )
68 rtl::OUStringBuffer aBuf( 32 );
69 aBuf.append( rtl_math_round( fMM, 2, rtl_math_RoundingMode_Floor ) );
70 aBuf.appendAscii( "mm" );
72 return aBuf.makeStringAndClear();
75 rtl::OUString pdfi::convertPixelToUnitString( double fPix )
77 rtl::OUStringBuffer aBuf( 32 );
78 aBuf.append( rtl_math_round( convPx2mm( fPix ), 2, rtl_math_RoundingMode_Floor ) );
79 aBuf.appendAscii( "mm" );
81 return aBuf.makeStringAndClear();