using System;
namespace drawings
{
class Program
{
static void ExploreSheet(
Sheet theSheet)
{
uint aViewCounter = 0;
{
Console.WriteLine("---- View <" + aViewCounter + ">");
DrawingElementVisitor aVisitor = new DrawingElementVisitor();
aViewCounter++;
}
}
static void ExploreDrawing(
Drawing theDrawing)
{
uint aSheetCounter = 0;
{
Console.WriteLine("-- Sheet <" + aSheetCounter + ">");
ExploreSheet(aSheet);
aSheetCounter++;
}
}
static int Main(string[] args)
{
string aKey = MTKLicenseKey.Value();
if (!LicenseManager.Activate(aKey))
{
Console.WriteLine("Failed to activate Manufacturing Toolkit license.");
return 1;
}
if (args.Length != 1)
{
Console.WriteLine("Usage: " +
$"{System.Reflection.Assembly.GetExecutingAssembly().Location} <input_file>, where:");
Console.WriteLine($" <input_file> is a name of the file to be read");
Console.WriteLine($"");
return 1;
}
string aSource = args[0];
{
Console.WriteLine("Failed to read the file " + aSource);
return 1;
}
Drawing aDrawing = aModel.
Drawing();
{
Console.WriteLine("The model doesn't contain a drawing");
return 1;
}
Console.WriteLine(
"Drawing \"" + aModel.
Name() +
"\":");
ExploreDrawing(aDrawing);
return 0;
}
}
{
public override void Apply(
CurveSet theElement)
{
Console.WriteLine("------- CurveSet <" + myCurveSetCounter + ">");
Console.WriteLine(
"--------- number of curves: " + theElement.
NumberOfCurves());
myCurveSetCounter++;
}
public override void Apply(
Hatch theElement)
{
Console.WriteLine("------- Hatch <" + myHatchCounter + ">");
Console.WriteLine(
"--------- number of contours: " + theElement.
NumberOfContours());
uint aNumberOfCurves = 0;
{
}
Console.WriteLine("--------- number of curves: " + aNumberOfCurves);
Console.WriteLine(
"--------- pattern: " + PatternToString (theElement.
Pattern()));
Console.WriteLine(
"--------- angle: " + theElement.
Angle());
Console.WriteLine(
"--------- scale: " + theElement.
Scale());
myHatchCounter++;
}
public override void Apply(
Text theElement)
{
Console.WriteLine("------- Text <" + myTextCounter + ">");
Console.WriteLine(
"--------- text: \"" + theElement.
GetText() +
"\"");
Console.WriteLine(
"--------- origin: " + PointToString(theElement.
TextOrigin()));
Console.WriteLine(
"--------- rotation: " + theElement.
TextProperties().
Rotation());
Console.WriteLine(
"--------- font size: " + theElement.
FontSize());
myTextCounter++;
}
private String PointToString(
Point2d thePoint)
{
return "(" + thePoint.
X() +
"; " + thePoint.
Y() +
")";
}
{
switch (thePattern)
{
default: return "Other";
}
}
private uint myCurveSetCounter = 0;
private uint myHatchCounter = 0;
private uint myTextCounter = 0;
}
}
Describes drawing elements composed of 2D curves.
Definition Drawing/Geometry.hxx:43
size_t NumberOfCurves() const
Returns the number of curves currently composing the element.
Definition Drawing/Geometry.cxx:78
Iterator over sheets of a drawing.
Definition Drawing.hxx:44
bool HasNext() const
Returns true if the iterator can be advanced with Next().
Definition Drawing.cxx:102
const Sheet & Next()
Returns the current sheet and advances the iterator.
Definition Drawing.cxx:108
Represents a single 2D drawing of a model.
Definition Drawing.hxx:30
Defines a visitor for drawing elements with empty implementation.
Definition ElementVisitor.hxx:56
Represents an area filled with a pattern.
Definition Hatch.hxx:29
const PiecewiseContour & Contour(size_t theIndex) const
Returns the contour.
Definition Hatch.cxx:108
PatternType
Represents pattern for drawing hatch.
Definition Hatch.hxx:32
double Scale() const
Returns the scale of the hatch.
Definition Hatch.cxx:147
PatternType Pattern() const
Returns the pattern of the hatch.
Definition Hatch.cxx:134
size_t NumberOfContours() const
Returns the number of hatch contours.
Definition Hatch.cxx:99
double Angle() const
Returns the angle of the hatch.
Definition Hatch.cxx:160
size_t NumberOfCurves() const
Returns the number of curves currently composing the element.
Definition Drawing/Geometry.cxx:197
Iterates over views of a drawing sheet.
Definition Sheet.hxx:72
bool HasNext() const
Returns true if the iterator can be advanced with Next().
Definition Sheet.cxx:212
const View & Next()
Returns the current view and advances the iterator.
Definition Sheet.cxx:218
Represents a single sheet of a model drawing.
Definition Sheet.hxx:30
Defines a text for drawing.
Definition Text.hxx:35
const Geom::Point2d & TextOrigin() const
Returns a position of the text on the 2D plane.
Definition Text.cxx:158
const UTF16String & GetText() const
Returns a text.
Definition Text.cxx:145
float FontSize() const
Returns size of the font in points.
Definition Text.cxx:171
Properties TextProperties() const
Returns the properties of dimension text.
Definition Text.cxx:177
Represents a view on a drawing sheet.
Definition View.hxx:37
Defines a 3D point.
Definition Point2d.hxx:32
Provides MTK data model.
Definition Model.hxx:39
UTF16String Name() const
Returns a model name.
Definition Model.cxx:256
Reads supported formats, see Import section.
Definition ModelReader.hxx:32
void SetParameters(const ModelReaderParameters &theParameters)
Sets reader parameters.
Definition ModelReader.cxx:262
bool Read(const UTF16String &theFilePath, ModelData::Model &theModel)
Reads the file at the specified path into the specified model.
Definition ModelReader.cxx:288
Defines parameters of the ModelReader.
Definition ModelReaderParameters.hxx:27
void SetReadDrawing(bool theReadDrawing)
Sets whether a drawing should be read from the file.
Definition ModelReaderParameters.cxx:98
Defines a Unicode (UTF-16) string wrapping a standard string.
Definition UTF16String.hxx:29
Contains classes, types and enums related to drawings.
Contains classes, types, enums, and functions related to geometric entities.
Defines classes, types, enums, and functions related to topological entities and scene graph elements...
Contains classes, namespaces, enums, types, and global functions related to Manufacturing Toolkit.
Definition LicenseManager_LicenseError.hxx:29