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:45
bool HasNext() const
Returns true if the iterator can be advanced with Next().
Definition Drawing.cxx:103
const Sheet & Next()
Returns the current sheet and advances the iterator.
Definition Drawing.cxx:109
Represents a single 2D drawing of a model.
Definition Drawing.hxx:32
Defines a visitor for drawing elements with empty implementation.
Definition ElementVisitor.hxx:58
Represents an area filled with a pattern.
Definition Hatch.hxx:32
const PiecewiseContour & Contour(size_t theIndex) const
Returns the contour.
Definition Hatch.cxx:109
PatternType
Definition Hatch.hxx:34
double Scale() const
Returns the scale of the hatch.
Definition Hatch.cxx:148
PatternType Pattern() const
Returns the pattern of the hatch.
Definition Hatch.cxx:135
size_t NumberOfContours() const
Returns the number of hatch contours.
Definition Hatch.cxx:100
double Angle() const
Returns the angle of the hatch.
Definition Hatch.cxx:161
size_t NumberOfCurves() const
Returns the number of curves currently composing the element.
Definition Drawing/Geometry.cxx:194
Iterates over views of a drawing sheet.
Definition Sheet.hxx:75
bool HasNext() const
Returns true if the iterator can be advanced with Next().
Definition Sheet.cxx:230
const View & Next()
Returns the current view and advances the iterator.
Definition Sheet.cxx:236
Represents a single sheet of a model drawing.
Definition Sheet.hxx:32
Defines a text for drawing.
Definition Text.hxx:36
const Geom::Point2d & TextOrigin() const
Returns a position of the text on the 2D plane.
Definition Text.cxx:156
const UTF16String & GetText() const
Returns a text.
Definition Text.cxx:143
float FontSize() const
Returns size of the font in points.
Definition Text.cxx:169
Properties TextProperties() const
Returns the properties of dimension text.
Definition Text.cxx:175
Represents a view on a drawing sheet.
Definition View.hxx:38
Defines a 3D point.
Definition Point2d.hxx:34
Provides MTK data model.
Definition Model.hxx:40
UTF16String Name() const
Returns a model name.
Definition Model.cxx:254
Reads supported formats, see Import section.
Definition ModelReader.hxx:33
void SetParameters(const ModelReaderParameters &theParameters)
Sets reader parameters.
Definition ModelReader.cxx:254
bool Read(const UTF16String &theFilePath, ModelData::Model &theModel)
Reads the file at the specified path into the specified model.
Definition ModelReader.cxx:280
Defines parameters of the ModelReader.
Definition ModelReaderParameters.hxx:29
void SetReadDrawing(bool theReadDrawing)
Sets whether a drawing should be read from the file.
Definition ModelReaderParameters.cxx:94
Defines a Unicode (UTF-16) string wrapping a standard string.
Definition UTF16String.hxx:30
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:30