1 | // This file is a part of Framsticks SDK. http://www.framsticks.com/ |
---|

2 | // Copyright (C) 1999-2021 Maciej Komosinski and Szymon Ulatowski. |
---|

3 | // See LICENSE.txt for details. |
---|

4 | |
---|

5 | #ifndef _MODELGEOMETRYINFO_H_ |
---|

6 | #define _MODELGEOMETRYINFO_H_ |
---|

7 | |
---|

8 | #include <frams/model/model.h> |
---|

9 | #include <frams/util/3d.h> |
---|

10 | #include <frams/util/list.h> |
---|

11 | |
---|

12 | |
---|

13 | /** |
---|

14 | Currently, the three functions area(), volume() and findSizesAndAxes() are independent and self-sufficient. |
---|

15 | Each of them converts the input model to SolidsShapeTypeModel if necessary. |
---|

16 | Were these functions to be called multiple times for the same model, this would be inefficient |
---|

17 | (the potential conversion of the same model would take place multiple times). |
---|

18 | |
---|

19 | To improve efficiency, these functions should not have the Model argument. |
---|

20 | Instead, another function should be introduced to set the model, the conversion to SolidsShapeTypeModel |
---|

21 | should take place in this function once, and these three functions would then always use the converted model. |
---|

22 | A similar optimization is already implemented in the ModelGeometry class that provides FramScript access to ModelGeometryInfo. |
---|

23 | */ |
---|

24 | namespace ModelGeometryInfo |
---|

25 | { |
---|

26 | double area(Model &model, const double density); |
---|

27 | double volume(Model &model, const double density); |
---|

28 | void findSizesAndAxes(Model &model, const double density, Pt3D &sizes, Orient &axes); |
---|

29 | ExtObject getVoxels(Model &model, const double density); |
---|

30 | |
---|

31 | void boundingBox(const Model &model, Pt3D &lowerBoundary, Pt3D &upperBoundary); |
---|

32 | void boundingBox(const Part *part, Pt3D &lowerBoundary, Pt3D &upperBoundary); |
---|

33 | double externalAreaOfPart(const Model &model, const int partIndex, const double density); |
---|

34 | double externalAreaOfEllipsoid(const Model &model, const int partIndex, const double density); |
---|

35 | double externalAreaOfCuboid(const Model &model, const int partIndex, const double density); |
---|

36 | double externalAreaOfCylinder(const Model &model, const int partIndex, const double density); |
---|

37 | } |
---|

38 | |
---|

39 | #endif |
---|