84b58f40f12d0ca21208bcc739ba442c50598ede
[occt.git] / src / IVtkTools / IVtkTools_SubPolyDataFilter.hxx
1 // Created on: 2011-10-27
2 // Created by: Roman KOZLOV
3 // Copyright (c) 2011-2014 OPEN CASCADE SAS 
4 // 
5 // This file is part of Open CASCADE Technology software library.
6 //
7 // This library is free software; you can redistribute it and/or modify it under
8 // the terms of the GNU Lesser General Public License version 2.1 as published
9 // by the Free Software Foundation, with special exception defined in the file
10 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
11 // distribution for complete text of the license and disclaimer of any warranty.
12 //
13 // Alternatively, this file may be used under the terms of Open CASCADE
14 // commercial license or contractual agreement.
15
16 #ifndef IVtkTOOLS_SUBPOLYDATAFILTER_H
17 #define IVtkTOOLS_SUBPOLYDATAFILTER_H
18
19 #include <IVtkTools.hxx>
20
21 #include "vtkPolyDataAlgorithm.h"
22
23 #ifdef _MSC_VER
24 #pragma warning(push)
25 #pragma warning(disable: 4251) // avoid warning C4251: "class needs to have dll-interface..."
26 #endif
27
28 //! @class IVtkTools_SubPolyDataFilter 
29 //! @brief Cells filter according to the given set of cells ids.
30 class IVtkTools_EXPORT IVtkTools_SubPolyDataFilter : public vtkPolyDataAlgorithm
31 {
32 public:
33   vtkTypeMacro(IVtkTools_SubPolyDataFilter,vtkPolyDataAlgorithm)
34
35   static IVtkTools_SubPolyDataFilter *New();
36   void PrintSelf (std::ostream& theOs, vtkIndent theIndent);
37
38   //! Set ids to be passed through this filter.
39   void SetData(const IVtk_IdTypeMap theSet);
40
41   //! Add ids to be passed through this filter.
42   void AddData(const IVtk_IdTypeMap theSet);
43
44   //! Set ids to be passed through this filter.
45   void SetData(const IVtk_ShapeIdList theIds);
46
47   //! Add ids to be passed through this filter.
48   void AddData(const IVtk_ShapeIdList theIds);
49
50   //! Clear ids set to be passed through this filter.
51   void Clear();
52
53   //! Set ids array name.
54   void SetIdsArrayName(const char* theArrayName);
55
56   void SetDoFiltering (const bool theDoFiltering);
57
58 protected:
59   //! @brief Filter cells according to the given set of ids.
60   //! Note: Data arrays are not passed through if filtering is turned on.
61   virtual int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
62
63   IVtkTools_SubPolyDataFilter();
64   virtual ~IVtkTools_SubPolyDataFilter();
65
66 protected:
67   //! Set of ids to be passed through this filter.
68   IVtk_IdTypeMap myIdsSet;
69   const char*    myIdsArrayName;
70   bool           myDoFiltering;
71 };
72
73 #ifdef _MSC_VER
74 #pragma warning(pop)
75 #endif
76
77 #endif // IVtkTOOLS_SUBPOLYDATAFILTER_H