To add your own controller, create a folder to hold your controller files under ./src/ai/controller/YOUR_CONTROLLER_NAME_HERE
. Inside the folder, create your controller class and any subsequent source files required. All controllers must inherit the base_controller class. Other than a constructor, the only method required to be implemented is the getAction()
method, which tells the engine handler what action to perform next. Although not required, it is highly recommended to overload the controllerDetailsToString()
method as well, as it is useful for debugging clarity.
An example of a default controller, which returns the do-nothing action, is implemented below. The source file for this example can also be seen under ./src/ai/controller/default/
.
// Includes
#include "base_controller.h"
#include "engine_types.h"
/**
* Default controller
*
* This does nothing, and acts as a backup to prevent unknown controller input from breaking
*/
class Default : public BaseController {
private:
public:
Default();
/**
* Always returns the noop action.
*/
Action getAction() override {return Action::noop;};
/**
* Convey any important details about the controller in string format.
* Useful for logging relevant information about the current controller configuration.
*/
virtual std::string controllerDetailsToString() override {return "My controller";}
};
To let the engine know the existence of your controller, a few changes need to be made.
- Edit the
./src/ai/include/controller_listing.h
to include information about your controller. A new entry should be made in theenum ControllerType
, as well as a short name inCONTROLLER_STRINGS
. The ordering should match BOTH in the enum as well as the string list. The name given in the string list will be used as the command line argument when selecting the controller, i.e.
./rocksndiamonds -controller YOUR_CONTROLLER_NAME
- The last step is to set the global controller pointer to your new class. Open
./src/ai/controller/controller.cpp
, and include your controller header at the top. Next, add another conditional statement insideinitController(ControllerType controller)
which will call your controller's constructor, and pass in any arguments required. NOTE: The conditional checks againstenum ControllerType
, so make sure you use the same enum name that was added in the above.
/**
* Inits the controller.
* Controller type is determined by command line argument.
*/
void Controller::initController(ControllerType controller) {
// Set appropriate controller
if (controller == CONTROLLER_DEFAULT) {
baseController_ = std::make_unique<Default>();
}
...
else if (controller == YOUR_CONTROLLER_ENUM_NAME) {
baseController_ = std::make_unique<YourControllerClass>();
}
...
}
Once the above steps are done, you should now be able to call your controller. Controllers are set using the -controller YOUR_CONTROLLER_STRING_NAME
command line argument. For example, if you added an entry to CONTROLLER_STRINGS
called MY_CONTROLLER
, the program call would be:
./rocksndiamonds -controller MY_CONTROLLER