You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdegraphics/kpovmodeler/pmpoint.h

123 lines
3.0 KiB

//-*-C++-*-
/*
**************************************************************************
description
--------------------
copyright : (C) 2000-2001 by Andreas Zehender
email : zehender@kde.org
**************************************************************************
**************************************************************************
* *
* This program 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. *
* *
**************************************************************************/
#ifndef PMPOINT_H
#define PMPOINT_H
#include "GL/gl.h"
#include <tqmemarray.h>
class PMVector;
class PMMatrix;
/**
* Class for 3d points.
*
* Used in @ref PMViewStructure.
*
* Optimized for rendering with opengl
*/
class PMPoint
{
public:
/**
* Creates a point with coordinates [0,0,0]
*/
PMPoint( );
/**
* Creates a point with coordinates [x,y,z]
*/
PMPoint( GLdouble x, GLdouble y, GLdouble z );
/**
* Creates a point from a vector. The size of the vector has to be 3
*/
PMPoint( const PMVector& v );
/**
* Copy constructor
*/
PMPoint( const PMPoint& p );
/**
* Returns a reference to a coordinate, 0:x, 1:y, 2:z
*/
GLdouble& operator[] ( int index ) { return m_coord[index];}
/**
* Returns a reference to a coordinate, 0:x, 1:y, 2:z
*/
const GLdouble& operator[] ( int index ) const { return m_coord[index];}
/**
* Returns the x coordinate
*/
GLdouble x( ) const { return m_coord[0]; }
/**
* Returns the y coordinate
*/
GLdouble y( ) const { return m_coord[1]; }
/**
* Returns the z coordinate
*/
GLdouble z( ) const { return m_coord[2]; }
/**
* Sets the x coordinate
*/
void setX( const GLdouble newx ) { m_coord[0] = newx; }
/**
* Sets the y coordinate
*/
void setY( const GLdouble newy ) { m_coord[1] = newy; }
/**
* Sets the z coordinate
*/
void setZ( const GLdouble newz ) { m_coord[2] = newz; }
/**
* Transforms the point p with the matrix m
* @see transform
*/
friend PMPoint operator* ( const PMMatrix& m, const PMPoint& p );
/**
* Assigns c to the point
*/
PMPoint& operator= ( const PMPoint& c );
/**
* Transforms the point with the matrix m. Same as p = m * p
*
* size must be 3!
*/
void transform( const PMMatrix& m );
private:
/**
* The coords. THIS MEMBER HAS TO BE THE FIRST AND ONLY ONE
* (for rendering with OpenGL)!
*/
GLdouble m_coord[3];
};
/**
* @ref TQMemArray of PMPoints
*/
typedef TQMemArray<PMPoint> PMPointArray;
#endif