diff options
Diffstat (limited to 'sc/source/filter/excel/fontbuff.cxx')
-rw-r--r-- | sc/source/filter/excel/fontbuff.cxx | 165 |
1 files changed, 165 insertions, 0 deletions
diff --git a/sc/source/filter/excel/fontbuff.cxx b/sc/source/filter/excel/fontbuff.cxx new file mode 100644 index 000000000000..26db50f0166f --- /dev/null +++ b/sc/source/filter/excel/fontbuff.cxx @@ -0,0 +1,165 @@ +/* -*- 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. + * + ************************************************************************/ + +// MARKER(update_precomp.py): autogen include statement, do not remove +#include "precompiled_sc.hxx" + +#include "lotfntbf.hxx" + +#include "scitems.hxx" +#include <editeng/cntritem.hxx> +#include <editeng/crsditem.hxx> +#include <editeng/eeitem.hxx> +#include <editeng/postitem.hxx> +#include <editeng/shdditem.hxx> +#include <editeng/escpitem.hxx> +#include <editeng/udlnitem.hxx> +#include <editeng/wghtitem.hxx> +#include <sfx2/printer.hxx> + +#include "attrib.hxx" +#include "document.hxx" +#include "global.hxx" +#include "docpool.hxx" +#include "patattr.hxx" +#include "ftools.hxx" + +const sal_uInt16 LotusFontBuffer::nSize = 8; + +void LotusFontBuffer::Fill( const sal_uInt8 nIndex, SfxItemSet& rItemSet ) +{ + sal_uInt8 nIntIndex = nIndex & 0x07; + + ENTRY* pAkt = pData + nIntIndex; + + if( pAkt->pFont ) + rItemSet.Put( *pAkt->pFont ); + + if( pAkt->pHeight ) + rItemSet.Put( *pAkt->pHeight ); + + if( pAkt->pColor ) + rItemSet.Put( *pAkt->pColor ); + + if( nIndex & 0x08 ) + { + SvxWeightItem aWeightItem( WEIGHT_BOLD, ATTR_FONT_WEIGHT ); + rItemSet.Put( aWeightItem ); + } + + if( nIndex & 0x10 ) + { + SvxPostureItem aAttr( ITALIC_NORMAL, ATTR_FONT_POSTURE ); + rItemSet.Put( aAttr ); + } + + FontUnderline eUnderline; + switch( nIndex & 0x60 ) // Bit 5+6 + { + case 0x60: + case 0x20: eUnderline = UNDERLINE_SINGLE; break; + case 0x40: eUnderline = UNDERLINE_DOUBLE; break; + default: eUnderline = UNDERLINE_NONE; + } + if( eUnderline != UNDERLINE_NONE ) + { + SvxUnderlineItem aUndItem( eUnderline, ATTR_FONT_UNDERLINE ); + rItemSet.Put( aUndItem ); + } +} + + +void LotusFontBuffer::SetName( const sal_uInt16 nIndex, const String& rName ) +{ + DBG_ASSERT( nIndex < nSize, "*LotusFontBuffer::SetName(): Array zu klein!" ); + if( nIndex < nSize ) + { + register ENTRY* pEntry = pData + nIndex; + pEntry->TmpName( rName ); + + if( pEntry->nType >= 0 ) + MakeFont( pEntry ); + } +} + + +void LotusFontBuffer::SetHeight( const sal_uInt16 nIndex, const sal_uInt16 nHeight ) +{ + DBG_ASSERT( nIndex < nSize, "*LotusFontBuffer::SetHeight(): Array zu klein!" ); + if( nIndex < nSize ) + pData[ nIndex ].Height( *( new SvxFontHeightItem( ( sal_uLong ) nHeight * 20, 100, ATTR_FONT_HEIGHT ) ) ); +} + + +void LotusFontBuffer::SetType( const sal_uInt16 nIndex, const sal_uInt16 nType ) +{ + DBG_ASSERT( nIndex < nSize, "*LotusFontBuffer::SetType(): Array zu klein!" ); + if( nIndex < nSize ) + { + register ENTRY* pEntry = pData + nIndex; + pEntry->Type( nType ); + + if( pEntry->pTmpName ) + MakeFont( pEntry ); + } +} + + +void LotusFontBuffer::MakeFont( ENTRY* pEntry ) +{ + FontFamily eFamily = FAMILY_DONTKNOW; + FontPitch ePitch = PITCH_DONTKNOW; + CharSet eCharSet = RTL_TEXTENCODING_DONTKNOW; + + switch( pEntry->nType ) + { + case 0x00: // Helvetica + eFamily = FAMILY_SWISS; + ePitch = PITCH_VARIABLE; + break; + case 0x01: // Times Roman + eFamily = FAMILY_ROMAN; + ePitch = PITCH_VARIABLE; + break; + case 0x02: // Courier + ePitch = PITCH_FIXED; + break; + case 0x03: // Symbol + eCharSet = RTL_TEXTENCODING_SYMBOL; + break; + } + + pEntry->pFont = new SvxFontItem( eFamily, *pEntry->pTmpName, EMPTY_STRING, ePitch, eCharSet, ATTR_FONT ); + + delete pEntry->pTmpName; + pEntry->pTmpName = NULL; +} + + + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |