Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revision | |||
| doc:mesh_reasoning [2014/06/05 11:38] – external edit 127.0.0.1 | doc:mesh_reasoning [2014/11/28 17:03] (current) – admin | ||
|---|---|---|---|
| Line 123: | Line 123: | ||
| * Handles (computable class for cylindrical handles, class ' | * Handles (computable class for cylindrical handles, class ' | ||
| + | |||
| + | |||
| + | |||
| + | |||
| + | |||
| + | ===== CAD models as source of geometric information ===== | ||
| + | |||
| + | CAD models can not only be used for visualization purposes, but can also serve as source of information about the geometry of the objects in the scene. For example, the dimensions of their bounding boxes can be read using the following commands: | ||
| + | |||
| + | Height of the model in meters | ||
| + | < | ||
| + | |||
| + | Width of the model in meters | ||
| + | < | ||
| + | |||
| + | Depth of the model in meters | ||
| + | < | ||
| + | |||
| + | As a reminder, x = width, z = height, and y = depth. For a full list of query predicates check knowrob_cad_models/ | ||
| + | |||
| + | |||
| + | ===== Writing your own CAD model parser ===== | ||
| + | |||
| + | The system comes with parsers for Collada and .ply files. You can, however, easily write your own parser for other file formats. | ||
| + | |||
| + | ===== Structure of a parser ===== | ||
| + | |||
| + | The base class for all parsers should be '' | ||
| + | |||
| + | ==== Model Parser ==== | ||
| + | |||
| + | The model parser is used to parse a CAD Model from a given file and is the base class for all parsers. | ||
| + | The parser loads a file and " | ||
| + | |||
| + | A special feature of the ModelParser is buffering: If a model has been parsed it will be stored in a model buffer. So if the same model should be parsed again it will be taken from this buffer instead of parsing it again. Keep in mind that if you change something in a Group of a specific model it will affect all the other existing instances of this model. | ||
| + | |||
| + | ==== List of available parsers ==== | ||
| + | |||
| + | Currently the following file formats are supported: | ||
| + | * [[#Collada Parser|Collada]]: | ||
| + | * [[#PLY Parser|Polygon File Format]]: *.ply | ||
| + | |||
| + | === Collada Parser === | ||
| + | The collada parser uses the [[[http:// | ||
| + | |||
| + | .kmz files are compressed Collada files (zip) and will be extracted into a temporary directory and parsed from there. | ||
| + | |||
| + | ==== How to create a new parser? ==== | ||
| + | Check out ColladaParser for a sample implementation of a parser. The necessary steps for creating a new model parser are: | ||
| + | |||
| + | * Create a new class and extend it from ModelParser | ||
| + | * Add your parser to the extension list (In ModelParser.java) so a file extension will be assigned to your parser: | ||
| + | * Example: < | ||
| + | * Implement the required methods. These should be self-explaining (see javadoc) | ||
| + | * Store all data in the Groups member of the ModelParser parent class. | ||


