diff options
Diffstat (limited to 'svx/source/xoutdev/xtabhtch.cxx')
-rw-r--r-- | svx/source/xoutdev/xtabhtch.cxx | 374 |
1 files changed, 374 insertions, 0 deletions
diff --git a/svx/source/xoutdev/xtabhtch.cxx b/svx/source/xoutdev/xtabhtch.cxx new file mode 100644 index 000000000000..703b2db16b1f --- /dev/null +++ b/svx/source/xoutdev/xtabhtch.cxx @@ -0,0 +1,374 @@ +/************************************************************************* + * + * 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_svx.hxx" + +// include --------------------------------------------------------------- + +#ifndef SVX_LIGHT + +#include <com/sun/star/container/XNameContainer.hpp> +#include "XPropertyTable.hxx" +#include <unotools/ucbstreamhelper.hxx> +#include <vcl/svapp.hxx> + +#include "xmlxtexp.hxx" +#include "xmlxtimp.hxx" + +#endif + +#include <tools/urlobj.hxx> +#include <vcl/virdev.hxx> +#include <svl/itemset.hxx> +#include <sfx2/docfile.hxx> +#include <svx/dialogs.hrc> +#include <svx/dialmgr.hxx> +#include <svx/xtable.hxx> +#include <svx/xpool.hxx> +#include "dlgutil.hxx" +#include <svx/xflhtit.hxx> +#include <svx/xflclit.hxx> +#include <svx/xfillit0.hxx> + +#include <svx/svdorect.hxx> +#include <svx/svdmodel.hxx> +#include <svx/sdr/contact/objectcontactofobjlistpainter.hxx> +#include <svx/sdr/contact/displayinfo.hxx> +#include <svx/xlnclit.hxx> + +using namespace ::com::sun::star; +using namespace ::rtl; + +sal_Unicode const pszExtHatch[] = {'s','o','h'}; + +char const aChckHatch[] = { 0x04, 0x00, 'S','O','H','L'}; // < 5.2 +char const aChckHatch0[] = { 0x04, 0x00, 'S','O','H','0'}; // = 5.2 +char const aChckXML[] = { '<', '?', 'x', 'm', 'l' }; // = 6.0 + +// ------------------ +// class XHatchTable +// ------------------ + +/************************************************************************* +|* +|* XHatchTable::XHatchTable() +|* +*************************************************************************/ + +XHatchTable::XHatchTable( const String& rPath, + XOutdevItemPool* pInPool, + USHORT nInitSize, USHORT nReSize ) : + XPropertyTable( rPath, pInPool, nInitSize, nReSize) +{ + pBmpTable = new Table( nInitSize, nReSize ); +} + +/************************************************************************/ + +XHatchTable::~XHatchTable() +{ +} + +/************************************************************************/ + +XHatchEntry* XHatchTable::Replace(long nIndex, XHatchEntry* pEntry ) +{ + return (XHatchEntry*) XPropertyTable::Replace(nIndex, pEntry); +} + +/************************************************************************/ + +XHatchEntry* XHatchTable::Remove(long nIndex) +{ + return (XHatchEntry*) XPropertyTable::Remove(nIndex, 0); +} + +/************************************************************************/ + +XHatchEntry* XHatchTable::GetHatch(long nIndex) const +{ + return (XHatchEntry*) XPropertyTable::Get(nIndex, 0); +} + +/************************************************************************/ + +BOOL XHatchTable::Load() +{ + return( FALSE ); +} + +/************************************************************************/ + +BOOL XHatchTable::Save() +{ + return( FALSE ); +} + +/************************************************************************/ + +BOOL XHatchTable::Create() +{ + return( FALSE ); +} + +/************************************************************************/ + +BOOL XHatchTable::CreateBitmapsForUI() +{ + return( FALSE ); +} + +/************************************************************************/ + +Bitmap* XHatchTable::CreateBitmapForUI( long /*nIndex*/, BOOL /*bDelete*/) +{ + return( NULL ); +} + +// ----------------- +// class XHatchList +// ----------------- + +class impXHatchList +{ +private: + VirtualDevice* mpVirtualDevice; + SdrModel* mpSdrModel; + SdrObject* mpBackgroundObject; + SdrObject* mpHatchObject; + +public: + impXHatchList(VirtualDevice* pV, SdrModel* pM, SdrObject* pB, SdrObject* pH) + : mpVirtualDevice(pV), + mpSdrModel(pM), + mpBackgroundObject(pB), + mpHatchObject(pH) + {} + + ~impXHatchList() + { + delete mpVirtualDevice; + SdrObject::Free(mpBackgroundObject); + SdrObject::Free(mpHatchObject); + delete mpSdrModel; + } + + VirtualDevice* getVirtualDevice() const { return mpVirtualDevice; } + SdrObject* getBackgroundObject() const { return mpBackgroundObject; } + SdrObject* getHatchObject() const { return mpHatchObject; } +}; + +void XHatchList::impCreate() +{ + if(!mpData) + { + const Point aZero(0, 0); + const StyleSettings& rStyleSettings = Application::GetSettings().GetStyleSettings(); + + VirtualDevice* pVirDev = new VirtualDevice; + OSL_ENSURE(0 != pVirDev, "XDashList: no VirtualDevice created!" ); + pVirDev->SetMapMode(MAP_100TH_MM); + const Size aSize(pVirDev->PixelToLogic(Size(BITMAP_WIDTH, BITMAP_HEIGHT))); + pVirDev->SetOutputSize(aSize); + pVirDev->SetDrawMode(rStyleSettings.GetHighContrastMode() + ? DRAWMODE_SETTINGSLINE | DRAWMODE_SETTINGSFILL | DRAWMODE_SETTINGSTEXT | DRAWMODE_SETTINGSGRADIENT + : DRAWMODE_DEFAULT); + + SdrModel* pSdrModel = new SdrModel(); + OSL_ENSURE(0 != pSdrModel, "XDashList: no SdrModel created!" ); + pSdrModel->GetItemPool().FreezeIdRanges(); + + const Size aSinglePixel(pVirDev->PixelToLogic(Size(1, 1))); + const Rectangle aBackgroundSize(aZero, Size(aSize.getWidth() - aSinglePixel.getWidth(), aSize.getHeight() - aSinglePixel.getHeight())); + SdrObject* pBackgroundObject = new SdrRectObj(aBackgroundSize); + OSL_ENSURE(0 != pBackgroundObject, "XDashList: no BackgroundObject created!" ); + pBackgroundObject->SetModel(pSdrModel); + pBackgroundObject->SetMergedItem(XFillStyleItem(XFILL_SOLID)); + pBackgroundObject->SetMergedItem(XFillColorItem(String(), rStyleSettings.GetFieldColor())); + pBackgroundObject->SetMergedItem(XLineStyleItem(XLINE_SOLID)); + pBackgroundObject->SetMergedItem(XLineColorItem(String(), Color(COL_BLACK))); + + SdrObject* pHatchObject = new SdrRectObj(aBackgroundSize); + OSL_ENSURE(0 != pHatchObject, "XDashList: no HatchObject created!" ); + pHatchObject->SetModel(pSdrModel); + pHatchObject->SetMergedItem(XFillStyleItem(XFILL_HATCH)); + pHatchObject->SetMergedItem(XLineStyleItem(XLINE_NONE)); + + mpData = new impXHatchList(pVirDev, pSdrModel, pBackgroundObject, pHatchObject); + OSL_ENSURE(0 != mpData, "XDashList: data creation went wrong!" ); + } +} + +void XHatchList::impDestroy() +{ + if(mpData) + { + delete mpData; + mpData = 0; + } +} + +XHatchList::XHatchList(const String& rPath, XOutdevItemPool* pInPool, sal_uInt16 nInitSize, sal_uInt16 nReSize) +: XPropertyList(rPath, pInPool, nInitSize, nReSize), + mpData(0) +{ + pBmpList = new List(nInitSize, nReSize); +} + +XHatchList::~XHatchList() +{ + if(mpData) + { + delete mpData; + mpData = 0; + } +} + +XHatchEntry* XHatchList::Replace(XHatchEntry* pEntry, long nIndex ) +{ + return (XHatchEntry*) XPropertyList::Replace(pEntry, nIndex); +} + +XHatchEntry* XHatchList::Remove(long nIndex) +{ + return (XHatchEntry*) XPropertyList::Remove(nIndex, 0); +} + +XHatchEntry* XHatchList::GetHatch(long nIndex) const +{ + return (XHatchEntry*) XPropertyList::Get(nIndex, 0); +} + +BOOL XHatchList::Load() +{ + if( bListDirty ) + { + bListDirty = FALSE; + + INetURLObject aURL( aPath ); + + if( INET_PROT_NOT_VALID == aURL.GetProtocol() ) + { + DBG_ASSERT( !aPath.Len(), "invalid URL" ); + return FALSE; + } + + aURL.Append( aName ); + + if( !aURL.getExtension().getLength() ) + aURL.setExtension( rtl::OUString( pszExtHatch, 3 ) ); + + uno::Reference< container::XNameContainer > xTable( SvxUnoXHatchTable_createInstance( this ), uno::UNO_QUERY ); + return SvxXMLXTableImport::load( aURL.GetMainURL( INetURLObject::NO_DECODE ), xTable ); + } + return( FALSE ); +} + +BOOL XHatchList::Save() +{ + INetURLObject aURL( aPath ); + + if( INET_PROT_NOT_VALID == aURL.GetProtocol() ) + { + DBG_ASSERT( !aPath.Len(), "invalid URL" ); + return FALSE; + } + + aURL.Append( aName ); + + if( !aURL.getExtension().getLength() ) + aURL.setExtension( rtl::OUString( pszExtHatch, 3 ) ); + + uno::Reference< container::XNameContainer > xTable( SvxUnoXHatchTable_createInstance( this ), uno::UNO_QUERY ); + return SvxXMLXTableExportComponent::save( aURL.GetMainURL( INetURLObject::NO_DECODE ), xTable ); +} + +BOOL XHatchList::Create() +{ + XubString aStr( SVX_RES( RID_SVXSTR_HATCH ) ); + xub_StrLen nLen; + + aStr.AppendAscii(" 1"); + nLen = aStr.Len() - 1; + Insert(new XHatchEntry(XHatch(RGB_Color(COL_BLACK),XHATCH_SINGLE,100, 0),aStr)); + aStr.SetChar(nLen, sal_Unicode('2')); + Insert(new XHatchEntry(XHatch(RGB_Color(COL_RED ),XHATCH_DOUBLE, 80,450),aStr)); + aStr.SetChar(nLen, sal_Unicode('3')); + Insert(new XHatchEntry(XHatch(RGB_Color(COL_BLUE ),XHATCH_TRIPLE,120, 0),aStr)); + + return( TRUE ); +} + +BOOL XHatchList::CreateBitmapsForUI() +{ + impCreate(); + + for( long i = 0; i < Count(); i++) + { + Bitmap* pBmp = CreateBitmapForUI( i, FALSE ); + DBG_ASSERT( pBmp, "XHatchList: Bitmap(UI) konnte nicht erzeugt werden!" ); + + if( pBmp ) + pBmpList->Insert( pBmp, i ); + } + + impDestroy(); + + return( TRUE ); +} + +Bitmap* XHatchList::CreateBitmapForUI( long nIndex, BOOL bDelete ) +{ + impCreate(); + VirtualDevice* pVD = mpData->getVirtualDevice(); + SdrObject* pHatchObject = mpData->getHatchObject(); + + pHatchObject->SetMergedItem(XFillStyleItem(XFILL_HATCH)); + pHatchObject->SetMergedItem(XFillHatchItem(String(), GetHatch(nIndex)->GetHatch())); + + sdr::contact::SdrObjectVector aObjectVector; + aObjectVector.push_back(mpData->getBackgroundObject()); + aObjectVector.push_back(pHatchObject); + sdr::contact::ObjectContactOfObjListPainter aPainter(*pVD, aObjectVector, 0); + sdr::contact::DisplayInfo aDisplayInfo; + + aPainter.ProcessDisplay(aDisplayInfo); + + const Point aZero(0, 0); + Bitmap* pBitmap = new Bitmap(pVD->GetBitmap(aZero, pVD->GetOutputSize())); + + if(bDelete) + { + impDestroy(); + } + + return pBitmap; +} + +////////////////////////////////////////////////////////////////////////////// +// eof |