// MapDrawItem.h: interface for the CMapDrawItem class. // ////////////////////////////////////////////////////////////////////// #if !defined(AFX_MAPDRAWITEM_H__66DFD065_E39E_4A47_9CD0_02E9013B2469__INCLUDED_) #define AFX_MAPDRAWITEM_H__66DFD065_E39E_4A47_9CD0_02E9013B2469__INCLUDED_ #if _MSC_VER > 1000 #pragma once #endif // _MSC_VER > 1000 #include #include #define ITEM_TYPE_POINT 0 #define ITEM_TYPE_POLYGON 1 #define ITEM_TYPE_MAP 2 #define NO_RAW_STAGE -10000.f #define RAW_STAGE_TEST -9990.f #define NO_REALIGN_COLOR 5 #define NAV_SKIP_COLOR 6 #define DEFAULT_POINT_COLOR 0 #define DEFAULT_POLY_COLOR 1 #define DEFAULT_MAP_COLOR 2 #define DEFAULT_SUPER_COLOR 3 #define POINT_ACQUIRE_COLOR 15 #define MAP_ACQUIRE_COLOR 16 #define HIGHLIGHT_COLOR 17 #define POLY_HIGHLIGHT_COLOR 18 #define CONT_COLOR_BASE_IND 7 #define NAV_FLAG_DRAWN_ON_FFT 0x1 class CMapDrawItem { public: COLORREF GetColor(bool highlight); static COLORREF GetContourColor(int index); void DeletePoint(int index); void AppendPoint(float inX, float inY); void AddPoint(float inX, float inY, int index); void AllocatePoints(int numPoints); CMapDrawItem(); CMapDrawItem(CMapDrawItem *item); virtual ~CMapDrawItem(); CMapDrawItem *Duplicate(); bool IsMap() { return mType == ITEM_TYPE_MAP; }; bool IsPoint() { return mType == ITEM_TYPE_POINT; }; bool IsPolygon() { return mType == ITEM_TYPE_POLYGON; }; bool IsNotMap() { return mType != ITEM_TYPE_MAP; }; bool IsNotPoint() { return mType != ITEM_TYPE_POINT; }; bool IsNotPolygon() { return mType != ITEM_TYPE_POLYGON; }; // Maintain Duplicate code when adding members that are allocated or shouldn't be copied int mNumPoints; // Number of points int mMaxPoints; // Current size of point array float *mPtX; // Arrays for X and Y point coordinates float *mPtY; CString mLabel; // Label string drawn on screen int mColor; // Color index CString mNote; // Long note string float mStageX; // Stage position float mStageY; float mStageZ; float mRawStageX; // Unadjusted stage position float mRawStageY; BOOL mCorner; // Flag for corner point BOOL mDraw; // Flag to draw BOOL mAcquire; // Flag to acquire area BOOL mRotOnLoad; // Flag to rotate when load int mFlags; // Flags defined in NAV_FLAGS int mRegPoint; // Registration point number int mRegistration; // Registration at which item exists int mOriginalReg; // Original registration int mOldReg; // Registration before last transform int mType; // Type = point, polygon, map CString mMapFile; // Full name of file where map lives CString mTrimmedName; // Trimmed name BOOL mMapMontage; // Flag that map is a montage int mMapSection; // Section number in file int mMapBinning; // Binning at which map was taken or of initial map image int mMontBinning; // Actual binning of montage used to make the map int mMontUseStage; // 1 if montage was taken with stage, 0 if not, -1 if unknown float mBacklashX; // Backlash when a montage was taken or for position generally float mBacklashY; int mMapMagInd; // Magnification int mMapCamera; // Camera float mMapExposure; // Exposure time for original map images float mMapSettling; // Drift settling int mShutterMode; // Shutter mode int mK2ReadMode; // Read mode for K2 camera float mDefocusOffset; // Defocus offset for map based on View images float mNetViewShiftX; // And net IS offset for a View image map float mNetViewShiftY; float mViewBeamShiftX; // Incremental beam shift and tilt to apply for a View image map float mViewBeamShiftY; float mViewBeamTiltX; float mViewBeamTiltY; int mMapAlpha; // Alpha value on JEOL int mMapID; // Unique ID number int mGroupID; // Unique ID for supermontage or other grouping int mPolygonID; // ID of polygon used to define supermont int mDrawnOnMapID; // ID of map point/polygon was drawn on int mAtSamePosID; // Items with this matching were taken at same raw stage pos int mFitToPolygonID; // ID of polygon that montage was fit to int mPieceDrawnOn; // Index of piece in map that item was drawn on float mXinPiece; // Coordinates in unbinned piece float mYinPiece; ScaleMat mMapScaleMat; // Scale matrix for drawing int mMapWidth; // Size of image at which scale matrix was defined int mMapHeight; int mTextExtent; float mMapMinScale; // Min and max scale values of image when map was defined float mMapMaxScale; int mMapFramesX; // Number of montage frames when montage acquired int mMapFramesY; int mMapSpotSize; // Illumination state when map was taken double mMapIntensity; int mMapProbeMode; float mMapTiltAngle; // Tilt angle of image BOOL mMapSlitIn; // Filter state when map was taken; ignore energy loss float mMapSlitWidth; int mMapLowDoseConSet; int mRealignedID; // ID of lower mag map with nearby realign error float mRealignErrX; // Final stage error of that realign operation float mRealignErrY; float mLocalRealiErrX; // Error in second round of realign operation float mLocalRealiErrY; int mRealignReg; // Original registration of that realign int mImported; // Indicator of an imported map or point drawn on one int mOldImported; // Value of import flag before transform int mRegisteredToID; // ID of map that an imported map was registered to int mOldDrawnOnID; // Value of mDrawnOnMapID before transform for point on import int mOldRegToID; // Value of mRegisteredToID before transform int mImageType; // STORE_TYPE flag for image float mFocusAxisPos; // Axis position of low dose focus area BOOL mRotateFocusAxis; // Whether rotate axis is on int mFocusAxisAngle; // Angle of rotation if rotating, 0 otherwise int mFocusXoffset; // X and Y displacement of focus area on camera int mFocusYoffset; int mSuperMontX; // Camera coordinate of this montage in supermontage int mSuperMontY; float *mGridMapXform; // Full transform from reload, if used on items (new/delete) signed char mNumXholes, mNumYholes; // Defined array size for multi-hole acquire short mNumSkipHoles; // Number of holes to skip unsigned char *mSkipHolePos; // list of x,y indexes of holes to skip (new/delete) float mXHoleISSpacing[3]; // IS vectors from hole finding, valid at map's mag float mYHoleISSpacing[3]; float mTSstartAngle; // Special stored starting and ending angle for tilt series float mTSendAngle; float mTSbidirAngle; // And bidirectional start angle float mTargetDefocus; // Target defocus to set when acquiring this item float mMarkerShiftX, mMarkerShiftY; // Shift applied to map in shift to marker int mShiftCohortID; // Identifier of maps shifted together int mMoveStageID; // Temporary flag to keep track of item stage was moved to std::map mUserValueMap; int mFilePropIndex; // Indexes into arrays of file properties and other params int mTSparamIndex; int mMontParamIndex; int mStateIndex; CString mFileToOpen; // Filename of file to open at this item }; #endif // !defined(AFX_MAPDRAWITEM_H__66DFD065_E39E_4A47_9CD0_02E9013B2469__INCLUDED_)