| [4271] | 1 | /* -*- mode: C++ ; c-file-style: "stroustrup" -*- ***************************** | 
|---|
|  | 2 | * Qwt Widget Library | 
|---|
|  | 3 | * Copyright (C) 1997   Josef Wilgen | 
|---|
|  | 4 | * Copyright (C) 2002   Uwe Rathmann | 
|---|
|  | 5 | * | 
|---|
|  | 6 | * This library is free software; you can redistribute it and/or | 
|---|
|  | 7 | * modify it under the terms of the Qwt License, Version 1.0 | 
|---|
|  | 8 | *****************************************************************************/ | 
|---|
|  | 9 |  | 
|---|
|  | 10 | /*! \file */ | 
|---|
|  | 11 | #ifndef QWT_POINT_3D_H | 
|---|
|  | 12 | #define QWT_POINT_3D_H 1 | 
|---|
|  | 13 |  | 
|---|
|  | 14 | #include "qwt_global.h" | 
|---|
|  | 15 | #include <qpoint.h> | 
|---|
|  | 16 | #ifndef QT_NO_DEBUG_STREAM | 
|---|
|  | 17 | #include <qdebug.h> | 
|---|
|  | 18 | #endif | 
|---|
|  | 19 |  | 
|---|
|  | 20 | /*! | 
|---|
|  | 21 | \brief QwtPoint3D class defines a 3D point in double coordinates | 
|---|
|  | 22 | */ | 
|---|
|  | 23 |  | 
|---|
|  | 24 | class QWT_EXPORT QwtPoint3D | 
|---|
|  | 25 | { | 
|---|
|  | 26 | public: | 
|---|
|  | 27 | QwtPoint3D(); | 
|---|
|  | 28 | QwtPoint3D( double x, double y, double z ); | 
|---|
|  | 29 | QwtPoint3D( const QwtPoint3D & ); | 
|---|
|  | 30 | QwtPoint3D( const QPointF & ); | 
|---|
|  | 31 |  | 
|---|
|  | 32 | bool isNull()    const; | 
|---|
|  | 33 |  | 
|---|
|  | 34 | double x() const; | 
|---|
|  | 35 | double y() const; | 
|---|
|  | 36 | double z() const; | 
|---|
|  | 37 |  | 
|---|
|  | 38 | double &rx(); | 
|---|
|  | 39 | double &ry(); | 
|---|
|  | 40 | double &rz(); | 
|---|
|  | 41 |  | 
|---|
|  | 42 | void setX( double x ); | 
|---|
|  | 43 | void setY( double y ); | 
|---|
|  | 44 | void setZ( double y ); | 
|---|
|  | 45 |  | 
|---|
|  | 46 | QPointF toPoint() const; | 
|---|
|  | 47 |  | 
|---|
|  | 48 | bool operator==( const QwtPoint3D & ) const; | 
|---|
|  | 49 | bool operator!=( const QwtPoint3D & ) const; | 
|---|
|  | 50 |  | 
|---|
|  | 51 | private: | 
|---|
|  | 52 | double d_x; | 
|---|
|  | 53 | double d_y; | 
|---|
|  | 54 | double d_z; | 
|---|
|  | 55 | }; | 
|---|
|  | 56 |  | 
|---|
|  | 57 | Q_DECLARE_TYPEINFO(QwtPoint3D, Q_MOVABLE_TYPE); | 
|---|
|  | 58 |  | 
|---|
|  | 59 | #ifndef QT_NO_DEBUG_STREAM | 
|---|
|  | 60 | QWT_EXPORT QDebug operator<<( QDebug, const QwtPoint3D & ); | 
|---|
|  | 61 | #endif | 
|---|
|  | 62 |  | 
|---|
|  | 63 | /*! | 
|---|
|  | 64 | Constructs a null point. | 
|---|
|  | 65 | \sa isNull() | 
|---|
|  | 66 | */ | 
|---|
|  | 67 | inline QwtPoint3D::QwtPoint3D(): | 
|---|
|  | 68 | d_x( 0.0 ), | 
|---|
|  | 69 | d_y( 0.0 ), | 
|---|
|  | 70 | d_z( 0.0 ) | 
|---|
|  | 71 | { | 
|---|
|  | 72 | } | 
|---|
|  | 73 |  | 
|---|
|  | 74 | //! Constructs a point with coordinates specified by x, y and z. | 
|---|
|  | 75 | inline QwtPoint3D::QwtPoint3D( double x, double y, double z = 0.0 ): | 
|---|
|  | 76 | d_x( x ), | 
|---|
|  | 77 | d_y( y ), | 
|---|
|  | 78 | d_z( z ) | 
|---|
|  | 79 | { | 
|---|
|  | 80 | } | 
|---|
|  | 81 |  | 
|---|
|  | 82 | /*! | 
|---|
|  | 83 | Copy constructor. | 
|---|
|  | 84 | Constructs a point using the values of the point specified. | 
|---|
|  | 85 | */ | 
|---|
|  | 86 | inline QwtPoint3D::QwtPoint3D( const QwtPoint3D &other ): | 
|---|
|  | 87 | d_x( other.d_x ), | 
|---|
|  | 88 | d_y( other.d_y ), | 
|---|
|  | 89 | d_z( other.d_z ) | 
|---|
|  | 90 | { | 
|---|
|  | 91 | } | 
|---|
|  | 92 |  | 
|---|
|  | 93 | /*! | 
|---|
|  | 94 | Constructs a point with x and y coordinates from a 2D point, | 
|---|
|  | 95 | and a z coordinate of 0. | 
|---|
|  | 96 | */ | 
|---|
|  | 97 | inline QwtPoint3D::QwtPoint3D( const QPointF &other ): | 
|---|
|  | 98 | d_x( other.x() ), | 
|---|
|  | 99 | d_y( other.y() ), | 
|---|
|  | 100 | d_z( 0.0 ) | 
|---|
|  | 101 | { | 
|---|
|  | 102 | } | 
|---|
|  | 103 |  | 
|---|
|  | 104 | /*! | 
|---|
|  | 105 | Returns true if the point is null; otherwise returns false. | 
|---|
|  | 106 |  | 
|---|
|  | 107 | A point is considered to be null if x, y and z-coordinates | 
|---|
|  | 108 | are equal to zero. | 
|---|
|  | 109 | */ | 
|---|
|  | 110 | inline bool QwtPoint3D::isNull() const | 
|---|
|  | 111 | { | 
|---|
|  | 112 | return d_x == 0.0 && d_y == 0.0 && d_z == 0; | 
|---|
|  | 113 | } | 
|---|
|  | 114 |  | 
|---|
|  | 115 | //! Returns the x-coordinate of the point. | 
|---|
|  | 116 | inline double QwtPoint3D::x() const | 
|---|
|  | 117 | { | 
|---|
|  | 118 | return d_x; | 
|---|
|  | 119 | } | 
|---|
|  | 120 |  | 
|---|
|  | 121 | //! Returns the y-coordinate of the point. | 
|---|
|  | 122 | inline double QwtPoint3D::y() const | 
|---|
|  | 123 | { | 
|---|
|  | 124 | return d_y; | 
|---|
|  | 125 | } | 
|---|
|  | 126 |  | 
|---|
|  | 127 | //! Returns the z-coordinate of the point. | 
|---|
|  | 128 | inline double QwtPoint3D::z() const | 
|---|
|  | 129 | { | 
|---|
|  | 130 | return d_z; | 
|---|
|  | 131 | } | 
|---|
|  | 132 |  | 
|---|
|  | 133 | //! Returns a reference to the x-coordinate of the point. | 
|---|
|  | 134 | inline double &QwtPoint3D::rx() | 
|---|
|  | 135 | { | 
|---|
|  | 136 | return d_x; | 
|---|
|  | 137 | } | 
|---|
|  | 138 |  | 
|---|
|  | 139 | //! Returns a reference to the y-coordinate of the point. | 
|---|
|  | 140 | inline double &QwtPoint3D::ry() | 
|---|
|  | 141 | { | 
|---|
|  | 142 | return d_y; | 
|---|
|  | 143 | } | 
|---|
|  | 144 |  | 
|---|
|  | 145 | //! Returns a reference to the z-coordinate of the point. | 
|---|
|  | 146 | inline double &QwtPoint3D::rz() | 
|---|
|  | 147 | { | 
|---|
|  | 148 | return d_z; | 
|---|
|  | 149 | } | 
|---|
|  | 150 |  | 
|---|
|  | 151 | //! Sets the x-coordinate of the point to the value specified by x. | 
|---|
|  | 152 | inline void QwtPoint3D::setX( double x ) | 
|---|
|  | 153 | { | 
|---|
|  | 154 | d_x = x; | 
|---|
|  | 155 | } | 
|---|
|  | 156 |  | 
|---|
|  | 157 | //! Sets the y-coordinate of the point to the value specified by y. | 
|---|
|  | 158 | inline void QwtPoint3D::setY( double y ) | 
|---|
|  | 159 | { | 
|---|
|  | 160 | d_y = y; | 
|---|
|  | 161 | } | 
|---|
|  | 162 |  | 
|---|
|  | 163 | //! Sets the z-coordinate of the point to the value specified by z. | 
|---|
|  | 164 | inline void QwtPoint3D::setZ( double z ) | 
|---|
|  | 165 | { | 
|---|
|  | 166 | d_z = z; | 
|---|
|  | 167 | } | 
|---|
|  | 168 |  | 
|---|
|  | 169 | /*! | 
|---|
|  | 170 | Rounds 2D point, where the z coordinate is dropped. | 
|---|
|  | 171 | */ | 
|---|
|  | 172 | inline QPointF QwtPoint3D::toPoint() const | 
|---|
|  | 173 | { | 
|---|
|  | 174 | return QPointF( d_x, d_y ); | 
|---|
|  | 175 | } | 
|---|
|  | 176 |  | 
|---|
|  | 177 | //! Returns true if this point and other are equal; otherwise returns false. | 
|---|
|  | 178 | inline bool QwtPoint3D::operator==( const QwtPoint3D &other ) const | 
|---|
|  | 179 | { | 
|---|
|  | 180 | return ( d_x == other.d_x ) && ( d_y == other.d_y ) && ( d_z == other.d_z ); | 
|---|
|  | 181 | } | 
|---|
|  | 182 |  | 
|---|
|  | 183 | //! Returns true if this rect and other are different; otherwise returns false. | 
|---|
|  | 184 | inline bool QwtPoint3D::operator!=( const QwtPoint3D &other ) const | 
|---|
|  | 185 | { | 
|---|
|  | 186 | return !operator==( other ); | 
|---|
|  | 187 | } | 
|---|
|  | 188 |  | 
|---|
|  | 189 | #endif | 
|---|