Package org.photonvision.targeting
Class PhotonPipelineResult
java.lang.Object
org.photonvision.targeting.PhotonPipelineResult
- All Implemented Interfaces:
- ProtobufSerializable,- WPISerializable,- PhotonStructSerializable<PhotonPipelineResult>
public class PhotonPipelineResult
extends Object
implements ProtobufSerializable, PhotonStructSerializable<PhotonPipelineResult>
Represents a pipeline result from a PhotonCamera.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final PhotonPipelineResultSerdestatic final PhotonPipelineResultProto
- 
Constructor SummaryConstructorsConstructorDescriptionConstructs an empty pipeline result.PhotonPipelineResult(long sequenceID, long captureTimestampMicros, long publishTimestampMicros, long timeSinceLastPong, List<PhotonTrackedTarget> targets) Constructs a pipeline result.PhotonPipelineResult(long sequenceID, long captureTimestamp, long publishTimestamp, long timeSinceLastPong, List<PhotonTrackedTarget> targets, Optional<MultiTargetPNPResult> result) Constructs a pipeline result.PhotonPipelineResult(PhotonPipelineMetadata metadata, List<PhotonTrackedTarget> targets, Optional<MultiTargetPNPResult> result) 
- 
Method SummaryModifier and TypeMethodDescriptionbooleanReturns the best target in this pipeline result.Return the latest multi-target result.intReturns the size of the packet needed to store this pipeline result.getSerde()Returns a copy of the vector of targets.doubleReturns the estimated time the frame was taken, in the Time Sync Server's time base (nt::Now).inthashCode()booleanReturns whether the pipeline has targets.toString()
- 
Field Details- 
metadata
- 
targets
- 
multitagResult
- 
photonStruct
- 
proto
 
- 
- 
Constructor Details- 
PhotonPipelineResultpublic PhotonPipelineResult()Constructs an empty pipeline result.
- 
PhotonPipelineResultpublic PhotonPipelineResult(long sequenceID, long captureTimestampMicros, long publishTimestampMicros, long timeSinceLastPong, List<PhotonTrackedTarget> targets) Constructs a pipeline result.- Parameters:
- sequenceID- The number of frames processed by this camera since boot
- captureTimestampMicros- The time, in uS in the coprocessor's timebase, that the coprocessor captured the image this result contains the targeting info of
- publishTimestampMicros- The time, in uS in the coprocessor's timebase, that the coprocessor published targeting info
- targets- The list of targets identified by the pipeline.
 
- 
PhotonPipelineResultpublic PhotonPipelineResult(long sequenceID, long captureTimestamp, long publishTimestamp, long timeSinceLastPong, List<PhotonTrackedTarget> targets, Optional<MultiTargetPNPResult> result) Constructs a pipeline result.- Parameters:
- sequenceID- The number of frames processed by this camera since boot
- captureTimestamp- The time, in uS in the coprocessor's timebase, that the coprocessor captured the image this result contains the targeting info of
- publishTimestamp- The time, in uS in the coprocessor's timebase, that the coprocessor published targeting info
- targets- The list of targets identified by the pipeline.
- result- Result from multi-target PNP.
 
- 
PhotonPipelineResultpublic PhotonPipelineResult(PhotonPipelineMetadata metadata, List<PhotonTrackedTarget> targets, Optional<MultiTargetPNPResult> result) 
 
- 
- 
Method Details- 
getPacketSizeReturns the size of the packet needed to store this pipeline result.- Returns:
- The size of the packet needed to store this pipeline result.
 
- 
getBestTargetReturns the best target in this pipeline result. If there are no targets, this method will return null. The best target is determined by the target sort mode in the PhotonVision UI.- Returns:
- The best target of the pipeline result.
 
- 
hasTargetsReturns whether the pipeline has targets.- Returns:
- Whether the pipeline has targets.
 
- 
getTargetsReturns a copy of the vector of targets.Returned in the order set by target sort mode. - Returns:
- A copy of the vector of targets.
 
- 
getMultiTagResultReturn the latest multi-target result. Be sure to check getMultiTagResult().estimatedPose.isPresent before using the pose estimate!
- 
getTimestampSecondsReturns the estimated time the frame was taken, in the Time Sync Server's time base (nt::Now). This is calculated using the estimated offset between Time Sync Server time and local time. The robot shall run a server, so the offset shall be 0.- Returns:
- The timestamp in seconds
 
- 
toString
- 
hashCode
- 
equals
- 
getSerde- Specified by:
- getSerdein interface- PhotonStructSerializable<PhotonPipelineResult>
 
 
-