diff options
Diffstat (limited to 'sd/source/core/drawdoc4.cxx')
-rw-r--r-- | sd/source/core/drawdoc4.cxx | 1463 |
1 files changed, 0 insertions, 1463 deletions
diff --git a/sd/source/core/drawdoc4.cxx b/sd/source/core/drawdoc4.cxx deleted file mode 100644 index 48b138ab8..000000000 --- a/sd/source/core/drawdoc4.cxx +++ /dev/null @@ -1,1463 +0,0 @@ -/* -*- 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_sd.hxx" - -#include <com/sun/star/style/XStyle.hpp> -#include <com/sun/star/container/XNameAccess.hpp> - -#include <tools/urlobj.hxx> -#include <sfx2/docfile.hxx> -#include <sfx2/dispatch.hxx> -#include "Outliner.hxx" -#include <comphelper/processfactory.hxx> -#include <editeng/outliner.hxx> - -#include "../ui/inc/DrawDocShell.hxx" -#include <editeng/eeitem.hxx> -#include <vcl/svapp.hxx> -#include <eetext.hxx> - -#include <editeng/akrnitem.hxx> - -#include <svx/svxids.hrc> -#include <svl/srchitem.hxx> -#include <editeng/lrspitem.hxx> -#include <editeng/ulspitem.hxx> -#include <editeng/lspcitem.hxx> -#include <editeng/adjitem.hxx> -#include <svx/dialogs.hrc> -#include <svx/dialmgr.hxx> // SVX_RESSTR -#include <editeng/bulitem.hxx> -#include <svx/xtable.hxx> -#include <svx/sxmsuitm.hxx> -#include <editeng/borderline.hxx> -#include <editeng/boxitem.hxx> -#include <svx/xit.hxx> -#include <svx/xlineit0.hxx> -#include <svx/sdshitm.hxx> -#include <svx/svdotext.hxx> -#include <svx/xfillit0.hxx> -#include <svx/sdshcitm.hxx> -#include <editeng/editstat.hxx> -#include <editeng/colritem.hxx> -#include <editeng/fhgtitem.hxx> -#include <editeng/wghtitem.hxx> -#include <editeng/postitem.hxx> -#include <editeng/crsditem.hxx> -#include <editeng/udlnitem.hxx> -#include <editeng/cntritem.hxx> -#include <editeng/emphitem.hxx> -#include <editeng/fontitem.hxx> -#include <editeng/shdditem.hxx> -#include <svx/xbtmpit.hxx> -#include <svx/xflhtit.hxx> -#include <svx/xflgrit.hxx> -#include <svx/xflclit.hxx> -#include <svx/xlnedcit.hxx> -#include <svx/xlnstcit.hxx> -#include <svx/xlnedwit.hxx> -#include <svx/xlnstwit.hxx> -#include <svx/xlnedit.hxx> -#include <editeng/charreliefitem.hxx> -#include <svx/xlnstit.hxx> -#include <svx/xlndsit.hxx> -#include <svx/xlnwtit.hxx> -#include <svx/xlnclit.hxx> -#include <svx/svditer.hxx> -#include <svx/svdogrp.hxx> -#include <tools/shl.hxx> -#include <editeng/numitem.hxx> -#include <editeng/editeng.hxx> -#include <editeng/unolingu.hxx> -#include <com/sun/star/linguistic2/XHyphenator.hpp> -#include <com/sun/star/lang/XMultiServiceFactory.hpp> -#include <svl/itempool.hxx> -#include <editeng/outlobj.hxx> -#include <sfx2/viewfrm.hxx> -#include <editeng/langitem.hxx> -#include <editeng/frmdiritem.hxx> - -#include "sdresid.hxx" -#include "drawdoc.hxx" -#include "sdpage.hxx" -#include "glob.hrc" -#include "glob.hxx" -#include "stlpool.hxx" -#include "helpids.h" -#include "sdiocmpt.hxx" -#include "shapelist.hxx" -#include <basegfx/point/b2dpoint.hxx> -#include <basegfx/polygon/b2dpolygon.hxx> -#include <svl/itemset.hxx> -#include "app.hrc" - -using ::rtl::OUString; -using namespace ::com::sun::star; -using namespace ::com::sun::star::uno; -using namespace ::com::sun::star::lang; -using namespace ::com::sun::star::style; -using namespace ::com::sun::star::container; -using namespace ::com::sun::star::linguistic2; -using namespace ::sd; - -/************************************************************************* -|* -|* CreateLayoutTemplates, Layoutvorlagen erzeugen -|* -|* Z.Zt. (31.03.95) speichert der StyleSheetPool nur diejenigen Sheets, die -|* ein ItemSet haben. Damit alle Sheets gespeichert werden, wird die ItemSet- -|* Erzeugung mit einem GetItemSet-Aufruf erzwungen. -|* Dies kann entfallen, sobald der Pool auch Sheets ohne ItemSet speichert. -|* -\************************************************************************/ - -void SdDrawDocument::CreateLayoutTemplates() -{ - SdStyleSheetPool* pSSPool = (SdStyleSheetPool*)GetStyleSheetPool(); - SfxStyleSheetBase* pSheet = NULL; - String aHelpFile; - String aStdName = String(SdResId(STR_STANDARD_STYLESHEET_NAME)); - - // ---- Standardvorlage ----------------------------------------------- - - // nicht benutzt, nicht benutzerdefiniert - // SB hatte wahrscheinlich Probleme mit SFXSTYLEBIT_AUTO, da dann gar nichts - // mehr im Gestalter angezeigt wird. Dieses Problem ist zu 364 j behoben worden - // sal_uInt16 nMask = SFXSTYLEBIT_ALL & ~(SFXSTYLEBIT_USED | SFXSTYLEBIT_USERDEF); - sal_uInt16 nMask = SFXSTYLEBIT_AUTO; - - String aName(aStdName); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetHelpId( aHelpFile, HID_STANDARD_STYLESHEET_NAME ); - SfxItemSet& rISet = pSheet->GetItemSet(); - SfxItemPool* pPool = rISet.GetPool(); - - String aNullStr; - - ::basegfx::B2DPolyPolygon aNullPolyPolygon; - Color aNullCol(RGB_Color(COL_DEFAULT_SHAPE_STROKE)); - - XDash aNullDash; - XGradient aNullGrad(aNullCol,RGB_Color(COL_WHITE)); - aNullGrad.SetStartIntens( 100 ); - aNullGrad.SetEndIntens( 100 ); - XHatch aNullHatch(aNullCol); - - // Linienattribute (Extended OutputDevice) - rISet.Put(XLineStyleItem(XLINE_SOLID)); - rISet.Put(XLineColorItem(String(), RGB_Color(COL_DEFAULT_SHAPE_STROKE))); - rISet.Put(XLineWidthItem(0)); - rISet.Put(XLineDashItem(pPool,aNullDash)); - rISet.Put(XLineStartItem(pPool,aNullPolyPolygon)); - rISet.Put(XLineEndItem(pPool,aNullPolyPolygon)); - rISet.Put(XLineStartWidthItem(200)); - rISet.Put(XLineEndWidthItem(200)); - rISet.Put(XLineStartCenterItem()); - rISet.Put(XLineEndCenterItem()); - rISet.Put(SdrTextHorzAdjustItem(SDRTEXTHORZADJUST_BLOCK)); - - // Fuellattribute (Extended OutputDevice) - rISet.Put(XFillStyleItem(XFILL_SOLID)); - rISet.Put(XFillColorItem(String(), RGB_Color(COL_DEFAULT_SHAPE_FILLING))); - - rISet.Put(XFillGradientItem(pPool,aNullGrad)); - rISet.Put(XFillHatchItem(pPool,aNullHatch)); - Size aNullSize( 32, 32 ); - Color aNullColor( COL_WHITE ); - Bitmap aNullBmp( aNullSize, 8 ); - aNullBmp.Erase( aNullColor ); - rISet.Put(XFillBitmapItem(pPool,aNullBmp)); - - // Schattenattribute (Drawing Engine) - rISet.Put(SdrShadowItem(sal_False)); - rISet.Put(SdrShadowColorItem(aNullStr, RGB_Color(COL_GRAY))); - rISet.Put(SdrShadowXDistItem(200)); // 3 mm Schattendistanz - rISet.Put(SdrShadowYDistItem(200)); - - Font aLatinFont, aCJKFont, aCTLFont; - - getDefaultFonts( aLatinFont, aCJKFont, aCTLFont ); - - SvxFontItem aSvxFontItem( aLatinFont.GetFamily(), aLatinFont.GetName(), aLatinFont.GetStyleName(), aLatinFont.GetPitch(), - aLatinFont.GetCharSet(), EE_CHAR_FONTINFO ); - - SvxFontItem aSvxFontItemCJK( aCJKFont.GetFamily(), aCJKFont.GetName(), aCJKFont.GetStyleName(), aCJKFont.GetPitch(), - aCJKFont.GetCharSet(), EE_CHAR_FONTINFO_CJK ); - - SvxFontItem aSvxFontItemCTL( aCTLFont.GetFamily(), aCTLFont.GetName(), aCTLFont.GetStyleName(), aCTLFont.GetPitch(), - aCTLFont.GetCharSet(), EE_CHAR_FONTINFO_CTL ); - - rISet.Put( aSvxFontItem ); - rISet.Put( aSvxFontItemCJK ); - rISet.Put( aSvxFontItemCTL ); - - rISet.Put( SvxFontHeightItem( 635, 100, EE_CHAR_FONTHEIGHT ) ); // sj: (i33745) changed default from 24 to 18 pt - rISet.Put( SvxFontHeightItem( 635, 100, EE_CHAR_FONTHEIGHT_CJK ) ); // 18 pt - rISet.Put( SvxFontHeightItem( convertFontHeightToCTL( 635 ), 100, EE_CHAR_FONTHEIGHT_CTL ) ); // 18 pt - - rISet.Put( SvxWeightItem( WEIGHT_NORMAL, EE_CHAR_WEIGHT ) ); - rISet.Put( SvxWeightItem( WEIGHT_NORMAL, EE_CHAR_WEIGHT_CJK ) ); - rISet.Put( SvxWeightItem( WEIGHT_NORMAL, EE_CHAR_WEIGHT_CTL ) ); - - rISet.Put( SvxPostureItem( ITALIC_NONE, EE_CHAR_ITALIC ) ); - rISet.Put( SvxPostureItem( ITALIC_NONE, EE_CHAR_ITALIC_CJK ) ); - rISet.Put( SvxPostureItem( ITALIC_NONE, EE_CHAR_ITALIC_CTL ) ); - - rISet.Put(SvxContourItem(sal_False, EE_CHAR_OUTLINE )); - rISet.Put(SvxShadowedItem(sal_False, EE_CHAR_SHADOW )); - rISet.Put(SvxUnderlineItem(UNDERLINE_NONE, EE_CHAR_UNDERLINE)); - rISet.Put(SvxOverlineItem(UNDERLINE_NONE, EE_CHAR_OVERLINE)); - rISet.Put(SvxCrossedOutItem(STRIKEOUT_NONE, EE_CHAR_STRIKEOUT )); - rISet.Put(SvxEmphasisMarkItem(EMPHASISMARK_NONE, EE_CHAR_EMPHASISMARK)); - rISet.Put(SvxCharReliefItem(RELIEF_NONE, EE_CHAR_RELIEF)); - rISet.Put(SvxColorItem(Color(COL_AUTO), EE_CHAR_COLOR )); - - // Absatzattribute (Edit Engine) - rISet.Put(SvxLRSpaceItem(EE_PARA_LRSPACE)); - rISet.Put(SvxULSpaceItem(EE_PARA_ULSPACE)); - - rISet.Put( SdrTextLeftDistItem( 250 ) ); // sj: (i33745) using text frame distances seems to be a better default - rISet.Put( SdrTextRightDistItem( 250 ) ); - rISet.Put( SdrTextUpperDistItem( 125 ) ); - rISet.Put( SdrTextLowerDistItem( 125 ) ); - - rISet.Put( SvxLineSpacingItem( LINE_SPACE_DEFAULT_HEIGHT, EE_PARA_SBL ) ); - - // #i16874# enable kerning by default but only for new documents - rISet.Put( SvxAutoKernItem( sal_True, EE_CHAR_PAIRKERNING ) ); - - // Bullet - // BulletItem und BulletFont fuer Titel und Gliederung - SvxBulletItem aBulletItem(EE_PARA_BULLET); - // die sind in allen Ebenen identisch - aBulletItem.SetStyle(BS_BULLET); - aBulletItem.SetStart(1); - aBulletItem.SetScale(45); // in Prozent - - Font aBulletFont( pSSPool->GetBulletFont() ); - - aBulletFont.SetSize(Size(0,635)); // sj: (i33745) changed default from 24 to 18 pt - - aBulletItem.SetFont(aBulletFont); - aBulletItem.SetSymbol( 0x25CF ); // Punkt - rISet.Put(aBulletItem); - - // Neues BulletItem - pSSPool->PutNumBulletItem( pSheet, aBulletFont ); - - SfxItemSet* pISet = NULL; - - // ---- Objekt mit Pfeilspitze ---------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_OBJWITHARROW)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_OBJWITHARROW ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_SOLID)); - pISet->Put(XLineColorItem(String(), RGB_Color(COL_BLACK))); - pISet->Put(XLineWidthItem(150)); - - ::basegfx::B2DPolygon aArrow; - aArrow.append(::basegfx::B2DPoint(10.0, 0.0)); - aArrow.append(::basegfx::B2DPoint(0.0, 30.0)); - aArrow.append(::basegfx::B2DPoint(20.0, 30.0)); - aArrow.setClosed(true); - pISet->Put(XLineStartItem(SVX_RESSTR(RID_SVXSTR_ARROW),::basegfx::B2DPolyPolygon(aArrow))); - - pISet->Put(XLineStartWidthItem(700)); - pISet->Put(XLineEndWidthItem(300)); - pISet->Put(XLineStartCenterItem(sal_True)); - - // ---- Objekt mit Schatten ------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_OBJWITHSHADOW)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_OBJWITHSHADOW ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(SdrShadowItem(sal_True)); - pISet->Put(SdrShadowColorItem(aNullStr, RGB_Color(COL_GRAY))); - pISet->Put(SdrShadowXDistItem(200)); // 3 mm Schattendistanz - pISet->Put(SdrShadowYDistItem(200)); - - // ---- Objekt ohne F�llung ------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_OBJWITHOUTFILL)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_OBJWITHOUTFILL ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XFillStyleItem(XFILL_NONE)); - pISet->Put(XLineColorItem(String(), RGB_Color(COL_BLACK))); - - // ---- Text ---------------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_TEXT)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_TEXT ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_NONE)); - - // ---- Textk�rper ---------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_TEXTBODY)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_TEXTBODY ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_NONE)); - - pISet->Put(SvxFontHeightItem(564, 100, EE_CHAR_FONTHEIGHT)); // 16 pt - - // ---- Textk�rper mit Blocksatz -------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_TEXTBODY_JUSTIFY)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_TEXTBODY_JUSTIFY ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_NONE)); - - pISet->Put(SvxAdjustItem(SVX_ADJUST_BLOCK, EE_PARA_JUST )); - - // ---- Textkoerper mit Einzug ----------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_TEXTBODY_INDENT)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_TEXTBODY_INDENT ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_NONE)); - - SvxLRSpaceItem aLRSpaceItem( EE_PARA_LRSPACE ); - aLRSpaceItem.SetTxtFirstLineOfst(600); // Erstzeileneinzug 6mm, rechts 0 - pISet->Put(aLRSpaceItem); - - // ---- Titel --------------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_TITLE)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_TITLE ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_NONE)); - - pISet->Put(SvxFontHeightItem(1551, 100, EE_CHAR_FONTHEIGHT )); // 44 pt - - // ---- Titel1 -------------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_TITLE1)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_TITLE1 ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_SOLID)); - pISet->Put(XFillColorItem(String(), RGB_Color(COL_CYAN))); - - pISet->Put(SdrShadowItem(sal_True)); - pISet->Put(SdrShadowColorItem(aNullStr, RGB_Color(COL_GRAY))); - pISet->Put(SdrShadowXDistItem(200)); // 2 mm Schattendistanz - pISet->Put(SdrShadowYDistItem(200)); - - pISet->Put(SvxFontHeightItem(846, 100, EE_CHAR_FONTHEIGHT )); // 24 pt - - pISet->Put(SvxAdjustItem(SVX_ADJUST_CENTER, EE_PARA_JUST )); - - // ---- Titel2 -------------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_TITLE2)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_TITLE2 ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineWidthItem(50)); - - // Farbe nicht aus der Farbtabelle holen, denn da kann diese Farbe - // geloescht oder veraendert sein - Color aOrange4(255, 204, 153); - pISet->Put(XFillColorItem(String(), aOrange4)); - - pISet->Put(SdrShadowItem(sal_True)); - pISet->Put(SdrShadowColorItem(aNullStr, RGB_Color(COL_GRAY))); - pISet->Put(SdrShadowXDistItem(200)); // 2 mm Schattendistanz - pISet->Put(SdrShadowYDistItem(200)); - - pISet->Put(SvxFontHeightItem(1270, 100, EE_CHAR_FONTHEIGHT )); // 36 pt - - SvxLRSpaceItem aLRSpItem( 200, 200, 0, 0, EE_PARA_LRSPACE); - pISet->Put( aLRSpItem ); // Erstzeileneinzug 0 mm, links und rechts 2 mm - - pISet->Put(SvxULSpaceItem(100, 100, EE_PARA_ULSPACE )); // Absatzrand oben/unten 1 mm - - pISet->Put(SvxAdjustItem(SVX_ADJUST_CENTER, EE_PARA_JUST )); - - // ---- Ueberschrift --------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_HEADLINE)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_HEADLINE ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_NONE)); - - pISet->Put(SvxFontHeightItem(846, 100, EE_CHAR_FONTHEIGHT )); // 24 pt - - pISet->Put(SvxULSpaceItem(420, 210, EE_PARA_ULSPACE )); // Absatzrand oben 4,2 mm, - // unten 2,1 mm - - // ---- Ueberschrift1 -------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_HEADLINE1)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_HEADLINE1 ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_NONE)); - - pISet->Put(SvxWeightItem(WEIGHT_BOLD, EE_CHAR_WEIGHT )); - - pISet->Put(SvxFontHeightItem(635, 100, EE_CHAR_FONTHEIGHT )); // 18 pt - - pISet->Put(SvxULSpaceItem(420, 210, EE_PARA_ULSPACE )); // Absatzrand oben 4,2 mm, - // unten 2,1 mm - - // ---- Ueberschrift2 -------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_HEADLINE2)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_HEADLINE2 ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XLineStyleItem(XLINE_NONE)); - pISet->Put(XFillStyleItem(XFILL_NONE)); - - pISet->Put(SvxPostureItem(ITALIC_NORMAL, EE_CHAR_ITALIC )); - pISet->Put(SvxWeightItem(WEIGHT_BOLD, EE_CHAR_WEIGHT)); - - pISet->Put(SvxFontHeightItem(494, 100, EE_CHAR_FONTHEIGHT )); // 14 pt - - pISet->Put(SvxULSpaceItem(420, 210, EE_PARA_ULSPACE )); // Absatzrand oben 4,2 mm, - // unten 2,1 mm - - // ---- Bemassung -------------------------------------------------- - - aName = String(SdResId(STR_POOLSHEET_MEASURE)); - pSheet = &(pSSPool->Make(aName, SD_STYLE_FAMILY_GRAPHICS, nMask)); - pSheet->SetParent(aStdName); - pSheet->SetHelpId( aHelpFile, HID_POOLSHEET_MEASURE ); - pISet = &pSheet->GetItemSet(); - - pISet->Put(XFillStyleItem(XFILL_NONE)); - pISet->Put(XLineColorItem(String(), RGB_Color(COL_BLACK))); - - pISet->Put(SvxFontHeightItem(423, 100, EE_CHAR_FONTHEIGHT )); // 12 pt - - pISet->Put(XLineStartItem(SVX_RESSTR(RID_SVXSTR_ARROW),::basegfx::B2DPolyPolygon(aArrow))); - pISet->Put(XLineStartWidthItem(200)); - pISet->Put(XLineEndItem(SVX_RESSTR(RID_SVXSTR_ARROW),::basegfx::B2DPolyPolygon(aArrow))); - pISet->Put(XLineEndWidthItem(200)); - pISet->Put(XLineStyleItem(XLINE_SOLID)); - pISet->Put(SdrMeasureShowUnitItem(true)); - - // Praesentationsvorlagen fuer das Standardlayout erzeugen - String aPrefix = String(SdResId(STR_LAYOUT_DEFAULT_NAME)); - pSSPool->CreateLayoutStyleSheets(aPrefix); -} - -static Any implMakeSolidCellStyle( SdStyleSheetPool* pSSPool, const OUString& rName, const OUString rParent, const Color& rColor ) -{ - SfxStyleSheetBase* pSheet = &(pSSPool->Make(rName, SD_STYLE_FAMILY_CELL, SFXSTYLEBIT_AUTO)); - pSheet->SetParent(rParent); - SfxItemSet* pISet = &pSheet->GetItemSet(); - pISet->Put(XFillStyleItem(XFILL_SOLID)); - pISet->Put(XFillColorItem(String(), rColor)); - - return Any( Reference< XStyle >( static_cast< XWeak* >( pSheet ), UNO_QUERY ) ); -} - -static void implCreateTableTemplate( const Reference< XNameContainer >& xTableFamily, const OUString& rName, const Any& rBody, const Any& rHeading, const Any& rBanding ) -{ - if( xTableFamily.is() ) try - { - if( !xTableFamily->hasByName( OUString( rName ) ) ) - { - Reference< XSingleServiceFactory > xFactory( xTableFamily, UNO_QUERY_THROW ); - Reference< XNameReplace > xDefaultTableStyle( xFactory->createInstance(), UNO_QUERY_THROW ); - xTableFamily->insertByName( OUString( rName ), Any( xDefaultTableStyle ) ); - - xDefaultTableStyle->replaceByName( OUString( RTL_CONSTASCII_USTRINGPARAM("body") ), rBody ); - xDefaultTableStyle->replaceByName( OUString( RTL_CONSTASCII_USTRINGPARAM("odd-rows") ), rBanding ); - xDefaultTableStyle->replaceByName( OUString( RTL_CONSTASCII_USTRINGPARAM("odd-columns") ), rBanding ); - xDefaultTableStyle->replaceByName( OUString( RTL_CONSTASCII_USTRINGPARAM("first-row") ), rHeading ); - xDefaultTableStyle->replaceByName( OUString( RTL_CONSTASCII_USTRINGPARAM("first-column") ), rHeading ); - xDefaultTableStyle->replaceByName( OUString( RTL_CONSTASCII_USTRINGPARAM("last-row") ), rHeading ); - xDefaultTableStyle->replaceByName( OUString( RTL_CONSTASCII_USTRINGPARAM("last-column") ), rHeading ); - } - } - catch( Exception& ) - { - OSL_FAIL("sd::implCreateTableTemplate(), exception caught!"); - } -} - -void SdDrawDocument::CreateDefaultCellStyles() -{ - SdStyleSheetPool* pSSPool = static_cast< SdStyleSheetPool* >(GetStyleSheetPool()); - SfxStyleSheetBase* pSheet = NULL; - String aHelpFile; - - const OUString sFamilyName( RTL_CONSTASCII_USTRINGPARAM( "table" ) ); - Reference< XNameContainer > xTableFamily( pSSPool->getByName( sFamilyName ), UNO_QUERY ); - - // ---- Default ----------------------------------------------- - - sal_uInt16 nMask = SFXSTYLEBIT_AUTO; - - OUString aDefaultCellStyleName( RTL_CONSTASCII_USTRINGPARAM("default") ); - - pSheet = &(pSSPool->Make(aDefaultCellStyleName, SD_STYLE_FAMILY_CELL, nMask)); - pSheet->SetHelpId( aHelpFile, HID_SD_CELL_STYLE_DEFAULT ); - SfxItemSet& rISet = pSheet->GetItemSet(); - - String aNullStr; - - Color aNullCol(RGB_Color(COL_BLACK)); - - XDash aNullDash; - XGradient aNullGrad(aNullCol,RGB_Color(COL_WHITE)); - aNullGrad.SetStartIntens( 100 ); - aNullGrad.SetEndIntens( 100 ); - XHatch aNullHatch(aNullCol); - - rISet.Put(XFillStyleItem(XFILL_SOLID)); - rISet.Put(XFillColorItem(String(), RGB_Color(0x00ccccff))); - - Font aLatinFont, aCJKFont, aCTLFont; - - getDefaultFonts( aLatinFont, aCJKFont, aCTLFont ); - - SvxFontItem aSvxFontItem( aLatinFont.GetFamily(), aLatinFont.GetName(), aLatinFont.GetStyleName(), aLatinFont.GetPitch(), - aLatinFont.GetCharSet(), EE_CHAR_FONTINFO ); - - SvxFontItem aSvxFontItemCJK( aCJKFont.GetFamily(), aCJKFont.GetName(), aCJKFont.GetStyleName(), aCJKFont.GetPitch(), - aCJKFont.GetCharSet(), EE_CHAR_FONTINFO_CJK ); - - SvxFontItem aSvxFontItemCTL( aCTLFont.GetFamily(), aCTLFont.GetName(), aCTLFont.GetStyleName(), aCTLFont.GetPitch(), - aCTLFont.GetCharSet(), EE_CHAR_FONTINFO_CTL ); - - rISet.Put( aSvxFontItem ); - rISet.Put( aSvxFontItemCJK ); - rISet.Put( aSvxFontItemCTL ); - - rISet.Put( SvxFontHeightItem( 635, 100, EE_CHAR_FONTHEIGHT ) ); // sj: (i33745) changed default from 24 to 18 pt - rISet.Put( SvxFontHeightItem( 635, 100, EE_CHAR_FONTHEIGHT_CJK ) ); // 18 pt - rISet.Put( SvxFontHeightItem( convertFontHeightToCTL( 635 ), 100, EE_CHAR_FONTHEIGHT_CTL ) ); // 18 pt - - rISet.Put(SvxColorItem(Color(COL_AUTO), EE_CHAR_COLOR )); - - // Absatzattribute (Edit Engine) - rISet.Put(SvxLRSpaceItem(EE_PARA_LRSPACE)); - rISet.Put(SvxULSpaceItem(EE_PARA_ULSPACE)); - - rISet.Put( SdrTextLeftDistItem( 250 ) ); - rISet.Put( SdrTextRightDistItem( 250 ) ); - rISet.Put( SdrTextUpperDistItem( 130 ) ); - rISet.Put( SdrTextLowerDistItem( 130 ) ); - - rISet.Put( SvxLineSpacingItem( LINE_SPACE_DEFAULT_HEIGHT, EE_PARA_SBL ) ); - rISet.Put( SvxAutoKernItem( sal_True, EE_CHAR_PAIRKERNING ) ); - rISet.Put( SdrTextVertAdjustItem(SDRTEXTVERTADJUST_TOP) ); - rISet.Put( SdrTextHorzAdjustItem(SDRTEXTHORZADJUST_LEFT) ); - - Color aWhite( COL_WHITE ); - ::editeng::SvxBorderLine aBorderLine( &aWhite, 1, ::editeng::SOLID ); - - SvxBoxItem aBoxItem( SDRATTR_TABLE_BORDER ); - aBoxItem.SetLine( &aBorderLine, BOX_LINE_TOP ); - aBoxItem.SetLine( &aBorderLine, BOX_LINE_BOTTOM ); - aBoxItem.SetLine( &aBorderLine, BOX_LINE_LEFT ); - aBoxItem.SetLine( &aBorderLine, BOX_LINE_RIGHT ); - - rISet.Put( aBoxItem ); - - Any aDefaultCellStyle( Reference< XStyle >( static_cast< XWeak* >( pSheet ), UNO_QUERY ) ); - - // ---- default -------------------------------------------------- - - Any aGray1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("gray1") ), aDefaultCellStyleName, RGB_COLORDATA(230,230,230))); - Any aGray2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("gray2") ), aDefaultCellStyleName, RGB_COLORDATA(204,204,204))); - Any aGray3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("gray3") ), aDefaultCellStyleName, RGB_COLORDATA(179,179,179))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("default") ), aGray1, aGray3, aGray2 ); - - // ---- BW ------------------------------------------------ - - Any aBW1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("bw1") ), aDefaultCellStyleName, RGB_COLORDATA(255,255,255))); - Any aBW2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("bw2") ), aDefaultCellStyleName, RGB_COLORDATA(230,230,230))); - Any aBW3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("bw3") ), aDefaultCellStyleName, RGB_COLORDATA(0,0,0))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("bw") ), aBW1, aBW3, aBW2 ); - - // ---- Orange -------------------------------------------------- - - Any aOrange1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("orange1") ), aDefaultCellStyleName, RGB_COLORDATA(255,204,153))); - Any aOrange2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("orange2") ), aDefaultCellStyleName, RGB_COLORDATA(255,153,102))); - Any aOrange3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("orange3") ), aDefaultCellStyleName, RGB_COLORDATA(255,102,51))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("orange") ), aOrange1, aOrange3, aOrange2 ); - - // ---- Turquise -------------------------------------------------- - - Any aTurquise1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("turquise1") ), aDefaultCellStyleName, RGB_COLORDATA(71,184,184))); - Any aTurquise2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("turquise2") ), aDefaultCellStyleName, RGB_COLORDATA(51,163,163))); - Any aTurquise3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("turquise3") ), aDefaultCellStyleName, RGB_COLORDATA(25,138,138))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("turquise") ), aTurquise1, aTurquise3, aTurquise2 ); - - // ---- Gray ------------------------------------------------ - - Any aBlue1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("blue1") ), aDefaultCellStyleName, RGB_COLORDATA(153,204,255))); - Any aBlue2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("blue2") ), aDefaultCellStyleName, RGB_COLORDATA(0,153,255))); - Any aBlue3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("blue3") ), aDefaultCellStyleName, RGB_COLORDATA(0,102,204))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("blue")), aBlue1, aBlue3, aBlue2 ); - - // ---- Sun ------------------------------------------------ - - Any aSun1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("sun1") ), aDefaultCellStyleName, RGB_COLORDATA(230,230,255))); - Any aSun2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("sun2") ), aDefaultCellStyleName, RGB_COLORDATA(204,204,255))); - Any aSun3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("sun3") ), aDefaultCellStyleName, RGB_COLORDATA(153,153,255))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("sun") ), aSun1, aSun3, aSun2 ); - - // ---- Earth ---------------------------------------------- - - Any aEarth1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("earth1") ), aDefaultCellStyleName, RGB_COLORDATA(255,255,204))); - Any aEarth2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("earth2") ), aDefaultCellStyleName, RGB_COLORDATA(255,204,153))); - Any aEarth3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("earth3") ), aDefaultCellStyleName, RGB_COLORDATA(204,102,51))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("earth") ), aEarth1, aEarth3, aEarth2 ); - - // ---- Green ---------------------------------------------- - - Any aGreen1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("green1") ), aDefaultCellStyleName, RGB_COLORDATA(255,255,204))); - Any aGreen2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("green2") ), aDefaultCellStyleName, RGB_COLORDATA(148,189,94))); - Any aGreen3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("green3") ), aDefaultCellStyleName, RGB_COLORDATA(92,133,38))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("green") ), aGreen1, aGreen3, aGreen2 ); - - // ---- Seetang ---------------------------------------------- - - Any aSeetang1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("seetang1") ), aDefaultCellStyleName, RGB_COLORDATA(204,255,255))); - Any aSeetang2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("seetang2") ), aDefaultCellStyleName, RGB_COLORDATA(71,184,184))); - Any aSeetang3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("seetang3") ), aDefaultCellStyleName, RGB_COLORDATA(51,163,163))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("seetang") ), aSeetang1, aSeetang3, aSeetang2 ); - - // ---- LightBlue ---------------------------------------------- - - Any aLightBlue1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("lightblue1") ), aDefaultCellStyleName, RGB_COLORDATA(255,255,255))); - Any aLightBlue2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("lightblue2") ), aDefaultCellStyleName, RGB_COLORDATA(230,230,255))); - Any aLightBlue3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("lightblue3") ), aDefaultCellStyleName, RGB_COLORDATA(153,153,204))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("lightblue") ), aLightBlue1, aLightBlue3, aLightBlue2 ); - - // ---- Yellow ---------------------------------------------- - - Any aYellow1( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("yellow1") ), aDefaultCellStyleName, RGB_COLORDATA(255,255,204))); - Any aYellow2( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("yellow2") ), aDefaultCellStyleName, RGB_COLORDATA(255,255,153))); - Any aYellow3( implMakeSolidCellStyle( pSSPool, OUString( RTL_CONSTASCII_USTRINGPARAM("yellow3") ), aDefaultCellStyleName, RGB_COLORDATA(255,204,153))); - - implCreateTableTemplate( xTableFamily, OUString(RTL_CONSTASCII_USTRINGPARAM("yellow") ), aYellow1, aYellow3, aYellow2 ); -} - -/************************************************************************* -|* -|* Anzahl der Seiten, die eine masterPage referenzieren -|* -\************************************************************************/ - -sal_uInt16 SdDrawDocument::GetMasterPageUserCount(SdrPage* pMaster) const -{ - sal_uInt16 nResult = 0; - sal_uInt16 nPage; - sal_uInt16 nPageCount = GetPageCount(); - - for (nPage = 0; nPage < nPageCount; nPage++) - { - const SdrPage* pPage = GetPage(nPage); - - if(pPage->TRG_HasMasterPage()) - { - if(&(pPage->TRG_GetMasterPage()) == pMaster) - { - nResult++; - } - } - } - return nResult; -} - - -/************************************************************************* -|* -|* OnlineSpelling im Hintergrund beenden -|* -\************************************************************************/ - -void SdDrawDocument::StopOnlineSpelling() -{ - if (mpOnlineSpellingTimer && mpOnlineSpellingTimer->IsActive()) - { - mpOnlineSpellingTimer->Stop(); - } - - delete mpOnlineSpellingTimer; - mpOnlineSpellingTimer = NULL; - - delete mpOnlineSpellingList; - mpOnlineSpellingList = NULL; -} - -/************************************************************************* -|* -|* OnlineSpelling im Hintergrund starten -|* -\************************************************************************/ - -void SdDrawDocument::StartOnlineSpelling(sal_Bool bForceSpelling) -{ - if (mbOnlineSpell && (bForceSpelling || mbInitialOnlineSpellingEnabled) && - mpDocSh && !mpDocSh->IsReadOnly() ) - { - StopOnlineSpelling(); - - ::sd::Outliner* pOutl = GetInternalOutliner(sal_True); - - Reference< XSpellChecker1 > xSpellChecker( LinguMgr::GetSpellChecker() ); - if ( xSpellChecker.is() ) - pOutl->SetSpeller( xSpellChecker ); - - Reference< XHyphenator > xHyphenator( LinguMgr::GetHyphenator() ); - if( xHyphenator.is() ) - pOutl->SetHyphenator( xHyphenator ); - - pOutl->SetDefaultLanguage( meLanguage ); - - mpOnlineSpellingList = new ShapeList; - sal_uInt16 nPage; - - for ( nPage = 0; nPage < GetPageCount(); nPage++ ) - { - // Alle Pages durchsuchen - FillOnlineSpellingList((SdPage*) GetPage(nPage)); - } - - for (nPage = 0; nPage < GetMasterPageCount(); nPage++) - { - // Alle MasterPages durchsuchen - FillOnlineSpellingList((SdPage*) GetMasterPage(nPage)); - } - - mpOnlineSpellingList->seekShape(0); - mpOnlineSpellingTimer = new Timer(); - mpOnlineSpellingTimer->SetTimeoutHdl( LINK(this, SdDrawDocument, OnlineSpellingHdl) ); - mpOnlineSpellingTimer->SetTimeout(250); - mpOnlineSpellingTimer->Start(); - } -} - -/************************************************************************* -|* -|* OnlineSpelling-Liste fuellen -|* -\************************************************************************/ - -void SdDrawDocument::FillOnlineSpellingList(SdPage* pPage) -{ - SdrObject* pObj = NULL; - SdrObjListIter aIter(*pPage, IM_FLAT); - - while (aIter.IsMore()) - { - pObj = aIter.Next(); - - if( !pObj ) - continue; - - if (pObj->GetOutlinerParaObject()) - { - // Textobjekt gefunden - mpOnlineSpellingList->addShape(*pObj); - } - else if (pObj->GetObjIdentifier() == OBJ_GRUP) - { - // Gruppenobjekt gefunden - SdrObjListIter aGroupIter(*((SdrObjGroup*)pObj)->GetSubList(), - IM_DEEPNOGROUPS); - - sal_Bool bSubTextObjFound = sal_False; - - while (aGroupIter.IsMore() && !bSubTextObjFound) - { - if (aGroupIter.Next()->GetOutlinerParaObject()) - { - // Textobjekt im Gruppenobjekt gefunden - bSubTextObjFound = sal_True; - } - } - - if (bSubTextObjFound) - { - mpOnlineSpellingList->addShape(*pObj); - } - } - } -} - -/************************************************************************* -|* -|* OnlineSpelling im Hintergrund -|* -\************************************************************************/ - -IMPL_LINK(SdDrawDocument, OnlineSpellingHdl, Timer*, EMPTYARG ) -{ - if (mpOnlineSpellingList!=NULL - && ( !mbOnlineSpell || mpOnlineSpellingList->hasMore())) - { - /********************************************************************** - * Naechstes Objekt spellen - **********************************************************************/ - SdrObject* pObj = mpOnlineSpellingList->getNextShape(); - - if (pObj) - { - if (pObj->GetOutlinerParaObject() && pObj->ISA(SdrTextObj)) - { - // Textobjekt spellen - SpellObject((SdrTextObj*) pObj); - } - else if (pObj->GetObjIdentifier() == OBJ_GRUP) - { - // Gruppenobjekt gefunden - SdrObjListIter aGroupIter(*((SdrObjGroup*)pObj)->GetSubList(), - IM_DEEPNOGROUPS); - - SdrObject* pSubObj = NULL; - - while (aGroupIter.IsMore()) - { - pSubObj = aGroupIter.Next(); - - if (pSubObj->GetOutlinerParaObject() && pSubObj->ISA(SdrTextObj)) - { - // Textobjekt im Gruppenobjekt gefunden - SpellObject((SdrTextObj*) pSubObj); - } - } - } - } - - // Weitersuchen - mpOnlineSpellingTimer->Start(); - } - else - { - // Spelling wurde initial durchgefuehrt - mbInitialOnlineSpellingEnabled = sal_False; - - // Suche beenden - StopOnlineSpelling(); - - delete mpOnlineSearchItem; - mpOnlineSearchItem = NULL; - } - - return(0); -} - -/************************************************************************* -|* -|* Objekt spellen (fuer OnlineSpelling) -|* -\************************************************************************/ - -void SdDrawDocument::SpellObject(SdrTextObj* pObj) -{ - if (pObj && pObj->GetOutlinerParaObject() /* && pObj != pView->GetTextEditObject() */) - { - mbHasOnlineSpellErrors = sal_False; - ::sd::Outliner* pOutl = GetInternalOutliner(sal_True); - pOutl->SetUpdateMode(sal_True); - Link aEvtHdl = pOutl->GetStatusEventHdl(); - pOutl->SetStatusEventHdl(LINK(this, SdDrawDocument, OnlineSpellEventHdl)); - - sal_uInt16 nOldOutlMode = pOutl->GetMode(); - sal_uInt16 nOutlMode = OUTLINERMODE_TEXTOBJECT; - if (((SdrTextObj*) pObj)->GetObjInventor() == SdrInventor && - ((SdrTextObj*) pObj)->GetObjIdentifier() == OBJ_OUTLINETEXT) - { - nOutlMode = OUTLINERMODE_OUTLINEOBJECT; - } - pOutl->Init( nOutlMode ); - - // Text in den Outliner setzen - pOutl->SetText(*((SdrTextObj*) pObj)->GetOutlinerParaObject()); - - if (!mpOnlineSearchItem || pOutl->HasText(*mpOnlineSearchItem)) - { - // Spelling - pOutl->CompleteOnlineSpelling(); - - if (mbHasOnlineSpellErrors) - { - sd::ModifyGuard aGuard( this ); - SdrModel* pModel = pObj->GetModel(); - bool bLock = sal_False; - if ( pModel ) - { - bLock = pModel->isLocked(); - pModel->setLock(true); - } - // taking text from the outliner - ((SdrTextObj*) pObj)->SetOutlinerParaObject( pOutl->CreateParaObject() ); - - pObj->BroadcastObjectChange(); - if ( pModel ) - pModel->setLock(bLock); - } - } - - pOutl->SetStatusEventHdl(aEvtHdl); - pOutl->SetUpdateMode(sal_False); - pOutl->Init( nOldOutlMode ); - mbHasOnlineSpellErrors = sal_False; - } -} - -/************************************************************************* -|* -|* Objekt wurde ins Model eingefuegt -|* -\************************************************************************/ -void SdDrawDocument::InsertObject(SdrObject* pObj, SdPage* /*pPage*/) -{ - if(mpOnlineSpellingList && pObj) - { - if (pObj->GetOutlinerParaObject() || (pObj->GetObjIdentifier() == OBJ_GRUP)) - { - // Objekt in OnlineSpelling-Liste aufnehmen - mpOnlineSpellingList->addShape(*pObj); - } - } -} - -/************************************************************************* -|* -|* Objekt wurde aus dem Model entfernt -|* -\************************************************************************/ -void SdDrawDocument::RemoveObject(SdrObject* pObj, SdPage* /*pPage*/) -{ - if(mpOnlineSpellingList && pObj) - { - if (pObj->GetOutlinerParaObject() || (pObj->GetObjIdentifier() == OBJ_GRUP)) - { - // Objekt in OnlineSpelling-Liste durch NULL-Pointer ersetzt - mpOnlineSpellingList->removeShape(*pObj); - } - } -} - -/************************************************************************* -|* -|* Callback fuer ExecuteSpellPopup() -|* -\************************************************************************/ -IMPL_LINK(SdDrawDocument, OnlineSpellEventHdl, EditStatus*, pEditStat) -{ - sal_uLong nStat = pEditStat->GetStatusWord(); - mbHasOnlineSpellErrors = (nStat & EE_STAT_WRONGWORDCHANGED) != 0; - - return(0); -} - -/************************************************************************* -|* -|* Callback fuer ExecuteSpellPopup() -|* -\************************************************************************/ - -// removed link and replaced with Imp method -void SdDrawDocument::ImpOnlineSpellCallback(SpellCallbackInfo* pInfo, SdrObject* pObj, SdrOutliner* pOutl) -{ - delete mpOnlineSearchItem; - mpOnlineSearchItem = NULL; - - sal_uInt16 nCommand = pInfo->nCommand; - - if (nCommand == SPELLCMD_IGNOREWORD - // restart when add to dictionary takes place, too. - || nCommand == SPELLCMD_ADDTODICTIONARY) - { - if(pObj && pOutl && pObj->ISA(SdrTextObj)) - { - sal_Bool bModified(IsChanged()); - ((SdrTextObj*)pObj)->SetOutlinerParaObject(pOutl->CreateParaObject()); - SetChanged(bModified); - pObj->BroadcastObjectChange(); - } - - mpOnlineSearchItem = new SvxSearchItem( SID_SEARCH_ITEM ); - mpOnlineSearchItem->SetSearchString(pInfo->aWord); - StartOnlineSpelling(); - } - else if (nCommand == SPELLCMD_STARTSPELLDLG) - { - SfxViewFrame::Current()->GetDispatcher()->Execute( SID_SPELL_DIALOG, - SFX_CALLMODE_ASYNCHRON ); - } -} - -/************************************************************************* -|* -|* Eindeutige Namen der StandardLayer durch sprachabhaengige Namen ersetzen -|* -\************************************************************************/ -void SdDrawDocument::RestoreLayerNames() -{ - SdrLayerAdmin& rLayerAdmin = GetLayerAdmin(); - sal_uInt16 nLayerCount = rLayerAdmin.GetLayerCount(); - - for (sal_uInt16 nLayer = 0; nLayer < nLayerCount; nLayer++) - { - SdrLayer* pLayer = rLayerAdmin.GetLayer(nLayer); - - if (pLayer) - { - String aLayerName(pLayer->GetName()); - - if (aLayerName.EqualsAscii( "LAYER_LAYOUT" )) - { - pLayer->SetName(String(SdResId(STR_LAYER_LAYOUT))); - } - else if (aLayerName.EqualsAscii( "LAYER_BCKGRND" )) - { - pLayer->SetName(String(SdResId(STR_LAYER_BCKGRND))); - } - else if (aLayerName.EqualsAscii( "LAYER_BACKGRNDOBJ" )) - { - pLayer->SetName(String(SdResId(STR_LAYER_BCKGRNDOBJ))); - } - else if (aLayerName.EqualsAscii( "LAYER_CONTROLS" )) - { - pLayer->SetName(String(SdResId(STR_LAYER_CONTROLS))); - } - else if (aLayerName.EqualsAscii( "LAYER_MEASURELINES" )) - { - pLayer->SetName(String(SdResId(STR_LAYER_MEASURELINES))); - } - } - } -} - -/************************************************************************* -|* -|* Formatierte Seitennummer zurueckgeben (1, I, i, a, usw.) -|* -\************************************************************************/ - -String SdDrawDocument::CreatePageNumValue(sal_uInt16 nNum) const -{ - String aPageNumValue; - sal_Bool bUpper = sal_False; - - switch (mePageNumType) - { - case SVX_CHARS_UPPER_LETTER: - aPageNumValue += (sal_Unicode)(char)((nNum - 1) % 26 + 'A'); - break; - case SVX_CHARS_LOWER_LETTER: - aPageNumValue += (sal_Unicode)(char)((nNum - 1) % 26 + 'a'); - break; - case SVX_ROMAN_UPPER: - bUpper = sal_True; - case SVX_ROMAN_LOWER: - aPageNumValue += SvxNumberFormat::CreateRomanString(nNum, bUpper); - break; - case SVX_NUMBER_NONE: - aPageNumValue.Erase(); - aPageNumValue += sal_Unicode(' '); - break; - default: - aPageNumValue += String::CreateFromInt32( (sal_Int32)nNum ); - } - - return(aPageNumValue); -} - - - -/************************************************************************* -|* -|* Layout-Template umbenennen -|* Zu beachten ist, das rOldLayoutName im Gegensatz zu rNewName den -|* kompletten Layout(!)-Namen enthaelt (inkl. ~LT~)! -|* -\************************************************************************/ - -void SdDrawDocument::RenameLayoutTemplate(const String& rOldLayoutName, const String& rNewName) -{ - String aOldName(rOldLayoutName); - sal_uInt16 nPos = aOldName.SearchAscii( SD_LT_SEPARATOR ); - - // erase everything after '~LT~' - aOldName.Erase(nPos + sizeof(SD_LT_SEPARATOR) - 1 ); - sal_uInt16 nLen = aOldName.Len(); - - std::vector<StyleReplaceData> aReplList; - SfxStyleSheetIterator aIter(mxStyleSheetPool.get(), SD_STYLE_FAMILY_MASTERPAGE); - SfxStyleSheetBase* pSheet = aIter.First(); - - while (pSheet) - { - String aSheetName = pSheet->GetName(); - - // if the sheetname starts with aOldName + "~LT~" - if (aSheetName.Match(aOldName) == nLen) - { - aSheetName.Erase(0, nLen - sizeof(SD_LT_SEPARATOR) + 1 ); - aSheetName.Insert(rNewName, 0); - - StyleReplaceData aReplData; - aReplData.nFamily = pSheet->GetFamily(); - aReplData.nNewFamily = pSheet->GetFamily(); - aReplData.aName = pSheet->GetName(); - aReplData.aNewName = aSheetName; - aReplList.push_back(aReplData); - - pSheet->SetName(aSheetName); - } - - pSheet = aIter.Next(); - } - - // jetzt noch den Layoutnamen der Zeichen- und der Notizseite - // sowie ihrer Masterpages setzen - String aPageLayoutName(rNewName); - aPageLayoutName.AppendAscii( RTL_CONSTASCII_STRINGPARAM( SD_LT_SEPARATOR )); - aPageLayoutName += String(SdResId(STR_LAYOUT_OUTLINE)); - - // an allen Seiten, die das jetzt umbeannte Layout benutzen, die - // Textobjekte von der Aenderung unterrichten und Layoutnamen setzen - sal_uInt16 nPage; - for (nPage = 0; nPage < GetPageCount(); nPage++) - { - SdPage* pPage = (SdPage*) GetPage(nPage); - String aTemp(pPage->GetLayoutName()); - - if (aTemp == rOldLayoutName) - { - pPage->SetLayoutName(aPageLayoutName); - - for (sal_uLong nObj = 0; nObj < pPage->GetObjCount(); nObj++) - { - SdrObject* pObj = pPage->GetObj(nObj); - - if (pObj->GetObjInventor() == SdrInventor) - { - switch( pObj->GetObjIdentifier() ) - { - case OBJ_TEXT: - case OBJ_OUTLINETEXT: - case OBJ_TITLETEXT: - { - OutlinerParaObject* pOPO = ((SdrTextObj*) pObj)->GetOutlinerParaObject(); - - if (pOPO) - { - std::vector<StyleReplaceData>::iterator it; - for (it = aReplList.begin(); it != aReplList.end(); ++it) - pOPO->ChangeStyleSheets( it->aName, it->nFamily, it->aNewName, it->nNewFamily ); - } - } - break; - - default: - break; - } - } - } - } - } - - // und nochmal fuer die Masterpages - // die betroffenen Masterpages erhalten als Seitennamen den Namen - // des Layouts - for (nPage = 0; nPage < GetMasterPageCount(); nPage++) - { - SdPage* pPage = (SdPage*) GetMasterPage(nPage); - String aTemp(pPage->GetLayoutName()); - - if (aTemp == rOldLayoutName) - { - pPage->SetLayoutName(aPageLayoutName); - pPage->SetName(rNewName); - - for (sal_uLong nObj = 0; nObj < pPage->GetObjCount(); nObj++) - { - SdrObject* pObj = pPage->GetObj(nObj); - - if (pObj->GetObjInventor() == SdrInventor) - { - switch(pObj->GetObjIdentifier()) - { - case OBJ_TEXT: - case OBJ_OUTLINETEXT: - case OBJ_TITLETEXT: - { - OutlinerParaObject* pOPO = ((SdrTextObj*)pObj)->GetOutlinerParaObject(); - - if (pOPO) - { - std::vector<StyleReplaceData>::iterator it; - for (it = aReplList.begin(); it != aReplList.end(); ++it) - pOPO->ChangeStyleSheets( it->aName, it->nFamily, it->aNewName, it->nNewFamily ); - } - } - break; - - default: - break; - } - } - } - } - } -} - -/************************************************************************* -|* -|* Outliner-Defaults setzen (Pool-Defaults) -|* -\************************************************************************/ -void SdDrawDocument::SetTextDefaults() const -{ - // BulletItem und BulletFont fuer Titel und Gliederung - SvxBulletItem aBulletItem(EE_PARA_BULLET); - Font aBulletFont( static_cast<SdStyleSheetPool*>( mxStyleSheetPool.get())->GetBulletFont() ); - aBulletFont.SetSize(Size(0,846)); // 24 pt - aBulletItem.SetFont(aBulletFont); - aBulletItem.SetStyle(BS_BULLET); - aBulletItem.SetStart(1); - aBulletItem.SetScale(45); // in Prozent - aBulletItem.SetSymbol( 0x25CF ); // Punkt - pItemPool->SetPoolDefaultItem( aBulletItem ); - - // Neues BulletItem - SvxNumberFormat aNumberFormat(SVX_NUM_CHAR_SPECIAL); - aNumberFormat.SetBulletFont(&aBulletFont); - aNumberFormat.SetBulletChar( 0x25CF ); // StarBats: 0xF000 + 34 - aNumberFormat.SetBulletRelSize(45); - aNumberFormat.SetBulletColor(Color(COL_AUTO)); - aNumberFormat.SetStart(1); - aNumberFormat.SetNumAdjust(SVX_ADJUST_LEFT); - - SvxNumRule aNumRule( NUM_BULLET_REL_SIZE|NUM_BULLET_COLOR|NUM_CHAR_TEXT_DISTANCE, 10, sal_False); - - aNumberFormat.SetLSpace( 0 ); - aNumberFormat.SetAbsLSpace( 0 ); - aNumberFormat.SetFirstLineOffset( 0 ); - aNumRule.SetLevel( 0, aNumberFormat ); - - for( sal_uInt16 i = 1; i < aNumRule.GetLevelCount(); i++ ) - { - const short nLSpace = (i + 1) * 600; - aNumberFormat.SetLSpace(nLSpace); - aNumberFormat.SetAbsLSpace(nLSpace); - aNumberFormat.SetFirstLineOffset(-600); - aNumRule.SetLevel( i, aNumberFormat ); - } - - SvxNumBulletItem aNumBulletItem( aNumRule, EE_PARA_NUMBULLET ); - pItemPool->SetPoolDefaultItem( aNumBulletItem ); -} - -::com::sun::star::text::WritingMode SdDrawDocument::GetDefaultWritingMode() const -{ - const SfxPoolItem* pItem = ( pItemPool ? pItemPool->GetPoolDefaultItem( EE_PARA_WRITINGDIR ) : NULL ); - ::com::sun::star::text::WritingMode eRet = ::com::sun::star::text::WritingMode_LR_TB; - - if( pItem ) - { - switch( ( (SvxFrameDirectionItem&)( *pItem ) ).GetValue() ) - { - case( FRMDIR_HORI_LEFT_TOP ): eRet = ::com::sun::star::text::WritingMode_LR_TB; break; - case( FRMDIR_HORI_RIGHT_TOP ): eRet = ::com::sun::star::text::WritingMode_RL_TB; break; - case( FRMDIR_VERT_TOP_RIGHT ): eRet = ::com::sun::star::text::WritingMode_TB_RL; break; - - default: - OSL_FAIL( "Frame direction not supported yet" ); - break; - } - } - - return eRet; -} - -void SdDrawDocument::SetDefaultWritingMode(::com::sun::star::text::WritingMode eMode ) -{ - if( pItemPool ) - { - SvxFrameDirection nVal; - switch( eMode ) - { - case ::com::sun::star::text::WritingMode_LR_TB: nVal = FRMDIR_HORI_LEFT_TOP; break; - case ::com::sun::star::text::WritingMode_RL_TB: nVal = FRMDIR_HORI_RIGHT_TOP; break; - case ::com::sun::star::text::WritingMode_TB_RL: nVal = FRMDIR_VERT_TOP_RIGHT; break; - default: - OSL_FAIL( "Frame direction not supported yet" ); - return; - } - - SvxFrameDirectionItem aModeItem( nVal, EE_PARA_WRITINGDIR ); - pItemPool->SetPoolDefaultItem( aModeItem ); - - SvxAdjustItem aAdjust( SVX_ADJUST_LEFT, EE_PARA_JUST ); - - if( eMode == ::com::sun::star::text::WritingMode_RL_TB ) - aAdjust.SetEnumValue( SVX_ADJUST_RIGHT ); - - pItemPool->SetPoolDefaultItem( aAdjust ); - - - } -} - -void SdDrawDocument::getDefaultFonts( Font& rLatinFont, Font& rCJKFont, Font& rCTLFont ) -{ - LanguageType eLatin = GetLanguage( EE_CHAR_LANGUAGE ); - - // If the UI language is Korean, the default Latin font has to - // be queried for Korean, too (the Latin language from the document can't be Korean). - // This is the same logic as in SwDocShell::InitNew. - LanguageType eUiLanguage = Application::GetSettings().GetUILanguage(); - switch( eUiLanguage ) - { - case LANGUAGE_KOREAN: - case LANGUAGE_KOREAN_JOHAB: - eLatin = eUiLanguage; - break; - } - - rLatinFont = OutputDevice::GetDefaultFont( DEFAULTFONT_LATIN_PRESENTATION, eLatin, DEFAULTFONT_FLAGS_ONLYONE ); - rCJKFont = OutputDevice::GetDefaultFont( DEFAULTFONT_CJK_PRESENTATION, GetLanguage( EE_CHAR_LANGUAGE_CJK ), DEFAULTFONT_FLAGS_ONLYONE ); - rCTLFont = OutputDevice::GetDefaultFont( DEFAULTFONT_CTL_PRESENTATION, GetLanguage( EE_CHAR_LANGUAGE_CTL ), DEFAULTFONT_FLAGS_ONLYONE ) ; -} - -/* converts the given western font height to a corresponding ctl font height, deppending on the system language */ -sal_uInt32 SdDrawDocument::convertFontHeightToCTL( sal_uInt32 nWesternFontHeight ) -{ - LanguageType eRealCTLLanguage = Application::GetSettings().GetLanguage(); - if( LANGUAGE_THAI == eRealCTLLanguage ) - { - // http://specs.openoffice.org/g11n/font_sizes/42775_42725_Individual_configurable_font_size_for_default_fonts.odt - double fTemp = double(nWesternFontHeight) * 1.333; - nWesternFontHeight = (sal_uInt32)fTemp; - // make some nice values for UI that displays PT instead of 1/100th mm - nWesternFontHeight = ((nWesternFontHeight * 72) + 1270) / 2540L; - nWesternFontHeight = ((nWesternFontHeight * 2540L) + 36) / 72; - } - return nWesternFontHeight; -} - -SdStyleSheetPool* SdDrawDocument::GetSdStyleSheetPool() const -{ - return dynamic_cast< SdStyleSheetPool* >( GetStyleSheetPool() ); -} - -ModifyGuard::ModifyGuard( SdDrawDocument* pDoc ) -: mpDocShell( 0 ), mpDoc( pDoc ) -{ - init(); -} - -void ModifyGuard::init() -{ - if( mpDocShell ) - { - mpDoc = mpDocShell->GetDoc(); - } - else if( mpDoc ) - { - mpDocShell = mpDoc->GetDocSh(); - } - - mbIsEnableSetModified = mpDocShell ? mpDocShell->IsEnableSetModified() : sal_False; - mbIsDocumentChanged = mpDoc ? mpDoc->IsChanged() : sal_False; - - if( mbIsEnableSetModified ) - mpDocShell->EnableSetModified( sal_False ); -} - -ModifyGuard::~ModifyGuard() -{ - if( mbIsEnableSetModified ) - mpDocShell->EnableSetModified( sal_True ); - - if( mpDoc && (mpDoc->IsChanged() != mbIsDocumentChanged) ) - mpDoc->SetChanged(mbIsDocumentChanged); -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |