Gazebo機器人仿真學習探索筆記(四)模型編輯

举报
zhangrelay 发表于 2021/07/15 06:37:05 2021/07/15
【摘要】 模型編輯主要是自定義編輯物體模型構建環境,也可以將多種模型組合爲新模型等,支持外部模型導入, 需要注意的導入模型格式有相應要求,否在無法導入成功, COLLADA (dae), STereoLithography (stl), Scalable Vector Graphics (svg)。 模型導入界面如下: 以Scalable Vector Graphics (svg)爲...

模型編輯主要是自定義編輯物體模型構建環境,也可以將多種模型組合爲新模型等,支持外部模型導入,

需要注意的導入模型格式有相應要求,否在無法導入成功,

COLLADA (dae), STereoLithography (stl), Scalable Vector Graphics (svg)。

模型導入界面如下:


Scalable Vector Graphics (svg)爲例,直接使用下面命令安裝使用:

~$ sudo apt-get install inkscape
 




也可以編輯組合模型:


這部分內容都是可視化操作,簡潔易學,可直接參考附錄中的官方文檔。

編輯好的模型可以重命名,然後另存,twotable,會自動生成如下文件。


效果如下:


自動生成的代碼如下所示:

model.config


  
  1. <?xml version="1.0" ?>
  2. <model>
  3. <name>twotable</name>
  4. <version>1.0</version>
  5. <sdf version="1.6">model.sdf</sdf>
  6. <author>
  7. <name></name>
  8. <email></email>
  9. </author>
  10. <description></description>
  11. </model>




  
  1. <?xml version='1.0'?>
  2. <sdf version='1.6'>
  3. <model name='twotable'>
  4. <model name='table'>
  5. <static>0</static>
  6. <link name='link'>
  7. <collision name='surface'>
  8. <pose frame=''>0 0 1 0 -0 0</pose>
  9. <geometry>
  10. <box>
  11. <size>1.5 0.8 0.03</size>
  12. </box>
  13. </geometry>
  14. <surface>
  15. <friction>
  16. <ode>
  17. <mu>0.6</mu>
  18. <mu2>0.6</mu2>
  19. </ode>
  20. </friction>
  21. </surface>
  22. </collision>
  23. <visual name='visual1'>
  24. <pose frame=''>0 0 1 0 -0 0</pose>
  25. <geometry>
  26. <box>
  27. <size>1.4 0.8 0.04</size>
  28. </box>
  29. </geometry>
  30. <material>
  31. <script>
  32. <uri>file://media/materials/scripts/gazebo.material</uri>
  33. <name>Gazebo/Wood</name>
  34. </script>
  35. </material>
  36. </visual>
  37. <collision name='front_left_leg'>
  38. <pose frame=''>0.68 0.38 0.5 0 -0 0</pose>
  39. <geometry>
  40. <cylinder>
  41. <radius>0.02</radius>
  42. <length>1</length>
  43. </cylinder>
  44. </geometry>
  45. </collision>
  46. <visual name='front_left_leg'>
  47. <pose frame=''>0.68 0.38 0.5 0 -0 0</pose>
  48. <geometry>
  49. <cylinder>
  50. <radius>0.02</radius>
  51. <length>1</length>
  52. </cylinder>
  53. </geometry>
  54. <material>
  55. <script>
  56. <uri>file://media/materials/scripts/gazebo.material</uri>
  57. <name>Gazebo/Grey</name>
  58. </script>
  59. </material>
  60. </visual>
  61. <collision name='front_right_leg'>
  62. <pose frame=''>0.68 -0.38 0.5 0 -0 0</pose>
  63. <geometry>
  64. <cylinder>
  65. <radius>0.02</radius>
  66. <length>1</length>
  67. </cylinder>
  68. </geometry>
  69. </collision>
  70. <visual name='front_right_leg'>
  71. <pose frame=''>0.68 -0.38 0.5 0 -0 0</pose>
  72. <geometry>
  73. <cylinder>
  74. <radius>0.02</radius>
  75. <length>1</length>
  76. </cylinder>
  77. </geometry>
  78. <material>
  79. <script>
  80. <uri>file://media/materials/scripts/gazebo.material</uri>
  81. <name>Gazebo/Grey</name>
  82. </script>
  83. </material>
  84. </visual>
  85. <collision name='back_right_leg'>
  86. <pose frame=''>-0.68 -0.38 0.5 0 -0 0</pose>
  87. <geometry>
  88. <cylinder>
  89. <radius>0.02</radius>
  90. <length>1</length>
  91. </cylinder>
  92. </geometry>
  93. </collision>
  94. <visual name='back_right_leg'>
  95. <pose frame=''>-0.68 -0.38 0.5 0 -0 0</pose>
  96. <geometry>
  97. <cylinder>
  98. <radius>0.02</radius>
  99. <length>1</length>
  100. </cylinder>
  101. </geometry>
  102. <material>
  103. <script>
  104. <uri>file://media/materials/scripts/gazebo.material</uri>
  105. <name>Gazebo/Grey</name>
  106. </script>
  107. </material>
  108. </visual>
  109. <collision name='back_left_leg'>
  110. <pose frame=''>-0.68 0.38 0.5 0 -0 0</pose>
  111. <geometry>
  112. <cylinder>
  113. <radius>0.02</radius>
  114. <length>1</length>
  115. </cylinder>
  116. </geometry>
  117. </collision>
  118. <visual name='back_left_leg'>
  119. <pose frame=''>-0.68 0.38 0.5 0 -0 0</pose>
  120. <geometry>
  121. <cylinder>
  122. <radius>0.02</radius>
  123. <length>1</length>
  124. </cylinder>
  125. </geometry>
  126. <material>
  127. <script>
  128. <uri>file://media/materials/scripts/gazebo.material</uri>
  129. <name>Gazebo/Grey</name>
  130. </script>
  131. </material>
  132. </visual>
  133. </link>
  134. <pose frame=''>0 1.23981 -0.324 0 -0 0</pose>
  135. </model>
  136. <model name='table_marble'>
  137. <static>1</static>
  138. <pose frame=''>0 -1.23981 0.324 0 -0 0</pose>
  139. <link name='link'>
  140. <collision name='collision'>
  141. <geometry>
  142. <mesh>
  143. <uri>model:///table_marble/meshes/table_lightmap.dae</uri>
  144. <scale>0.25 0.25 0.25</scale>
  145. </mesh>
  146. </geometry>
  147. </collision>
  148. <visual name='visual'>
  149. <geometry>
  150. <mesh>
  151. <uri>model://table_marble/meshes/table_lightmap.dae</uri>
  152. <scale>0.25 0.25 0.25</scale>
  153. </mesh>
  154. </geometry>
  155. <material>
  156. <script>
  157. <uri>model://table_marble/materials/scripts</uri>
  158. <uri>model://table_marble/materials/textures</uri>
  159. <name>Table/Marble_Lightmap</name>
  160. </script>
  161. <lighting>0</lighting>
  162. </material>
  163. </visual>
  164. </link>
  165. </model>
  166. <static>0</static>
  167. <allow_auto_disable>1</allow_auto_disable>
  168. </model>
  169. </sdf>




