1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#pragma once
#include <drawinglayer/drawinglayerdllapi.h>
#include <drawinglayer/primitive3d/groupprimitive3d.hxx>
#include <drawinglayer/attribute/fillgraphicattribute.hxx>
#include <basegfx/vector/b2dvector.hxx>
#include <drawinglayer/attribute/fillgradientattribute.hxx>
namespace drawinglayer
{
namespace primitive3d
{
/** TexturePrimitive3D class
This 3D grouping primitive is used to define a texture for
3d geometry by embedding it. It is used as base class for
extended texture definitions
*/
class TexturePrimitive3D : public GroupPrimitive3D
{
private:
/// texture geometry definition
basegfx::B2DVector maTextureSize;
/// flag if texture shall be modulated with white interpolated color
bool mbModulate : 1;
/// flag if texture shall be filtered
bool mbFilter : 1;
public:
/// constructor
TexturePrimitive3D(
const Primitive3DContainer& rChildren,
const basegfx::B2DVector& rTextureSize,
bool bModulate,
bool bFilter);
/// data read access
const basegfx::B2DVector& getTextureSize() const { return maTextureSize; }
bool getModulate() const { return mbModulate; }
bool getFilter() const { return mbFilter; }
/// compare operator
virtual bool operator==(const BasePrimitive3D& rPrimitive) const override;
};
} // end of namespace primitive3d
} // end of namespace drawinglayer
namespace drawinglayer
{
namespace primitive3d
{
/** UnifiedTransparenceTexturePrimitive3D class
This 3D primitive expands TexturePrimitive3D to a unified
transparence texture definition. All 3D primitives
embedded here will be shown with the given transparency.
*/
class UnifiedTransparenceTexturePrimitive3D final : public TexturePrimitive3D
{
private:
/// transparency definition
double mfTransparence;
public:
/// constructor
UnifiedTransparenceTexturePrimitive3D(
double fTransparence,
const Primitive3DContainer& rChildren);
/// data read access
double getTransparence() const { return mfTransparence; }
/// compare operator
virtual bool operator==(const BasePrimitive3D& rPrimitive) const override;
/// own getB3DRange implementation to include transparent geometries to BoundRect calculations
virtual basegfx::B3DRange getB3DRange(const geometry::ViewInformation3D& rViewInformation) const override;
/// local decomposition.
virtual Primitive3DContainer get3DDecomposition(const geometry::ViewInformation3D& rViewInformation) const override;
/// provide unique ID
DeclPrimitive3DIDBlock()
};
} // end of namespace primitive3d
} // end of namespace drawinglayer
namespace drawinglayer
{
namespace primitive3d
{
/** GradientTexturePrimitive3D class
This 3D primitive expands TexturePrimitive3D to a gradient texture
definition. All 3D primitives embedded here will be shown with the
defined gradient.
*/
class GradientTexturePrimitive3D : public TexturePrimitive3D
{
private:
/// the gradient definition
attribute::FillGradientAttribute maGradient;
public:
/// constructor
GradientTexturePrimitive3D(
const attribute::FillGradientAttribute& rGradient,
const Primitive3DContainer& rChildren,
const basegfx::B2DVector& rTextureSize,
bool bModulate,
bool bFilter);
/// data read access
const attribute::FillGradientAttribute& getGradient() const { return maGradient; }
/// compare operator
virtual bool operator==(const BasePrimitive3D& rPrimitive) const override;
/// provide unique ID
DeclPrimitive3DIDBlock()
};
} // end of namespace primitive3d
} // end of namespace drawinglayer
namespace drawinglayer
{
namespace primitive3d
{
/** BitmapTexturePrimitive3D class
This 3D primitive expands TexturePrimitive3D to a bitmap texture
definition. All 3D primitives embedded here will be shown with the
defined bitmap (maybe tiled if defined).
*/
class BitmapTexturePrimitive3D final : public TexturePrimitive3D
{
private:
/// bitmap fill attribute
attribute::FillGraphicAttribute maFillGraphicAttribute;
public:
/// constructor
BitmapTexturePrimitive3D(
const attribute::FillGraphicAttribute& rFillGraphicAttribute,
const Primitive3DContainer& rChildren,
const basegfx::B2DVector& rTextureSize,
bool bModulate,
bool bFilter);
/// data read access
const attribute::FillGraphicAttribute& getFillGraphicAttribute() const { return maFillGraphicAttribute; }
/// compare operator
virtual bool operator==(const BasePrimitive3D& rPrimitive) const override;
/// provide unique ID
DeclPrimitive3DIDBlock()
};
} // end of namespace primitive3d
} // end of namespace drawinglayer
namespace drawinglayer
{
namespace primitive3d
{
/** TransparenceTexturePrimitive3D class
This 3D primitive expands TexturePrimitive3D to a transparence texture
definition. For transparence definition, a gradient is used. The values in
that gradient will be interpreted as luminance Transparence-Values. All 3D
primitives embedded here will be shown with the defined transparence.
*/
class TransparenceTexturePrimitive3D final : public GradientTexturePrimitive3D
{
public:
/// constructor
TransparenceTexturePrimitive3D(
const attribute::FillGradientAttribute& rGradient,
const Primitive3DContainer& rChildren,
const basegfx::B2DVector& rTextureSize);
/// compare operator
virtual bool operator==(const BasePrimitive3D& rPrimitive) const override;
/// provide unique ID
DeclPrimitive3DIDBlock()
};
} // end of namespace primitive3d
} // end of namespace drawinglayer
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|