/****************************************************************************
** Copyright (C) 2001-2013 RibbonSoft, GmbH. All rights reserved.
**
** This file is part of the dxflib project.
**
** This file is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** Licensees holding valid dxflib Professional Edition licenses may use
** this file in accordance with the dxflib Commercial License
** Agreement provided with the Software.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
** See http://www.ribbonsoft.com for further details.
**
** Contact info@ribbonsoft.com if any conditions of this licensing are
** not clear to you.
**
**********************************************************************/

#ifndef DL_EXTRUSION_H
#define DL_EXTRUSION_H

#include "dl_global.h"

#include <math.h>


/**
 * Extrusion direction.
 *
 * @author Andrew Mustun
 */
class DXFLIB_EXPORT DL_Extrusion
{
public:

    /**
     * Default constructor.
     */
    DL_Extrusion()
    {
        direction = new double[3];
        setDirection( 0.0, 0.0, 1.0 );
        setElevation( 0.0 );
    }

    /**
     * Destructor.
     */
    ~DL_Extrusion()
    {
        delete[] direction;
    }

    /**
     * Constructor for DXF extrusion.
     *
     * @param direction Vector of axis along which the entity shall be extruded
     *                  this is also the Z axis of the Entity coordinate system
     * @param elevation Distance of the entities XY plane from the origin of the
     *                  world coordinate system
     */
    DL_Extrusion( double adx, double ady, double adz, double aelevation )
    {
        direction = new double[3];
        setDirection( adx, ady, adz );
        setElevation( aelevation );
    }

    /**
     * Sets the direction vector.
     */
    void setDirection( double dx, double dy, double dz )
    {
        direction[0]    = dx;
        direction[1]    = dy;
        direction[2]    = dz;
    }

    /**
     * @return direction vector.
     */
    double* getDirection() const
    {
        return direction;
    }

    /**
     * @return direction vector.
     */
    void getDirection( double dir[] ) const
    {
        dir[0]  = direction[0];
        dir[1]  = direction[1];
        dir[2]  = direction[2];
    }

    /**
     * Sets the elevation.
     */
    void setElevation( double aelevation )
    {
        this->elevation = aelevation;
    }

    /**
     * @return Elevation.
     */
    double getElevation() const
    {
        return elevation;
    }

    /**
     * Copies extrusion (deep copies) from another extrusion object.
     */
    DL_Extrusion operator =( const DL_Extrusion& extru )
    {
        setDirection( extru.direction[0], extru.direction[1], extru.direction[2] );
        setElevation( extru.elevation );

        return *this;
    }

private:
    double* direction;
    double  elevation;
};

#endif