/////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2002-2016, Open Design Alliance (the "Alliance"). // All rights reserved. // // This software and its documentation and related materials are owned by // the Alliance. The software may only be incorporated into application // programs owned by members of the Alliance, subject to a signed // Membership Agreement and Supplemental Software License Agreement with the // Alliance. The structure and organization of this software are the valuable // trade secrets of the Alliance and its suppliers. The software is also // protected by copyright law and international treaty provisions. Application // programs incorporating this software must include the following statement // with their copyright notices: // // This application incorporates Teigha(R) software pursuant to a license // agreement with Open Design Alliance. // Teigha(R) Copyright (C) 2002-2016 by Open Design Alliance. // All rights reserved. // // By use of this software, its documentation or related materials, you // acknowledge and accept the above terms. /////////////////////////////////////////////////////////////////////////////// #ifndef __ODGISELECTPROC__ #define __ODGISELECTPROC__ #include "Gi/GiConveyorNode.h" #include "Gs/Gs.h" #include "Ge/GeDoubleArray.h" #include "Ge/GePoint2dArray.h" class OdGiDeviation; class OdGiConveyorContext; #include "TD_PackPush.h" /** \details This class implements conveyor nodes performing selections. \remarks Behavior of this node depends on the selection mode. * If the mode is "fence", the points specify polyline vertices. * If the mode is "crossing" or "window", the points specify polygon vertices. If exactly two points are specified, the polygon is rectangle, with the points opposite vertices. For any input primitive, this node performs the following actions: 1. It checks for primitive intersections with the polygon border. 2. If intersections are found, the node MARKS current drawable, and stops to handle the primitive. 3. If the mode is mode is "crossing", and the primitive is inside the polygon, the node node MARKS the current drawable and stops to handle the primitive. 4. If the mode is "window", and primitive is outside the polygon, the node MARKS the current drawable and stops to handle the primitive. To MARK the current drawable is means to currentDrawableDesc()->markBySelection(true). If the drawable is neither a compound object nor uses nesting, means currentDrawableDesc()->markToSkip(true) This conveyor node is used for implementation OdGsBaseVectorizeView::select() and does not produce any output. */ class ODGI_EXPORT OdGiSelectProc : public OdGiConveyorNode { public: enum { kCheckMarkerOnChange = 1, kCheckMarkerOnViewModeChange = 2, kCheckMarkerFinish = 0x80000000 }; public: ODRX_DECLARE_MEMBERS(OdGiSelectProc); virtual void set(const OdGePoint2d* pPoints, OdUInt32 nPoints, OdGsView::SelectionMode mode, OdGsSelectionReactor* pReactor) = 0; virtual void get(OdGePoint2dArray& points, OdGsView::SelectionMode& mode) = 0; virtual void check_n_fire_selected(OdUInt32 flags = 0) = 0; /** Sets max deviation for curve tesselation. */ virtual void setDeviation(const OdGeDoubleArray& deviations) = 0; /** Sets deviation object to obtain max deviation for curve tesselation. */ virtual void setDeviation(const OdGiDeviation* pDeviation) = 0; /** Sets the draw context object (to access to traits, etc). */ virtual void setDrawContext(OdGiConveyorContext* pDrawCtx) = 0; /** Checks is selection reactor and selection mode supports subentity selection. */ static bool supportsSubentitySelection(const OdGiViewport *pView, OdGsView::SelectionMode mode, OdGsSelectionReactor* pReactor); }; typedef OdSmartPtr OdGiSelectProcPtr; #include "TD_PackPop.h" #endif //#ifndef __ODGISELECTPROC__