1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 29*cdf0e10cSrcweir #include "precompiled_drawinglayer.hxx" 30*cdf0e10cSrcweir 31*cdf0e10cSrcweir #include <drawinglayer/processor2d/contourextractor2d.hxx> 32*cdf0e10cSrcweir #include <drawinglayer/primitive2d/drawinglayer_primitivetypes2d.hxx> 33*cdf0e10cSrcweir #include <drawinglayer/primitive2d/polygonprimitive2d.hxx> 34*cdf0e10cSrcweir #include <drawinglayer/primitive2d/polypolygonprimitive2d.hxx> 35*cdf0e10cSrcweir #include <drawinglayer/primitive2d/bitmapprimitive2d.hxx> 36*cdf0e10cSrcweir #include <basegfx/polygon/b2dpolygontools.hxx> 37*cdf0e10cSrcweir #include <drawinglayer/primitive2d/metafileprimitive2d.hxx> 38*cdf0e10cSrcweir #include <drawinglayer/primitive2d/transparenceprimitive2d.hxx> 39*cdf0e10cSrcweir #include <drawinglayer/primitive2d/maskprimitive2d.hxx> 40*cdf0e10cSrcweir #include <drawinglayer/primitive2d/transformprimitive2d.hxx> 41*cdf0e10cSrcweir #include <drawinglayer/primitive2d/sceneprimitive2d.hxx> 42*cdf0e10cSrcweir 43*cdf0e10cSrcweir ////////////////////////////////////////////////////////////////////////////// 44*cdf0e10cSrcweir 45*cdf0e10cSrcweir using namespace com::sun::star; 46*cdf0e10cSrcweir 47*cdf0e10cSrcweir ////////////////////////////////////////////////////////////////////////////// 48*cdf0e10cSrcweir 49*cdf0e10cSrcweir namespace drawinglayer 50*cdf0e10cSrcweir { 51*cdf0e10cSrcweir namespace processor2d 52*cdf0e10cSrcweir { 53*cdf0e10cSrcweir ContourExtractor2D::ContourExtractor2D(const geometry::ViewInformation2D& rViewInformation) 54*cdf0e10cSrcweir : BaseProcessor2D(rViewInformation), 55*cdf0e10cSrcweir maExtractedContour() 56*cdf0e10cSrcweir { 57*cdf0e10cSrcweir } 58*cdf0e10cSrcweir 59*cdf0e10cSrcweir ContourExtractor2D::~ContourExtractor2D() 60*cdf0e10cSrcweir { 61*cdf0e10cSrcweir } 62*cdf0e10cSrcweir 63*cdf0e10cSrcweir void ContourExtractor2D::processBasePrimitive2D(const primitive2d::BasePrimitive2D& rCandidate) 64*cdf0e10cSrcweir { 65*cdf0e10cSrcweir switch(rCandidate.getPrimitive2DID()) 66*cdf0e10cSrcweir { 67*cdf0e10cSrcweir case PRIMITIVE2D_ID_POLYGONHAIRLINEPRIMITIVE2D : 68*cdf0e10cSrcweir { 69*cdf0e10cSrcweir // extract hairline in world coordinates 70*cdf0e10cSrcweir const primitive2d::PolygonHairlinePrimitive2D& rPolygonCandidate(static_cast< const primitive2d::PolygonHairlinePrimitive2D& >(rCandidate)); 71*cdf0e10cSrcweir basegfx::B2DPolygon aLocalPolygon(rPolygonCandidate.getB2DPolygon()); 72*cdf0e10cSrcweir aLocalPolygon.transform(getViewInformation2D().getObjectTransformation()); 73*cdf0e10cSrcweir 74*cdf0e10cSrcweir if(aLocalPolygon.isClosed()) 75*cdf0e10cSrcweir { 76*cdf0e10cSrcweir // line polygons need to be represented as open polygons to differentiate them 77*cdf0e10cSrcweir // from filled polygons 78*cdf0e10cSrcweir basegfx::tools::openWithGeometryChange(aLocalPolygon); 79*cdf0e10cSrcweir } 80*cdf0e10cSrcweir 81*cdf0e10cSrcweir maExtractedContour.push_back(basegfx::B2DPolyPolygon(aLocalPolygon)); 82*cdf0e10cSrcweir break; 83*cdf0e10cSrcweir } 84*cdf0e10cSrcweir case PRIMITIVE2D_ID_POLYPOLYGONCOLORPRIMITIVE2D : 85*cdf0e10cSrcweir { 86*cdf0e10cSrcweir // extract fill in world coordinates 87*cdf0e10cSrcweir const primitive2d::PolyPolygonColorPrimitive2D& rPolygonCandidate(static_cast< const primitive2d::PolyPolygonColorPrimitive2D& >(rCandidate)); 88*cdf0e10cSrcweir basegfx::B2DPolyPolygon aLocalPolyPolygon(rPolygonCandidate.getB2DPolyPolygon()); 89*cdf0e10cSrcweir aLocalPolyPolygon.transform(getViewInformation2D().getObjectTransformation()); 90*cdf0e10cSrcweir maExtractedContour.push_back(aLocalPolyPolygon); 91*cdf0e10cSrcweir break; 92*cdf0e10cSrcweir } 93*cdf0e10cSrcweir case PRIMITIVE2D_ID_BITMAPPRIMITIVE2D : 94*cdf0e10cSrcweir { 95*cdf0e10cSrcweir // extract BoundRect from bitmaps in world coordinates 96*cdf0e10cSrcweir const primitive2d::BitmapPrimitive2D& rBitmapCandidate(static_cast< const primitive2d::BitmapPrimitive2D& >(rCandidate)); 97*cdf0e10cSrcweir basegfx::B2DHomMatrix aLocalTransform(getViewInformation2D().getObjectTransformation() * rBitmapCandidate.getTransform()); 98*cdf0e10cSrcweir basegfx::B2DPolygon aPolygon(basegfx::tools::createUnitPolygon()); 99*cdf0e10cSrcweir aPolygon.transform(aLocalTransform); 100*cdf0e10cSrcweir maExtractedContour.push_back(basegfx::B2DPolyPolygon(aPolygon)); 101*cdf0e10cSrcweir break; 102*cdf0e10cSrcweir } 103*cdf0e10cSrcweir case PRIMITIVE2D_ID_METAFILEPRIMITIVE2D : 104*cdf0e10cSrcweir { 105*cdf0e10cSrcweir // extract BoundRect from MetaFiles in world coordinates 106*cdf0e10cSrcweir const primitive2d::MetafilePrimitive2D& rMetaCandidate(static_cast< const primitive2d::MetafilePrimitive2D& >(rCandidate)); 107*cdf0e10cSrcweir basegfx::B2DHomMatrix aLocalTransform(getViewInformation2D().getObjectTransformation() * rMetaCandidate.getTransform()); 108*cdf0e10cSrcweir basegfx::B2DPolygon aPolygon(basegfx::tools::createUnitPolygon()); 109*cdf0e10cSrcweir aPolygon.transform(aLocalTransform); 110*cdf0e10cSrcweir maExtractedContour.push_back(basegfx::B2DPolyPolygon(aPolygon)); 111*cdf0e10cSrcweir break; 112*cdf0e10cSrcweir } 113*cdf0e10cSrcweir case PRIMITIVE2D_ID_TRANSPARENCEPRIMITIVE2D : 114*cdf0e10cSrcweir { 115*cdf0e10cSrcweir // sub-transparence group. Look at children 116*cdf0e10cSrcweir const primitive2d::TransparencePrimitive2D& rTransCandidate(static_cast< const primitive2d::TransparencePrimitive2D& >(rCandidate)); 117*cdf0e10cSrcweir process(rTransCandidate.getChildren()); 118*cdf0e10cSrcweir break; 119*cdf0e10cSrcweir } 120*cdf0e10cSrcweir case PRIMITIVE2D_ID_MASKPRIMITIVE2D : 121*cdf0e10cSrcweir { 122*cdf0e10cSrcweir // extract mask in world coordinates, ignore content 123*cdf0e10cSrcweir const primitive2d::MaskPrimitive2D& rMaskCandidate(static_cast< const primitive2d::MaskPrimitive2D& >(rCandidate)); 124*cdf0e10cSrcweir basegfx::B2DPolyPolygon aMask(rMaskCandidate.getMask()); 125*cdf0e10cSrcweir aMask.transform(getViewInformation2D().getObjectTransformation()); 126*cdf0e10cSrcweir maExtractedContour.push_back(basegfx::B2DPolyPolygon(aMask)); 127*cdf0e10cSrcweir break; 128*cdf0e10cSrcweir } 129*cdf0e10cSrcweir case PRIMITIVE2D_ID_TRANSFORMPRIMITIVE2D : 130*cdf0e10cSrcweir { 131*cdf0e10cSrcweir // remember current ViewInformation2D 132*cdf0e10cSrcweir const primitive2d::TransformPrimitive2D& rTransformCandidate(static_cast< const primitive2d::TransformPrimitive2D& >(rCandidate)); 133*cdf0e10cSrcweir const geometry::ViewInformation2D aLastViewInformation2D(getViewInformation2D()); 134*cdf0e10cSrcweir 135*cdf0e10cSrcweir // create new local ViewInformation2D 136*cdf0e10cSrcweir const geometry::ViewInformation2D aViewInformation2D( 137*cdf0e10cSrcweir getViewInformation2D().getObjectTransformation() * rTransformCandidate.getTransformation(), 138*cdf0e10cSrcweir getViewInformation2D().getViewTransformation(), 139*cdf0e10cSrcweir getViewInformation2D().getViewport(), 140*cdf0e10cSrcweir getViewInformation2D().getVisualizedPage(), 141*cdf0e10cSrcweir getViewInformation2D().getViewTime(), 142*cdf0e10cSrcweir getViewInformation2D().getExtendedInformationSequence()); 143*cdf0e10cSrcweir updateViewInformation(aViewInformation2D); 144*cdf0e10cSrcweir 145*cdf0e10cSrcweir // proccess content 146*cdf0e10cSrcweir process(rTransformCandidate.getChildren()); 147*cdf0e10cSrcweir 148*cdf0e10cSrcweir // restore transformations 149*cdf0e10cSrcweir updateViewInformation(aLastViewInformation2D); 150*cdf0e10cSrcweir 151*cdf0e10cSrcweir break; 152*cdf0e10cSrcweir } 153*cdf0e10cSrcweir case PRIMITIVE2D_ID_SCENEPRIMITIVE2D : 154*cdf0e10cSrcweir { 155*cdf0e10cSrcweir // 2D Scene primitive containing 3D stuff; extract 2D contour in world coordinates 156*cdf0e10cSrcweir const primitive2d::ScenePrimitive2D& rScenePrimitive2DCandidate(static_cast< const primitive2d::ScenePrimitive2D& >(rCandidate)); 157*cdf0e10cSrcweir const primitive2d::Primitive2DSequence xExtracted2DSceneGeometry(rScenePrimitive2DCandidate.getGeometry2D()); 158*cdf0e10cSrcweir const primitive2d::Primitive2DSequence xExtracted2DSceneShadow(rScenePrimitive2DCandidate.getShadow2D(getViewInformation2D())); 159*cdf0e10cSrcweir 160*cdf0e10cSrcweir // proccess content 161*cdf0e10cSrcweir if(xExtracted2DSceneGeometry.hasElements()) 162*cdf0e10cSrcweir { 163*cdf0e10cSrcweir process(xExtracted2DSceneGeometry); 164*cdf0e10cSrcweir } 165*cdf0e10cSrcweir 166*cdf0e10cSrcweir // proccess content 167*cdf0e10cSrcweir if(xExtracted2DSceneShadow.hasElements()) 168*cdf0e10cSrcweir { 169*cdf0e10cSrcweir process(xExtracted2DSceneShadow); 170*cdf0e10cSrcweir } 171*cdf0e10cSrcweir 172*cdf0e10cSrcweir break; 173*cdf0e10cSrcweir } 174*cdf0e10cSrcweir case PRIMITIVE2D_ID_WRONGSPELLPRIMITIVE2D : 175*cdf0e10cSrcweir case PRIMITIVE2D_ID_MARKERARRAYPRIMITIVE2D : 176*cdf0e10cSrcweir case PRIMITIVE2D_ID_POINTARRAYPRIMITIVE2D : 177*cdf0e10cSrcweir { 178*cdf0e10cSrcweir // ignorable primitives 179*cdf0e10cSrcweir break; 180*cdf0e10cSrcweir } 181*cdf0e10cSrcweir case PRIMITIVE2D_ID_TEXTSIMPLEPORTIONPRIMITIVE2D : 182*cdf0e10cSrcweir case PRIMITIVE2D_ID_TEXTDECORATEDPORTIONPRIMITIVE2D : 183*cdf0e10cSrcweir { 184*cdf0e10cSrcweir // primitives who's BoundRect will be added in world coordinates 185*cdf0e10cSrcweir basegfx::B2DRange aRange(rCandidate.getB2DRange(getViewInformation2D())); 186*cdf0e10cSrcweir aRange.transform(getViewInformation2D().getObjectTransformation()); 187*cdf0e10cSrcweir maExtractedContour.push_back(basegfx::B2DPolyPolygon(basegfx::tools::createPolygonFromRect(aRange))); 188*cdf0e10cSrcweir break; 189*cdf0e10cSrcweir } 190*cdf0e10cSrcweir default : 191*cdf0e10cSrcweir { 192*cdf0e10cSrcweir // process recursively 193*cdf0e10cSrcweir process(rCandidate.get2DDecomposition(getViewInformation2D())); 194*cdf0e10cSrcweir break; 195*cdf0e10cSrcweir } 196*cdf0e10cSrcweir } 197*cdf0e10cSrcweir } 198*cdf0e10cSrcweir 199*cdf0e10cSrcweir } // end of namespace processor2d 200*cdf0e10cSrcweir } // end of namespace drawinglayer 201*cdf0e10cSrcweir 202*cdf0e10cSrcweir ////////////////////////////////////////////////////////////////////////////// 203*cdf0e10cSrcweir // eof 204