附錄:官方文檔

Model Editor

Overview

This tutorial describes the process of creating a model using the Model Editor.

Open the Model Editor

  1. Make sure Gazebo is installed.

  2. Start up gazebo.

    $ gazebo
    
        
  3. On the Edit menu, go to Model Editor, or hit Ctrl+M to open the editor.

Graphical user interface

The editor is composed of the following 2 areas:

  • The Palette on the left has two tabs. The Insert tab lets you insertparts (links and other models) into the scene to build the model. The Modeltab displays a list of all the parts that make up the model you are building.

  • The 3D View on the right where you can see a preview of your model andinteract with it to edit its properties and create joints between links.

The GUI tools on the top toolbar can be used to manipulate joints and links inthe 3D View.

Add Links

Add simple shapes

The model editor has three simple primitive geometries that the user can insertinto the 3D view to make a link of the model.

  1. On the Palette, click on the box, sphere, or cylinder icon underSimple Shapes.

  2. Move your mouse cursor over the 3D view to see the visual appear, andclick/release anywhere to add it to the model.

    Tip: You can press Esc to cancel adding the currentlink attached to the mouse cursor.

Add meshes

To add a custom mesh,

  1. Click on the Add button under Custom Shapes, which pops up a dialogthat lets you find the mesh you want to add.

  2. Click on Browse button and use the file browser to find the mesh fileon your local machine. If you know the path of the mesh file, you can enter itdirectly in the text field box next to the Browse button. Note Gazebocurrently only supports importing COLLADA (dae), STereoLithography (stl),and Scalable Vector Graphics (svg) files.

  3. Click Import to load the mesh file. Then, add it to the 3D view.

