7#include "PushFrameCameraDetectorMap.h"
13#include "CameraFocalPlaneMap.h"
29 const double frameletRate,
int frameletHeight):
63 double unsummedFrameletLine;
73 double unsummedFrameletSample = sample;
136 const double deltaT) {
144 int framelet = (int)((line - 0.5) / actualFrameletHeight) + 1;
441 const int band)
const {
Convert between parent image coordinates and detector coordinates.
double p_parentLine
The parent line calculated from the detector.
virtual double LineScaleFactor() const
Return scaling factor for computing line resolution.
virtual bool SetParent(const double sample, const double line)
Compute detector position from a parent image coordinate.
double p_parentSample
The parent sample calculated from the detector.
double p_detectorSample
Detector coordinate sample value.
double p_detectorLine
Detector coordinate line value.
virtual bool SetDetector(const double sample, const double line)
Compute parent position from a detector coordinate.
Camera * p_camera
Pointer to the camera.
int ParentLines() const
Returns the number of lines in the parent alphacube.
PushFrameCameraDetectorMap(Camera *parent, const double etStart, const double frameletRate, int frameletHeight)
Construct a detector map for push frame cameras.
bool p_flippedFramelets
Indicates whether the geometry in a framelet is flipped.
int p_frameletHeight
Height of a framelet in detector lines.
double p_exposureDuration
Exposure duration in secs.
bool p_timeAscendingFramelets
Are framelets reversed from top-to-bottom in file.
void SetFrameletRate(const double frameletRate)
Reset the frame rate.
int TotalFramelets() const
Return the total number of framelets including padding.
virtual double exposureDuration(const double sample, const double line, const int band) const
This virtual method is for returning the exposure duration of a given pixel.
void SetFrameletsGeometricallyFlipped(bool frameletsFlipped)
Mirrors the each framelet in the file.
virtual bool SetParent(const double sample, const double line)
Compute detector position from a parent image coordinate.
void SetBandFirstDetectorLine(int firstLine)
Change the starting line in the detector based on band.
virtual ~PushFrameCameraDetectorMap()
Destructor.
double frameletLine() const
This returns the calculated framelet line.
int GetBandFirstDetectorLine()
Return the starting line in the detector for the current band.
void SetFrameletOffset(int frameletOffset)
Reset the frame offset.
bool timeAscendingFramelets()
Returns if the framelets are reversed from top-to-bottom.
void SetStartTime(const double etStart)
Reset the starting ephemeris time.
int frameletHeight() const
This returns how many lines are considered a single framelet.
double p_frameletSample
The sample in the current framelet.
double p_etStart
Starting time at the top of the first parent line.
int Framelet()
This method returns the current framelet.
void SetFrameletOrderReversed(bool frameletOrderReversed, int nframelets)
Changes the direction of the framelets.
int FrameletOffset() const
Return the frame offset.
void SetExposureDuration(double exposureDuration)
Change the exposure duration in seconds.
double p_frameletRate
iTime between framelets in parent cube.
int p_framelet
The current framelet.
virtual bool SetDetector(const double sample, const double line)
Compute parent position from a detector coordinate.
double frameletSample() const
This returns the calculated framelet sample.
int p_nframelets
If flipped framelets, the number of framelets in this band.
double StartEphemerisTime() const
This returns the starting ET of this band.
int p_bandStartDetector
The first detector line of current band.
double p_frameletLine
The line in the current framelet.
void SetFramelet(int framelet, const double deltaT=0)
This method changes the current framelet.
double FrameletRate() const
Return the time in seconds between framelets.
int p_frameletOffset
The numner of framelets padding the top of the band.
void setTime(const iTime &time)
By setting the time you essential set the position of the spacecraft and body as indicated in the cla...
This is free and unencumbered software released into the public domain.