Ellipse.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
00029 #ifndef REGION_ELLIPSE_H_
00030 #define REGION_ELLIPSE_H_
00031
00032 #include <display/region/Rectangle.h>
00033 #include <casa/BasicSL/String.h>
00034 #include <list>
00035
00036 namespace casa {
00037
00038 class PanelDisplay;
00039 class AnnRegion;
00040
00041 namespace viewer {
00042
00043
00044 class QtRegionSourceKernel;
00045
00046
00047
00048
00049 class Ellipse : public Rectangle {
00050 public:
00051 ~Ellipse( );
00052 Ellipse( WorldCanvas *wc, QtRegionDock *d, double x1, double y1, double x2, double y2);
00053
00054
00055 Ellipse( QtRegionSourceKernel *factory, WorldCanvas *wc, double x1, double y1, double x2, double y2, bool hold_signals=false );
00056
00057
00058 unsigned int mouseMovement( double x, double y, bool other_selected );
00059
00060 AnnotationBase *annotation( ) const;
00061
00062 bool flag( MSAsRaster * ) {
00063 return false;
00064 }
00065
00066
00067 region::RegionTypes type( ) const {
00068 return region::EllipseRegion;
00069 }
00070
00071 protected:
00072 std::list<SHARED_PTR<RegionInfo> > *generate_dds_centers( );
00073 ImageRegion *get_image_region( DisplayData* ) const;
00074
00075
00076
00077
00078 void generate_nonimage_statistics( DisplayData*, std::list<RegionInfo> * ) { }
00079
00080 virtual void fetch_region_details( region::RegionTypes &type, std::vector<std::pair<int,int> > &pixel_pts,
00081 std::vector<std::pair<double,double> > &world_pts ) const;
00082
00083 void drawRegion( bool );
00084
00085
00086 private:
00087 std::pair<Vector<Quantity>,Vector<Quantity> > posAndRadii( ) const;
00088 bool output_region( ds9writer &out, WorldCanvas *wc, const std::vector<std::pair<double,double> > &pts ) const;
00089
00090 };
00091 }
00092 }
00093
00094 #endif