blob: ebb208d0e1c53f01e3923de1e7ed6bb79f8beef9 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
//--------------------------------------------------------------------
//
// File Name : IGESGraph_LineFontDefPattern.cxx
// Date :
// Author : CKY / Contract Toubro-Larsen
// Copyright : MATRA-DATAVISION 1993
//
//--------------------------------------------------------------------
#include <IGESGraph_LineFontDefPattern.ixx>
#include <Standard_DimensionMismatch.hxx>
IGESGraph_LineFontDefPattern::IGESGraph_LineFontDefPattern () { }
// This class inherits from IGESData_LineFontEntity
void IGESGraph_LineFontDefPattern::Init
(const Handle(TColStd_HArray1OfReal)& allSegLength,
const Handle(TCollection_HAsciiString)& aPattern)
{
if (allSegLength->Lower() != 1)
Standard_DimensionMismatch::Raise("IGESGraph_LineFontDefPattern : Init");
theSegmentLengths = allSegLength;
theDisplayPattern = aPattern;
InitTypeAndForm(304,2);
}
Standard_Integer IGESGraph_LineFontDefPattern::NbSegments () const
{
return theSegmentLengths->Length();
}
Standard_Real IGESGraph_LineFontDefPattern::Length
(const Standard_Integer Index) const
{
return theSegmentLengths->Value(Index);
// if Index is out of bound HArray1 will raise OutOfRange exception
}
Handle(TCollection_HAsciiString) IGESGraph_LineFontDefPattern::DisplayPattern
() const
{
return theDisplayPattern;
}
Standard_Boolean IGESGraph_LineFontDefPattern::IsVisible
(const Standard_Integer Index) const
{
Standard_Integer nbSegs = theSegmentLengths->Length();
if (Index <= 0 || Index > nbSegs) return Standard_False;
// Get the Character out of String, which contains the required BIT
char tempStr[2];
Standard_Integer length = theDisplayPattern->Length();
tempStr[0] = theDisplayPattern->Value(length - ((nbSegs - Index) / 4));
tempStr[1] = 0;
Standard_Integer tempVal =
(Standard_Integer) strtol(tempStr, (char **)NULL, 16);
// Now get the BIT out of tempVal
Standard_Integer mask = 0x01;
mask <<= ((nbSegs - Index) % 4);
return ((tempVal & mask) != 0);
}
|