DisplayShape.h
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef TRIALDISPLAY_DISPLAYSHAPE_H
00029 #define TRIALDISPLAY_DISPLAYSHAPE_H
00030
00031 #include <casa/aips.h>
00032 #include <casa/Arrays/Matrix.h>
00033 #include <casa/Containers/Record.h>
00034
00035 namespace casa {
00036
00037 class DSShape;
00038 class DSClosed;
00039 class DisplayEnums;
00040 class PixelCanvas;
00041 class DParameterColorChoice;
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077 class DisplayShape {
00078
00079 public:
00080
00081 enum HandleShape {Filled_Square=0, Open_Square, Filled_Circle,
00082 Open_Circle, Filled_Triangle, Open_Triangle
00083 };
00084
00085
00086
00087 DisplayShape();
00088
00089 DisplayShape(const DisplayShape& other);
00090
00091 virtual ~DisplayShape();
00092
00093
00094
00095
00096
00097 virtual void draw(PixelCanvas* pc);
00098 virtual void rotateAbout(const Float& relAngle, const Float& aboutX,
00099 const Float& aboutY) ;
00100 virtual void move(const Float& dX, const Float& dY);
00101
00102
00103
00104
00105
00106 virtual Matrix<Float> rotatePolygon(const Matrix<Float>& toRotate,
00107 const Float& angle,
00108 const Float& aboutX,
00109 const Float& aboutY);
00110
00111
00112 virtual Vector<Float> rotatePoint(const Vector<Float>& toRotate,
00113 const Float& angle,
00114 const Float& aboutX, const Float& aboutY);
00115
00116
00117 virtual Matrix<Float> translateMatrix(const Matrix<Float>& points,
00118 const Float& dx, const Float& dy);
00119
00120
00121
00122 virtual Bool inPolygon(const Matrix<Float>& points, const Float& xPos,
00123 const Float& yPos);
00124
00125
00126
00127
00128
00129 virtual Bool closestLine(const Matrix<Float>& points, const Float& xPos,
00130 const Float& yPos,
00131 Int& firstVert, Int& secondVert,
00132 const Bool& closedPoly = True);
00133
00134
00135
00136 virtual Bool closestPoint(const Matrix<Float>& points,
00137 const Float& xPos, const Float& yPos,
00138 Int& out);
00139
00140
00141 virtual Bool closestPoints(const Matrix<Float>& points,
00142 const Float& xPos, const Float& yPos,
00143 Int& outClosest, Int& outSecond);
00144
00145
00146 virtual Bool inObject(const Float& xPos, const Float& yPos) = 0;
00147
00148
00149 virtual Float toRadians(const Float& degrees);
00150
00151
00152 virtual Float toDegrees(const Float& radians);
00153
00154
00155 virtual void setCenter(const Float& xPos, const Float& yPos) = 0;
00156
00157
00158 virtual Vector<Float> getCenter() = 0;
00159
00160
00161 virtual void changePoint(const Vector<Float>& newPos) = 0;
00162
00163
00164
00165 virtual void changePoint(const Vector<Float>& newPoint,
00166 const Int nPoint) = 0;
00167
00168
00169
00170 virtual void addPoint(const Vector<Float>& ) { };
00171
00172
00173 virtual void rotate(const Float& angle) = 0;
00174
00175
00176 virtual void scale(const Float& scaleFactor) = 0;
00177
00178
00179
00180 virtual void addLocked(DisplayShape* toLock);
00181
00182
00183 virtual void removeLocked(DisplayShape* removeLock);
00184
00185
00186
00187 virtual void buildHandles(const Matrix<Float>& startPoints);
00188 virtual Matrix<Float> getHandleLocations();
00189 virtual void setHandlePositions(const Matrix<Float>& newPoints);
00190 virtual DSClosed* makeHandle(const Vector<Float>& newHandlePos);
00191 virtual void addHandle(const Vector<Float>& newHandlePos,
00192 const Bool& atEnd = True
00193 , const Int position = 0);
00194 virtual Bool removeHandle(const Vector<Float>& getRidOf);
00195 virtual Bool removeHandle(const Int nHandle);
00196
00197 virtual Bool onHandles(const Float& xPos, const Float& yPos);
00198 virtual Bool whichHandle(const Float& xPos, const Float& yPos, Int& out);
00199
00200 virtual void setDrawHandles(const Bool& shouldIDraw);
00201 virtual Bool drawingHandles() {
00202 return itsDrawHandles;
00203 }
00204 virtual void setHasHandles(const Bool& hasHandles);
00205 virtual void setHandleShape(const DisplayShape::HandleShape& shape);
00206 virtual void setHandleSize(const Int pixelSize);
00207 virtual void setHandleColor(const String& handleColor);
00208 virtual uInt nHandles();
00209
00210
00211
00212
00213 virtual void setColor(const String& newColor);
00214 virtual String getColor();
00215
00216
00217
00218
00219 virtual Record getOptions();
00220 virtual Bool setOptions(const Record& settings);
00221
00222
00223 virtual void recalculateScreenPosition() {}
00224
00225 private:
00226
00227 virtual void setDefaultOptions();
00228
00229
00230
00231 DParameterColorChoice* itsColor;
00232
00233
00234 PtrBlock<DSClosed*> itsHandles;
00235
00236
00237 PtrBlock<DisplayShape*> itsLocks;
00238
00239
00240
00241
00242 Bool itsHasHandles;
00243
00244
00245 Bool itsDrawHandles;
00246
00247
00248 Bool itsValidHandles;
00249
00250
00251
00252 String itsHandleColor;
00253 DisplayShape::HandleShape itsHandleShape;
00254 Int itsHandleSize;
00255
00256
00257 };
00258
00259 }
00260
00261 #endif
00262
00263
00264
00265