summaryrefslogtreecommitdiff
path: root/drawinglayer/source/primitive3d/textureprimitive3d.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'drawinglayer/source/primitive3d/textureprimitive3d.cxx')
-rw-r--r--drawinglayer/source/primitive3d/textureprimitive3d.cxx152
1 files changed, 71 insertions, 81 deletions
diff --git a/drawinglayer/source/primitive3d/textureprimitive3d.cxx b/drawinglayer/source/primitive3d/textureprimitive3d.cxx
index a220c5c76ae4..876765b948d9 100644
--- a/drawinglayer/source/primitive3d/textureprimitive3d.cxx
+++ b/drawinglayer/source/primitive3d/textureprimitive3d.cxx
@@ -4,9 +4,9 @@
*
* $RCSfile: textureprimitive3d.cxx,v $
*
- * $Revision: 1.3 $
+ * $Revision: 1.4 $
*
- * last change: $Author: aw $ $Date: 2006-08-09 16:51:16 $
+ * last change: $Author: aw $ $Date: 2006-10-19 10:38:34 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
@@ -33,37 +33,39 @@
*
************************************************************************/
-#ifndef _DRAWINGLAYER_PRIMITIVE3D_TEXTUREPRIMITIVE3D_HXX
+#ifndef INCLUDED_DRAWINGLAYER_PRIMITIVE3D_TEXTUREPRIMITIVE3D_HXX
#include <drawinglayer/primitive3d/textureprimitive3d.hxx>
#endif
//////////////////////////////////////////////////////////////////////////////
+using namespace com::sun::star;
+
+//////////////////////////////////////////////////////////////////////////////
+
namespace drawinglayer
{
namespace primitive3d
{
- texturePrimitive3D::texturePrimitive3D(
- const primitiveVector3D& rPrimitiveVector,
+ TexturePrimitive3D::TexturePrimitive3D(
+ const Primitive3DSequence& rChildren,
const basegfx::B2DVector& rTextureSize,
bool bModulate, bool bFilter)
- : vectorPrimitive3D(rPrimitiveVector),
+ : GroupPrimitive3D(rChildren),
maTextureSize(rTextureSize),
mbModulate(bModulate),
mbFilter(bFilter)
{
}
- texturePrimitive3D::~texturePrimitive3D()
- {
- }
-
- bool texturePrimitive3D::operator==(const basePrimitive3D& rPrimitive) const
+ bool TexturePrimitive3D::operator==(const BasePrimitive3D& rPrimitive) const
{
- if(vectorPrimitive3D::operator==(rPrimitive))
+ if(GroupPrimitive3D::operator==(rPrimitive))
{
- const texturePrimitive3D& rCompare = (texturePrimitive3D&)rPrimitive;
- return (mbModulate == rCompare.mbModulate && mbFilter == rCompare.mbFilter);
+ const TexturePrimitive3D& rCompare = (TexturePrimitive3D&)rPrimitive;
+
+ return (getModulate() == rCompare.getModulate()
+ && getFilter() == rCompare.getFilter());
}
return false;
@@ -77,53 +79,51 @@ namespace drawinglayer
{
namespace primitive3d
{
- void simpleTransparenceTexturePrimitive3D::decompose(primitiveVector3D& rTarget)
+ Primitive3DSequence UnifiedAlphaTexturePrimitive3D::createLocalDecomposition(double /*fTime*/) const
{
- if(0.0 == mfTransparence)
+ if(0.0 == getTransparence())
{
- // no transparence used, so just add the content
- rTarget.insert(rTarget.end(), maPrimitiveVector.begin(), maPrimitiveVector.end());
+ // no transparence used, so just use content
+ return getChildren();
}
- else if(mfTransparence > 0.0 && mfTransparence < 1.0)
+ else if(getTransparence() > 0.0 && getTransparence() < 1.0)
{
- // create transparenceTexturePrimitive3D with fixed transparence as replacement
- const basegfx::BColor aGray(mfTransparence, mfTransparence, mfTransparence);
- const attribute::fillGradientAttribute aFillGradient(attribute::GRADIENTSTYLE_LINEAR, 0.0, 0.0, 0.0, 0.0, aGray, aGray, 1);
- basePrimitive3D* pNewTransparenceTexturePrimitive3D = new transparenceTexturePrimitive3D(aFillGradient, maPrimitiveVector, maTextureSize);
- rTarget.push_back(referencedPrimitive3D(*pNewTransparenceTexturePrimitive3D));
+ // create AlphaTexturePrimitive3D with fixed transparence as replacement
+ const basegfx::BColor aGray(getTransparence(), getTransparence(), getTransparence());
+ const attribute::FillGradientAttribute aFillGradient(attribute::GRADIENTSTYLE_LINEAR, 0.0, 0.0, 0.0, 0.0, aGray, aGray, 1);
+ const Primitive3DReference xRef(new AlphaTexturePrimitive3D(aFillGradient, getChildren(), getTextureSize()));
+ return Primitive3DSequence(&xRef, 1L);
}
else
{
// completely transparent or invalid definition, add nothing
+ return Primitive3DSequence();
}
}
- simpleTransparenceTexturePrimitive3D::simpleTransparenceTexturePrimitive3D(
+ UnifiedAlphaTexturePrimitive3D::UnifiedAlphaTexturePrimitive3D(
double fTransparence,
- const primitiveVector3D& rPrimitiveVector)
- : texturePrimitive3D(rPrimitiveVector, basegfx::B2DVector(), false, false),
+ const Primitive3DSequence& rChildren)
+ : TexturePrimitive3D(rChildren, basegfx::B2DVector(), false, false),
mfTransparence(fTransparence)
{
}
- simpleTransparenceTexturePrimitive3D::~simpleTransparenceTexturePrimitive3D()
+ bool UnifiedAlphaTexturePrimitive3D::operator==(const BasePrimitive3D& rPrimitive) const
{
- }
-
- bool simpleTransparenceTexturePrimitive3D::operator==(const basePrimitive3D& rPrimitive) const
- {
- if(texturePrimitive3D::operator==(rPrimitive))
+ if(TexturePrimitive3D::operator==(rPrimitive))
{
- const simpleTransparenceTexturePrimitive3D& rCompare = (simpleTransparenceTexturePrimitive3D&)rPrimitive;
- return (mfTransparence == rCompare.mfTransparence);
+ const UnifiedAlphaTexturePrimitive3D& rCompare = (UnifiedAlphaTexturePrimitive3D&)rPrimitive;
+
+ return (getTransparence() == rCompare.getTransparence());
}
return false;
}
- PrimitiveID simpleTransparenceTexturePrimitive3D::getID() const
+ sal_uInt32 UnifiedAlphaTexturePrimitive3D::getPrimitiveID() const
{
- return CreatePrimitiveID('S', 'T', 'X', '3');
+ return Create3DPrimitiveID('3','U','A','T');
}
} // end of namespace primitive3d
} // end of namespace drawinglayer
@@ -134,40 +134,37 @@ namespace drawinglayer
{
namespace primitive3d
{
- void gradientTexturePrimitive3D::decompose(primitiveVector3D& rTarget)
+ Primitive3DSequence GradientTexturePrimitive3D::createLocalDecomposition(double /*fTime*/) const
{
- rTarget.insert(rTarget.end(), maPrimitiveVector.begin(), maPrimitiveVector.end());
+ return getChildren();
}
- gradientTexturePrimitive3D::gradientTexturePrimitive3D(
- const attribute::fillGradientAttribute& rGradient,
- const primitiveVector3D& rPrimitiveVector,
+ GradientTexturePrimitive3D::GradientTexturePrimitive3D(
+ const attribute::FillGradientAttribute& rGradient,
+ const Primitive3DSequence& rChildren,
const basegfx::B2DVector& rTextureSize,
bool bModulate,
bool bFilter)
- : texturePrimitive3D(rPrimitiveVector, rTextureSize, bModulate, bFilter),
+ : TexturePrimitive3D(rChildren, rTextureSize, bModulate, bFilter),
maGradient(rGradient)
{
}
- gradientTexturePrimitive3D::~gradientTexturePrimitive3D()
+ bool GradientTexturePrimitive3D::operator==(const BasePrimitive3D& rPrimitive) const
{
- }
-
- bool gradientTexturePrimitive3D::operator==(const basePrimitive3D& rPrimitive) const
- {
- if(texturePrimitive3D::operator==(rPrimitive))
+ if(TexturePrimitive3D::operator==(rPrimitive))
{
- const gradientTexturePrimitive3D& rCompare = (gradientTexturePrimitive3D&)rPrimitive;
- return (maGradient == rCompare.maGradient);
+ const GradientTexturePrimitive3D& rCompare = (GradientTexturePrimitive3D&)rPrimitive;
+
+ return (getGradient() == rCompare.getGradient());
}
return false;
}
- PrimitiveID gradientTexturePrimitive3D::getID() const
+ sal_uInt32 GradientTexturePrimitive3D::getPrimitiveID() const
{
- return CreatePrimitiveID('G', 'R', 'X', '3');
+ return Create3DPrimitiveID('3','G','T','e');
}
} // end of namespace primitive3d
} // end of namespace drawinglayer
@@ -178,39 +175,36 @@ namespace drawinglayer
{
namespace primitive3d
{
- void bitmapTexturePrimitive3D::decompose(primitiveVector3D& rTarget)
+ Primitive3DSequence BitmapTexturePrimitive3D::createLocalDecomposition(double /*fTime*/) const
{
- rTarget.insert(rTarget.end(), maPrimitiveVector.begin(), maPrimitiveVector.end());
+ return getChildren();
}
- bitmapTexturePrimitive3D::bitmapTexturePrimitive3D(
- const attribute::fillBitmapAttribute& rBitmap,
- const primitiveVector3D& rPrimitiveVector,
+ BitmapTexturePrimitive3D::BitmapTexturePrimitive3D(
+ const attribute::FillBitmapAttribute& rBitmap,
+ const Primitive3DSequence& rChildren,
const basegfx::B2DVector& rTextureSize,
bool bModulate, bool bFilter)
- : texturePrimitive3D(rPrimitiveVector, rTextureSize, bModulate, bFilter),
+ : TexturePrimitive3D(rChildren, rTextureSize, bModulate, bFilter),
maBitmap(rBitmap)
{
}
- bitmapTexturePrimitive3D::~bitmapTexturePrimitive3D()
+ bool BitmapTexturePrimitive3D::operator==(const BasePrimitive3D& rPrimitive) const
{
- }
-
- bool bitmapTexturePrimitive3D::operator==(const basePrimitive3D& rPrimitive) const
- {
- if(texturePrimitive3D::operator==(rPrimitive))
+ if(TexturePrimitive3D::operator==(rPrimitive))
{
- const bitmapTexturePrimitive3D& rCompare = (bitmapTexturePrimitive3D&)rPrimitive;
- return (maBitmap == rCompare.maBitmap);
+ const BitmapTexturePrimitive3D& rCompare = (BitmapTexturePrimitive3D&)rPrimitive;
+
+ return (getBitmap() == rCompare.getBitmap());
}
return false;
}
- PrimitiveID bitmapTexturePrimitive3D::getID() const
+ sal_uInt32 BitmapTexturePrimitive3D::getPrimitiveID() const
{
- return CreatePrimitiveID('B', 'M', 'X', '3');
+ return Create3DPrimitiveID('3','B','T','e');
}
} // end of namespace primitive3d
} // end of namespace drawinglayer
@@ -221,26 +215,22 @@ namespace drawinglayer
{
namespace primitive3d
{
- transparenceTexturePrimitive3D::transparenceTexturePrimitive3D(
- const attribute::fillGradientAttribute& rGradient,
- const primitiveVector3D& rPrimitiveVector,
+ AlphaTexturePrimitive3D::AlphaTexturePrimitive3D(
+ const attribute::FillGradientAttribute& rGradient,
+ const Primitive3DSequence& rChildren,
const basegfx::B2DVector& rTextureSize)
- : gradientTexturePrimitive3D(rGradient, rPrimitiveVector, rTextureSize, false, false)
- {
- }
-
- transparenceTexturePrimitive3D::~transparenceTexturePrimitive3D()
+ : GradientTexturePrimitive3D(rGradient, rChildren, rTextureSize, false, false)
{
}
- bool transparenceTexturePrimitive3D::operator==(const basePrimitive3D& rPrimitive) const
+ bool AlphaTexturePrimitive3D::operator==(const BasePrimitive3D& rPrimitive) const
{
- return (gradientTexturePrimitive3D::operator==(rPrimitive));
+ return (GradientTexturePrimitive3D::operator==(rPrimitive));
}
- PrimitiveID transparenceTexturePrimitive3D::getID() const
+ sal_uInt32 AlphaTexturePrimitive3D::getPrimitiveID() const
{
- return CreatePrimitiveID('T', 'R', 'X', '3');
+ return Create3DPrimitiveID('3','A','T','e');
}
} // end of namespace primitive3d
} // end of namespace drawinglayer