Create Joints

The model editor supports creating several types of joints between links in themodel being edited. To create a joint:

  1. Click on the joint icon on the tool bar. This brings up the Joint CreationDialog which allows you to specify different properties of the joint youwant to create. As you can see in the dialog, the default joint type isa Revolute joint.

  2. Begin by moving your mouse over the link you wish to create a joint for tosee it being highlighted and click on it. This link will be the parent link ofthe joint.

  3. Next, move your mouse to the link which you would like to be the child linkof the joint. Click on it to see a colored line connecting the two links anda joint visual attached to the child link.

    The line representing the joint is color-coded. Play around with differentjoint types to see the colors.

    The joint visual consists of RGB axes which help to give an idea of thecoordinate frame of the joint. The yellow arrow indicates the primary axis ofthe joint. For example, in the case of a revolute joint, this is the axis ofrotation.

  4. Once you have specified all the desired properties of the joint in theJoint Creation Dialog, click on the Create button at the bottom to finalizejoint creation.

    Tip: You can press Esc any time to cancel the joint creation process.

Edit your model

Note: Be careful when editing your model; the editor currently has no option to undo your actions.

Tip: All measurements are in meters.

Edit links

The model editor supports editing properties of a link which you wouldalso find in its SDF.

Note: Gazebo 6+ supports editinglinks, visuals, and collisions. The ability to edit sensors andplugins are to be implemented in later versions.

To edit a link's properties: Double-click on the link or right click and selectOpen Link Inspector. A dialog window will appear which containsLink, Visual, and Collision property tabs.

As an example, try changing the link pose and visual colors. Once you are done, click onOK to close the inspector.

Edit joints

As mentioned earlier, joint properties can also be edited. These are propertiesthat you would find in the joint SDF.

To edit a joint: Double-click on the line connecting the links or right clickon it and select Open Joint Inspector. The joint inspector will appear.

As an example, try changing the joint pose and joint type. Once you are done, click onOK to close the inspector.

Saving your model

Saving will create a directory, SDF and config files for your model.

As an exercise, let's build a simple car and save it. The car will have abox chassis and four cylinder wheels. Each wheel will be connected to thechassis with a revolute joint:

Once you're happy with the model you created, go to the Model tab in the leftpanel and give it a name.

To save the model, choose File, then Save As (or hit Ctrl+S) in the topmenu. A dialog will come up where you can choose the location for your model.

Exit

When you're done creating the model and you've saved it, go to File and thenExit Model Editor.

Your model will show up in the main window.

Edit existing models

Rather than creating a model from the ground up;you can also edit existing models that are already in the simulation.

To edit an existing model:

  • Make sure you have saved the model you created, and you have exited the model editor. Alternatively, start from a fresh Gazebo instance.

  • Insert a model from the Insert tab on the left. For example, let'sinsert a Simple Arm.

  • Right click on the model you just inserted and select Edit Model.

Now you are in the model editor and you are free to add new links to themodel or edit existing ones.


Extrude SVG files

Overview

This tutorial describes the process of extruding SVG files, which are 2Dimages, to create 3D meshes for your models in Gazebo. It is sometimeseasier to design part of a model in a program like Inkscape or Illustrator.

