Setting up and running a simulation can involve loading various kinds of resources, such as robot models and plugins, from different locations, which can include a local filesystem and online servers. Ignition Gazebo offers a few different mechanisms for locating required resources.
Plugins
A plugin is a shared library that adheres to a specific API and is loaded at runtime. Typically, plugins are scoped to perform a narrow set of features. For example, the diff_drive plugin, provided by Ignition Gazebo, implements a differential drive controller for mobile robots.
Ignition relies on plugins for rendering, physics simulation, sensor data generation, and many of the capabilities. The following sections describe how Ignition finds and loads different types of plugins.
System Plugins
A system plugin is used by Ignition Gazebo, and provides an entry point for simulation customization and control. Refer to the Create System Plugins tutorial for information about creating your own system plugin.
System plugins may be loaded through:
- Tags in SDF files, where filenameis the shared library andnameis the class to be loaded. A system plugin can be attached to different entities.- Attached to the world: <world><plugin>
- Attached to a model: <model><plugin>
- Attached to a sensor: <sensor><plugin>
 
- Attached to the world: 
- Passing the shared library and class to be loaded through PluginInfo (within ServerConfig) when instantiating the Server.
Ignition will look for system plugins on the following paths, in order:
- All paths on the IGN_GAZEBO_SYSTEM_PLUGIN_PATHenvironment variable
- $HOME/.ignition/gazebo/plugins
- Systems that are installed with Ignition Gazebo
Ignition GUI plugins
Each Ignition GUI plugin defines a widget.
GUI plugins may be loaded through:
- Tags in SDF world files, where filenameis the shared library:- <world><gui><plugin>
 
- Tags in GUI config files, where filenameis the shared library:- <plugin>
 
- The plugin menu on the top-right of the screen.
Ignition will look for GUI plugins on the following paths, in order:
- All paths set on the IGN_GUI_PLUGIN_PATHenvironment variable
- GUI plugins that are installed with Ignition Gazebo
- Other paths added by calling gz::gui::App()->AddPluginPath
- ~/.ignition/gui/plugins
- Plugins which are installed with Gazebo GUI
Physics engines
Ignition Physics uses a plugin architecture and its physics engines are built as plugins that are loaded at run time using Ignition Plugin.
See the Physics engines tutorial for more details.
Rendering engines
Ignition Rendering uses a plugin architecture and its render engines are built as plugins that are loaded at run time using Ignition Plugin.
At the moment, Ignition Rendering will only look for render engine plugin shared libraries installed within its <install_prefix>/lib directory. Likewise, the resources used by these engines are located in Ignition Rendering's <install_prefix>/share directory.
Sensors
Each unique type of sensor in Ignition Sensors is a plugin. When a particular sensor type is requested, the relevant plugin is loaded by Ignition Plugin and a sensor object is instantiated from it.
At the moment, Ignition Sensors will only look for sensor plugin shared libraries installed within its <install_prefix>/lib directory.
Models, lights, actors
Top-level entities such as models, lights and actors may be loaded through:
- Tags in SDF world files:- <world><model>
- <world><light>
- <world><actor>
- <include><uri>(path / URL)
 
- The /world/<world_name>/createservice:- SDF file as string (<model>/<light>/<actor>root)
- Path / URL to SDF file
- (TODO) gz::msgs::Model,gz::msgs::Light
 
- SDF file as string (
- Within a system, using SdfEntityCreator or directly creating components and entities.
Ignition will look for URIs (path / URL) in the following, in order:
- All paths on the IGN_GAZEBO_RESOURCE_PATH* environment variable (if path is URI, scheme is stripped)
- Current running path / absolute path
- Ignition Fuel- Cache (i.e. $HOME/.ignition/fuel)
- Web server
 
- Cache (i.e. 
- The SDF_PATHenvironment variable also works in some scenarios, but it's not recommended when using Ignition Gazebo.
Meshes
Mesh files may be loaded through:
- Tags in SDF files:- <geometry><mesh><uri>
- <actor><skin><filename>
- <actor><animation><filename>
 
Ignition will look for URIs (path / URL) in the following, in order:
- Current running path / absolute path
- All paths on the IGN_GAZEBO_RESOURCE_PATH* environment variable (if path is URI, scheme is stripped)
- The IGN_FILE_PATHenvironment variable also works in some scenarios, but it's not recommended when using Ignition Gazebo.
GUI configuration
Ignition Gazebo's GUI configuration can come from the following, in order:
- The command line option --gui-config <file path>
- Plugins within SDF's <world><gui>
- $HOME/.ignition/gazebo/gui.config(if that file doesn't exist, the default- gui.configfile that is installed with Ignition Gazebo will be copied to that location)