PathPlanner Docs 2025 Help

Custom Logging

PathPlannerLib provides the ability to set custom logging callbacks that will be called when the built-in path following commands are running. You can set these callbacks through the PathPlannerLogging class.

These can be used for logging path following data with logging frameworks such as AdvantageKit, or visualization with a Field2d Widget.

public class RobotContainer { private final Field2d field; public RobotContainer(){ field = new Field2d(); SmartDashboard.putData("Field", field); // Logging callback for current robot pose PathPlannerLogging.setLogCurrentPoseCallback((pose) -> { // Do whatever you want with the pose here field.setRobotPose(pose); }); // Logging callback for target robot pose PathPlannerLogging.setLogTargetPoseCallback((pose) -> { // Do whatever you want with the pose here field.getObject("target pose").setPose(pose); }); // Logging callback for the active path, this is sent as a list of poses PathPlannerLogging.setLogActivePathCallback((poses) -> { // Do whatever you want with the poses here field.getObject("path").setPoses(poses); }); } }
#include <frc/smartdashboard/Field2d.h> #include <frc/smartdashboard/SmartDashboard.h> #include <pathplanner/lib/util/PathPlannerLogging.h> using namespace pathplanner; frc::Field2d m_field; RobotContainer() { frc::SmartDashboard::PutData("Field", &m_field); // Logging callback for current robot pose PathPlannerLogging::setLogCurrentPoseCallback([this](frc::Pose2d pose) -> { // Do whatever you want with the pose here m_field.SetRobotPose(pose); }); // Logging callback for target robot pose PathPlannerLogging::setLogTargetPoseCallback([this](frc::Pose2d pose) -> { // Do whatever you want with the pose here m_field.GetObject("target pose").setPose(pose); }); // Logging callback for the active path, this is sent as a vector of poses PathPlannerLogging::setLogActivePathCallback([this](std::vector<frc::Pose2d> poses) -> { // Do whatever you want with the poses here m_field.GetObject("path").setPoses(poses); }); }
from pathplannerlib.logging import PathPlannerLogging from wpilib import Field2d, SmartDashboard field = Field2d() SmartDashboard.putData('Field', field) # Logging callback for current robot pose PathPlannerLogging.setLogCurrentPoseCallback(lambda pose: field.setRobotPose(pose)) # Logging callback for target robot pose PathPlannerLogging.setLogTargetPoseCallback(lambda pose: field.getObject('target pose').setPose(pose)) # Logging callback for the active path, this is sent as a list of poses PathPlannerLogging.setLogActivePathCallback(lambda poses: field.getObject('path').setPoses(poses))
Last modified: 05 January 2025