Before starting, make sure you're familiar with theModel Editor.

This tutorial will show you how to make a custom wheel as an .svg in Inkscape,and import it into Gazebo so that it can be attached to a robot.

Using the Inkscape SVG editor

There are many SVG editors. For this tutorial, we will use the open sourceInkscape program (seeinstallation instructions ).

This is the wheelSVG file used in this tutorial.

Document preparation

Start Inkscape. This will create a blank document. First, lets change thedocument size to better accommodate our wheel: under the File->Documentproperties menu, select the Page tab and change the document size to acustom size of 100.0 x 100.0 mm.

Then, in the same dialog, select the Gridstab, press the New button to create a custom grid. Then, check the Enabled,Visible, and Snap to visible grid lines only options. ChangeSpacing X and Spacing Y to be 10.

You should end up with a document looking like this:

Draw

You can use the different tools (pen, text, stars and shapes, etc.) to createyour geometry. In this example, the wheel is made from circles (pressing theShift Key you can start your circle from the center, and using the CTRL keyallows you to keep the roundness of the shape). It is possible to combineshapes together, making sure that paths are closed and that the part hasa proper thickness.

Note: a stick figure or two circles that touch each other would notresult in valid Gazebo models. The SVG paths must create an closed contour withholes, where the holes cannot touch the contour or other holes. Holes insideholes are treated as solid parts (and they can have holes, too).

Gazebo only imports paths, but it's easy with Inkscape to transform any shapeto a path. Select Select All from the Edit menu. Then select thePath -> Object to Path menu item. This will transform every object intoseparate paths and sub paths. This transformation is irreversible, so if youtransform text into paths, you will not be able to alter the text.

Gazebo does not support grouping. Use the Ungroup from the Object menu toseparate groups of paths.

Save your drawing

Save your drawing to an SVG file you can use later in Gazebo. Use the Saveoption from the File menu.

Create a Gazebo Model

SDFormat does not support SVG directly; it supports 2Dpoly lines. The Gazebo Model Editor has an import mechanism that extracts thepoly lines from SVG files, and saves them as an SDF model file.

Launch Gazebo and Select Model Editor from the Edit menu to enter theGazebo Model Editor mode (as opposed to the simulation mode).

Then press the Add button in the Custom Shapes section of the Insert tab.

This will open the Import Link dialog from where you can select the SVG fileby pressing the Browse button.

Once the file has been selected, press the Import button to open theExtrude Link dialog.

The dialog allows you to set parameters of the extrusions:

  • Thickness: How thick the link will be. This corresponds to the extrusionheight in the z axis. For the SVG path shown on the right, the axis ofextrusion is outwards from the screen.

  • Resolution: How many pixels in your SVG correspond to a meter. Thedefault value (3543.3 px/m) corresponds to 90 dpi (dots per inch), which isthe default resolution for several editors, including Inkscape. If your modelshows up the size you'd like in Inkscape when you display the units as meters,you shouldn't change the resolution value.

  • Samples per segment: This indicates into how many segments to divide each ofthe curved paths in the SVG. The more segments, the more complex your linkwill be. It doesn't change anything for straight paths.

On the right, you can see the path extracted from your SVG. The red points arethe summit of the triangulation of the extruded 3D model.

Set the thickness of the wheel to 0.025 m, and press OK. Your new link shouldappear in the 3D view.

A new link is created, and it comes with a default collision shape that isa copy of the generated 3D mesh.

Next, select Exit Model Editor from the File menu. Gazebo will prompt youto save the new model to disk. Press the Save and Exit button on the Exitdialog, and the Save Model dialog will appear.

Set the name of the new model to "HollowWheel", and fill in the information underthe Advanced Options section. Press the Save button.

Your new Gazebo model is now ready to roll ;-)



文章来源: zhangrelay.blog.csdn.net,作者:zhangrelay,版权归原作者所有,如需转载,请联系作者。

原文链接:zhangrelay.blog.csdn.net/article/details/52842627

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。