/*************************************************************************
 *
 *  OpenOffice.org - a multi-platform office productivity suite
 *
 *  $RCSfile: sdrattribute.cxx,v $
 *
 *  $Revision: 1.5 $
 *
 *  last change: $Author: aw $ $Date: 2008-05-27 14:11:19 $
 *
 *  The Contents of this file are made available subject to
 *  the terms of GNU Lesser General Public License Version 2.1.
 *
 *
 *    GNU Lesser General Public License Version 2.1
 *    =============================================
 *    Copyright 2005 by Sun Microsystems, Inc.
 *    901 San Antonio Road, Palo Alto, CA 94303, USA
 *
 *    This library is free software; you can redistribute it and/or
 *    modify it under the terms of the GNU Lesser General Public
 *    License version 2.1, as published by the Free Software Foundation.
 *
 *    This library 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 for more details.
 *
 *    You should have received a copy of the GNU Lesser General Public
 *    License along with this library; if not, write to the Free Software
 *    Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 *    MA  02111-1307  USA
 *
 ************************************************************************/

// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_drawinglayer.hxx"

#include <drawinglayer/attribute/sdrshadowattribute.hxx>
#include <basegfx/vector/b2dvector.hxx>
#include <basegfx/color/bcolor.hxx>

//////////////////////////////////////////////////////////////////////////////

namespace drawinglayer
{
	namespace attribute
	{
		class ImpSdrShadowAttribute
		{
		public:
			// refcounter
			sal_uInt32								mnRefCount;

			// shadow definitions
			basegfx::B2DVector					maOffset;					// shadow offset 1/100th mm
			double								mfTransparence;				// [0.0 .. 1.0], 0.0==no transp.
			basegfx::BColor						maColor;					// color of shadow

			ImpSdrShadowAttribute(
				const basegfx::B2DVector& rOffset, 
                double fTransparence, 
                const basegfx::BColor& rColor)
			:	mnRefCount(0),
		    	maOffset(rOffset),
			    mfTransparence(fTransparence),
			    maColor(rColor)
		    {
		    }

			// data read access
			const basegfx::B2DVector& getOffset() const { return maOffset; }
			double getTransparence() const { return mfTransparence;	}
			const basegfx::BColor& getColor() const { return maColor; }

			bool operator==(const ImpSdrShadowAttribute& rCandidate) const
		    {
			    return (getOffset() == rCandidate.getOffset()
                    && getTransparence() == rCandidate.getTransparence()
				    && getColor() == rCandidate.getColor());
		    }
            
            static ImpSdrShadowAttribute* get_global_default()
            {
                static ImpSdrShadowAttribute* pDefault = 0;

                if(!pDefault)
                {
                    pDefault = new ImpSdrShadowAttribute(
                        basegfx::B2DVector(),
                        0.0, 
                        basegfx::BColor());

                    // never delete; start with RefCount 1, not 0
    			    pDefault->mnRefCount++;
                }

                return pDefault;
            }
		};

        SdrShadowAttribute::SdrShadowAttribute(
            const basegfx::B2DVector& rOffset, 
            double fTransparence, 
            const basegfx::BColor& rColor)
		:	mpSdrShadowAttribute(new ImpSdrShadowAttribute(
                rOffset, fTransparence, rColor))
		{
		}

		SdrShadowAttribute::SdrShadowAttribute()
        :	mpSdrShadowAttribute(ImpSdrShadowAttribute::get_global_default())
		{
			mpSdrShadowAttribute->mnRefCount++;
		}

        SdrShadowAttribute::SdrShadowAttribute(const SdrShadowAttribute& rCandidate)
		:	mpSdrShadowAttribute(rCandidate.mpSdrShadowAttribute)
		{
			mpSdrShadowAttribute->mnRefCount++;
		}

		SdrShadowAttribute::~SdrShadowAttribute()
		{
			if(mpSdrShadowAttribute->mnRefCount)
			{
				mpSdrShadowAttribute->mnRefCount--;
			}
			else
			{
				delete mpSdrShadowAttribute;
			}
		}

        bool SdrShadowAttribute::isDefault() const
        {
            return mpSdrShadowAttribute == ImpSdrShadowAttribute::get_global_default();
        }

        SdrShadowAttribute& SdrShadowAttribute::operator=(const SdrShadowAttribute& rCandidate)
		{
			if(rCandidate.mpSdrShadowAttribute != mpSdrShadowAttribute)
			{
				if(mpSdrShadowAttribute->mnRefCount)
				{
					mpSdrShadowAttribute->mnRefCount--;
				}
				else
				{
					delete mpSdrShadowAttribute;
				}
				
				mpSdrShadowAttribute = rCandidate.mpSdrShadowAttribute;
				mpSdrShadowAttribute->mnRefCount++;
			}

			return *this;
		}

		bool SdrShadowAttribute::operator==(const SdrShadowAttribute& rCandidate) const
		{
			if(rCandidate.mpSdrShadowAttribute == mpSdrShadowAttribute)
			{
				return true;
			}

			if(rCandidate.isDefault() != isDefault())
			{
				return false;
			}

			return (*rCandidate.mpSdrShadowAttribute == *mpSdrShadowAttribute);
		}

		const basegfx::B2DVector& SdrShadowAttribute::getOffset() const 
        { 
            return mpSdrShadowAttribute->getOffset(); 
        }

		double SdrShadowAttribute::getTransparence() const 
        { 
            return mpSdrShadowAttribute->getTransparence();	
        }

		const basegfx::BColor& SdrShadowAttribute::getColor() const 
        { 
            return mpSdrShadowAttribute->getColor(); 
        }
    } // end of namespace attribute
} // end of namespace drawinglayer

//////////////////////////////////////////////////////////////////////////////
// eof