1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: pdfihelper.cxx,v $
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>
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('#') );
51 aBuf
.append( sal_Unicode('0') );
52 aBuf
.append( sal_Int32(nRed
), 16 );
54 aBuf
.append( sal_Unicode('0') );
55 aBuf
.append( sal_Int32(nGreen
), 16 );
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();