/* -*- 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ // include --------------------------------------------------------------- #include "svx/XPropertyTable.hxx" #include #include #include #include #include #include #include #include "svx/dlgutil.hxx" #include #include #include #include #include #include #include #include using namespace ::com::sun::star; using namespace ::rtl; 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() { delete mpData; mpData = NULL; } XHatchList::XHatchList( const String& rPath, XOutdevItemPool* pInPool ) : XPropertyList( XHATCH_LIST, rPath, pInPool ), mpData( NULL ) { pBmpList = new BitmapList_impl(); } XHatchList::~XHatchList() { delete mpData; mpData = NULL; } XHatchEntry* XHatchList::Replace(XHatchEntry* pEntry, long nIndex ) { return (XHatchEntry*) XPropertyList::Replace(pEntry, nIndex); } XHatchEntry* XHatchList::Remove(long nIndex) { return (XHatchEntry*) XPropertyList::Remove(nIndex); } XHatchEntry* XHatchList::GetHatch(long nIndex) const { return (XHatchEntry*) XPropertyList::Get(nIndex, 0); } uno::Reference< container::XNameContainer > XHatchList::createInstance() { return uno::Reference< container::XNameContainer >( SvxUnoXHatchTable_createInstance( this ), uno::UNO_QUERY ); } sal_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( sal_True ); } sal_Bool XHatchList::CreateBitmapsForUI() { impCreate(); for( long i = 0; i < Count(); i++) { Bitmap* pBmp = CreateBitmapForUI( i, sal_False ); DBG_ASSERT( pBmp, "XHatchList: Bitmap(UI) konnte nicht erzeugt werden!" ); if( pBmp ) { if ( (size_t)i < pBmpList->size() ) { pBmpList->insert( pBmpList->begin() + i, pBmp ); } else { pBmpList->push_back( pBmp ); } } } impDestroy(); return( sal_True ); } Bitmap* XHatchList::CreateBitmapForUI( long nIndex, sal_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; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */