summaryrefslogtreecommitdiff
path: root/sd/source/core/drawdoc4.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'sd/source/core/drawdoc4.cxx')
-rw-r--r--sd/source/core/drawdoc4.cxx1463
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: */