1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <processor3d/geometry2dextractor.hxx>
21 #include <drawinglayer/primitive3d/drawinglayer_primitivetypes3d.hxx>
22 #include <drawinglayer/primitive3d/transformprimitive3d.hxx>
23 #include <drawinglayer/primitive3d/modifiedcolorprimitive3d.hxx>
24 #include <drawinglayer/primitive3d/polygonprimitive3d.hxx>
25 #include <basegfx/polygon/b2dpolygontools.hxx>
26 #include <drawinglayer/primitive3d/polypolygonprimitive3d.hxx>
27 #include <basegfx/polygon/b2dpolypolygontools.hxx>
28 #include <drawinglayer/primitive2d/PolygonHairlinePrimitive2D.hxx>
29 #include <drawinglayer/primitive2d/PolyPolygonColorPrimitive2D.hxx>
30 #include <primitive3d/textureprimitive3d.hxx>
34 using namespace com::sun::star
;
37 namespace drawinglayer::processor3d
39 // as tooling, the process() implementation takes over API handling and calls this
40 // virtual render method when the primitive implementation is BasePrimitive3D-based.
41 void Geometry2DExtractingProcessor::processBasePrimitive3D(const primitive3d::BasePrimitive3D
& rCandidate
)
43 // it is a BasePrimitive3D implementation, use getPrimitive3DID() call for switch
44 switch(rCandidate
.getPrimitive3DID())
46 case PRIMITIVE3D_ID_TRANSFORMPRIMITIVE3D
:
48 // transform group. Remember current transformations
49 const primitive3d::TransformPrimitive3D
& rPrimitive
= static_cast< const primitive3d::TransformPrimitive3D
& >(rCandidate
);
50 const geometry::ViewInformation3D
aLastViewInformation3D(getViewInformation3D());
52 // create new transformation; add new object transform from right side
53 const geometry::ViewInformation3D
aNewViewInformation3D(
54 aLastViewInformation3D
.getObjectTransformation() * rPrimitive
.getTransformation(),
55 aLastViewInformation3D
.getOrientation(),
56 aLastViewInformation3D
.getProjection(),
57 aLastViewInformation3D
.getDeviceToView(),
58 aLastViewInformation3D
.getViewTime(),
59 aLastViewInformation3D
.getExtendedInformationSequence());
60 updateViewInformation(aNewViewInformation3D
);
62 // let break down recursively
63 process(rPrimitive
.getChildren());
65 // restore transformations
66 updateViewInformation(aLastViewInformation3D
);
69 case PRIMITIVE3D_ID_MODIFIEDCOLORPRIMITIVE3D
:
71 // ModifiedColorPrimitive3D; push, process and pop
72 const primitive3d::ModifiedColorPrimitive3D
& rModifiedCandidate
= static_cast< const primitive3d::ModifiedColorPrimitive3D
& >(rCandidate
);
73 const primitive3d::Primitive3DContainer
& rSubSequence
= rModifiedCandidate
.getChildren();
75 if(!rSubSequence
.empty())
77 maBColorModifierStack
.push(rModifiedCandidate
.getColorModifier());
78 process(rModifiedCandidate
.getChildren());
79 maBColorModifierStack
.pop();
83 case PRIMITIVE3D_ID_POLYGONHAIRLINEPRIMITIVE3D
:
85 // PolygonHairlinePrimitive3D
86 const primitive3d::PolygonHairlinePrimitive3D
& rPrimitive
= static_cast< const primitive3d::PolygonHairlinePrimitive3D
& >(rCandidate
);
87 basegfx::B2DPolygon
a2DHairline(basegfx::utils::createB2DPolygonFromB3DPolygon(rPrimitive
.getB3DPolygon(), getViewInformation3D().getObjectToView()));
89 if(a2DHairline
.count())
91 a2DHairline
.transform(getObjectTransformation());
92 const basegfx::BColor
aModifiedColor(maBColorModifierStack
.getModifiedColor(rPrimitive
.getBColor()));
93 const primitive2d::Primitive2DReference
xRef(new primitive2d::PolygonHairlinePrimitive2D(std::move(a2DHairline
), aModifiedColor
));
94 maPrimitive2DSequence
.push_back(xRef
);
98 case PRIMITIVE3D_ID_POLYPOLYGONMATERIALPRIMITIVE3D
:
100 // PolyPolygonMaterialPrimitive3D
101 const primitive3d::PolyPolygonMaterialPrimitive3D
& rPrimitive
= static_cast< const primitive3d::PolyPolygonMaterialPrimitive3D
& >(rCandidate
);
102 basegfx::B2DPolyPolygon
a2DFill(basegfx::utils::createB2DPolyPolygonFromB3DPolyPolygon(rPrimitive
.getB3DPolyPolygon(), getViewInformation3D().getObjectToView()));
106 a2DFill
.transform(getObjectTransformation());
107 const basegfx::BColor
aModifiedColor(maBColorModifierStack
.getModifiedColor(rPrimitive
.getMaterial().getColor()));
108 const primitive2d::Primitive2DReference
xRef(new primitive2d::PolyPolygonColorPrimitive2D(std::move(a2DFill
), aModifiedColor
));
109 maPrimitive2DSequence
.push_back(xRef
);
113 case PRIMITIVE3D_ID_GRADIENTTEXTUREPRIMITIVE3D
:
114 case PRIMITIVE3D_ID_HATCHTEXTUREPRIMITIVE3D
:
115 case PRIMITIVE3D_ID_BITMAPTEXTUREPRIMITIVE3D
:
116 case PRIMITIVE3D_ID_TRANSPARENCETEXTUREPRIMITIVE3D
:
117 case PRIMITIVE3D_ID_UNIFIEDTRANSPARENCETEXTUREPRIMITIVE3D
:
119 // TexturePrimitive3D: Process children, do not try to decompose
120 const primitive3d::TexturePrimitive3D
& rTexturePrimitive
= static_cast< const primitive3d::TexturePrimitive3D
& >(rCandidate
);
121 const primitive3d::Primitive3DContainer
& aChildren(rTexturePrimitive
.getChildren());
123 if(!aChildren
.empty())
129 case PRIMITIVE3D_ID_SHADOWPRIMITIVE3D
:
131 // accept but ignore labels and shadow; these should be extracted separately
136 // process recursively
137 process(rCandidate
.get3DDecomposition(getViewInformation3D()));
143 Geometry2DExtractingProcessor::Geometry2DExtractingProcessor(
144 const geometry::ViewInformation3D
& rViewInformation
,
145 basegfx::B2DHomMatrix aObjectTransformation
)
146 : BaseProcessor3D(rViewInformation
),
147 maObjectTransformation(std::move(aObjectTransformation
)),
148 maBColorModifierStack()
152 } // end of namespace
154 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */