b311480e |
1 | // Created on: 2005-10-14 |
2 | // Created by: Mikhail KLOKOV |
3 | // Copyright (c) 2005-2012 OPEN CASCADE SAS |
4 | // |
5 | // The content of this file is subject to the Open CASCADE Technology Public |
6 | // License Version 6.5 (the "License"). You may not use the content of this file |
7 | // except in compliance with the License. Please obtain a copy of the License |
8 | // at http://www.opencascade.org and read it completely before using this file. |
9 | // |
10 | // The Initial Developer of the Original Code is Open CASCADE S.A.S., having its |
11 | // main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France. |
12 | // |
13 | // The Original Code and all software distributed under the License is |
14 | // distributed on an "AS IS" basis, without warranty of any kind, and the |
15 | // Initial Developer hereby disclaims all such warranties, including without |
16 | // limitation, any warranties of merchantability, fitness for a particular |
17 | // purpose or non-infringement. Please see the License for the specific terms |
18 | // and conditions governing the rights and limitations under the License. |
19 | |
7fd59977 |
20 | |
21 | |
22 | #include <IntTools_CurveRangeLocalizeData.ixx> |
23 | #include <IntTools_ListIteratorOfListOfCurveRangeSample.hxx> |
24 | #include <IntTools_ListIteratorOfListOfBox.hxx> |
25 | #include <IntTools_MapIteratorOfMapOfCurveSample.hxx> |
26 | |
27 | IntTools_CurveRangeLocalizeData::IntTools_CurveRangeLocalizeData(const Standard_Integer theNbSample, |
28 | const Standard_Real theMinRange) |
29 | { |
30 | myNbSampleC = theNbSample; |
31 | myMinRangeC = theMinRange; |
32 | } |
33 | |
34 | void IntTools_CurveRangeLocalizeData::AddOutRange(const IntTools_CurveRangeSample& theRange) |
35 | { |
36 | myMapRangeOut.Add(theRange); |
37 | myMapBox.UnBind(theRange); |
38 | } |
39 | |
40 | void IntTools_CurveRangeLocalizeData::AddBox(const IntTools_CurveRangeSample& theRange, |
41 | const Bnd_Box& theBox) |
42 | { |
43 | myMapBox.Bind(theRange, theBox); |
44 | } |
45 | |
46 | Standard_Boolean IntTools_CurveRangeLocalizeData::FindBox(const IntTools_CurveRangeSample& theRange,Bnd_Box& theBox) const |
47 | { |
48 | if(myMapBox.IsBound(theRange)) { |
49 | theBox = myMapBox(theRange); |
50 | return Standard_True; |
51 | } |
52 | return Standard_False; |
53 | } |
54 | |
55 | Standard_Boolean IntTools_CurveRangeLocalizeData::IsRangeOut(const IntTools_CurveRangeSample& theRange) const |
56 | { |
57 | return myMapRangeOut.Contains(theRange); |
58 | } |
59 | |
60 | void IntTools_CurveRangeLocalizeData::ListRangeOut(IntTools_ListOfCurveRangeSample& theList) const |
61 | { |
62 | IntTools_MapIteratorOfMapOfCurveSample anIt(myMapRangeOut); |
63 | |
64 | for(; anIt.More(); anIt.Next()) |
65 | theList.Append(anIt.Key()); |
66 | } |
67 | |