public class analyzer {
static {
try {
System.loadLibrary("CadExMTK");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String[] args) {
String aKey = MTKLicenseKey.Value();
if (!LicenseManager.Activate(aKey)) {
System.out.println("Failed to activate Manufacturing Toolkit license.");
System.exit(1);
}
if (args.length < 1 || args.length > 2) {
System.out.println("Usage: " + " <input_file> <input_resolution>, where:");
System.out.println(" <input_file> is a name of the file to be read");
System.out.print(" <input_resolution> is an optional argument that determine accuracy");
System.out.print(" of wall thickness calculation.");
System.out.print(" The larger the value, the higher the accuracy of the calculations,");
System.out.print("but greatly increase computation time and memory usage.");
System.out.println("Should be at least 100.");
System.exit(1);
}
String aSource = args[0];
int aResolution = 1000;
if (args.length == 2) {
aResolution = Integer.parseInt(args[1]);
}
if (aResolution < 100) {
System.out.format("WARNING: Input resolution \"%d\" < 100. Will be used default resolution.\n\n", aResolution);
aResolution = 1000;
}
Model aModel = new Model();
ModelReader aReader = new ModelReader();
if (!aReader.Read(new UTF16String(aSource), aModel)) {
System.out.println("Failed to read the file " + aSource);
System.exit(1);
}
System.out.format("Model: %s\n\n", aModel.Name());
PartProcessor aPartProcessor = new PartProcessor();
aPartProcessor.Resolution = aResolution;
ModelElementUniqueVisitor aVisitor = new ModelElementUniqueVisitor(aPartProcessor);
aModel.Accept(aVisitor);
}
static class PartProcessor extends SolidProcessor
{
public PartProcessor()
{
myAnalyzer = new WallThickness_Analyzer();
}
@Override
public void ProcessSolid(Solid theSolid)
{
WallThickness_Data aWTData = myAnalyzer.Perform(theSolid, Resolution);
PrintWTData(aWTData);
}
void PrintWTData(WallThickness_Data theData)
{
if (!theData.IsEmpty())
{
System.out.format(" Min thickness = %f mm\n", theData.MinThickness());
System.out.format(" Max thickness = %f mm\n", theData.MaxThickness());
}
else
{
System.out.println(" Failed to analyze the wall thickness of this entity.");
}
}
public long Resolution = 1000;
private WallThickness_Analyzer myAnalyzer;
}
}
Defines classes, types, enums, and functions related to topological entities and scene graph elements...
Defines classes, namespaces, enums, types, and global functions related to Manufacturing Toolkit.
Definition LicenseManager_LicenseError.hxx:30