/* -*- 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. * ************************************************************************/ #ifndef INCLUDED_DRAWINGLAYER_PROCESSOR2D_VCLMETAFILEPROCESSOR2D_HXX #define INCLUDED_DRAWINGLAYER_PROCESSOR2D_VCLMETAFILEPROCESSOR2D_HXX #include #include #include ////////////////////////////////////////////////////////////////////////////// // vcl::PDFExtOutDevData support #include ////////////////////////////////////////////////////////////////////////////// // predefines class GDIMetaFile; class Rectangle; class Gradient; class SvtGraphicFill; class SvtGraphicStroke; namespace drawinglayer { namespace attribute { class FillGradientAttribute; class LineAttribute; class StrokeAttribute; class LineStartEndAttribute; }} namespace basegfx { class BColor; } ////////////////////////////////////////////////////////////////////////////// namespace drawinglayer { namespace processor2d { /** VclMetafileProcessor2D class This processor derived from VclProcessor2D is the base class for rendering all feeded primitives to a classical VCL-Metafile, including all over the time grown extra data in comments and PDF exception data creations. Also printing needs some exception stuff. All in all it is needed to emulate the old ::paint output from the old Drawinglayer as long as exporters and/or filters still use the Metafile and the extra-data added to it (which can be seen mostly as 'extensions' or simply as 'hacks'). */ class VclMetafileProcessor2D : public VclProcessor2D { private: /// local helper(s) Rectangle impDumpToMetaFile( const primitive2d::Primitive2DSequence& rContent, GDIMetaFile& o_rContentMetafile); void impConvertFillGradientAttributeToVCLGradient( Gradient& o_rVCLGradient, const attribute::FillGradientAttribute& rFiGrAtt, bool bIsTransparenceGradient); void impStartSvtGraphicFill(SvtGraphicFill* pSvtGraphicFill); void impEndSvtGraphicFill(SvtGraphicFill* pSvtGraphicFill); SvtGraphicStroke* impTryToCreateSvtGraphicStroke( const basegfx::B2DPolygon& rB2DPolygon, const basegfx::BColor* pColor, const attribute::LineAttribute* pLineAttribute, const attribute::StrokeAttribute* pStrokeAttribute, const attribute::LineStartEndAttribute* pStart, const attribute::LineStartEndAttribute* pEnd); void impStartSvtGraphicStroke(SvtGraphicStroke* pSvtGraphicStroke); void impEndSvtGraphicStroke(SvtGraphicStroke* pSvtGraphicStroke); /// the current clipping PolyPolygon from MaskPrimitive2D basegfx::B2DPolyPolygon maClipPolyPolygon; /// the target MetaFile GDIMetaFile* mpMetaFile; /* do not allow embedding SvtGraphicFills into each other, use a counter to prevent that */ sal_uInt32 mnSvtGraphicFillCount; /// same for SvtGraphicStroke sal_uInt32 mnSvtGraphicStrokeCount; /* hold the last unified transparence value to have it handy on SvtGraphicStroke creation */ double mfCurrentUnifiedTransparence; /* break iterator support made static so it only needs to be fetched once, even with many single constructed VclMetafileProcessor2D. It's still incarnated on demand, but exists for OOo runtime now by purpose. */ static ::com::sun::star::uno::Reference< ::com::sun::star::i18n::XBreakIterator > mxBreakIterator; /* vcl::PDFExtOutDevData support For the first step, some extra actions at vcl::PDFExtOutDevData need to be emulated with the VclMetafileProcessor2D. These are potentially temporarily since PDF export may use PrimitiveSequences one day directly. */ vcl::PDFExtOutDevData* mpPDFExtOutDevData; protected: /* the local processor for BasePrinitive2D-Implementation based primitives, called from the common process()-implementation */ virtual void processBasePrimitive2D(const primitive2d::BasePrimitive2D& rCandidate); public: /// constructor/destructor VclMetafileProcessor2D( const geometry::ViewInformation2D& rViewInformation, OutputDevice& rOutDev); virtual ~VclMetafileProcessor2D(); }; } // end of namespace processor2d } // end of namespace drawinglayer ////////////////////////////////////////////////////////////////////////////// #endif // INCLUDED_DRAWINGLAYER_PROCESSOR2D_VCLMETAFILEPROCESSOR2D_HXX // eof /* vim:set shiftwidth=4 softtabstop=4 expandtab: */