| /*----------------------------------------------------------------------------*/ |
| /* Copyright (c) FIRST 2016-2017. All Rights Reserved. */ |
| /* Open Source Software - may be modified and shared by FRC teams. The code */ |
| /* must be accompanied by the FIRST BSD license file in the root directory of */ |
| /* the project. */ |
| /*----------------------------------------------------------------------------*/ |
| |
| #include "simulation/SimGyro.h" |
| |
| #include "simulation/MainNode.h" |
| |
| using namespace frc; |
| |
| SimGyro::SimGyro(std::string topic) { |
| commandPub = MainNode::Advertise<gazebo::msgs::GzString>("~/simulator/" + |
| topic + "/control"); |
| |
| posSub = MainNode::Subscribe("~/simulator/" + topic + "/position", |
| &SimGyro::positionCallback, this); |
| velSub = MainNode::Subscribe("~/simulator/" + topic + "/velocity", |
| &SimGyro::velocityCallback, this); |
| |
| if (commandPub->WaitForConnection( |
| gazebo::common::Time(5.0))) { // Wait up to five seconds. |
| std::cout << "Initialized ~/simulator/" + topic << std::endl; |
| } else { |
| std::cerr << "Failed to initialize ~/simulator/" + topic + |
| ": does the gyro exist?" |
| << std::endl; |
| } |
| } |
| |
| void SimGyro::Reset() { sendCommand("reset"); } |
| |
| double SimGyro::GetAngle() { return position; } |
| |
| double SimGyro::GetVelocity() { return velocity; } |
| |
| void SimGyro::sendCommand(std::string cmd) { |
| gazebo::msgs::GzString msg; |
| msg.set_data(cmd); |
| commandPub->Publish(msg); |
| } |
| |
| void SimGyro::positionCallback(const gazebo::msgs::ConstFloat64Ptr& msg) { |
| position = msg->data(); |
| } |
| |
| void SimGyro::velocityCallback(const gazebo::msgs::ConstFloat64Ptr& msg) { |
| velocity = msg->data(); |
| } |