historical/toontown-classic.git/panda/include/pStatStripChart.I
2024-01-16 11:20:27 -06:00

169 lines
4.3 KiB
Text

/**
* PANDA 3D SOFTWARE
* Copyright (c) Carnegie Mellon University. All rights reserved.
*
* All use of this software is subject to the terms of the revised BSD
* license. You should have received a copy of this license along
* with this source code in a file named "LICENSE."
*
* @file pStatStripChart.I
* @author drose
* @date 2000-07-15
*/
/**
* Returns the View this chart represents.
*/
INLINE PStatView &PStatStripChart::
get_view() const {
return _view;
}
/**
* Returns the particular collector whose data this strip chart reflects.
*/
INLINE int PStatStripChart::
get_collector_index() const {
return _collector_index;
}
/**
* Changes the amount of time the width of the horizontal axis represents.
* This may force a redraw.
*/
INLINE void PStatStripChart::
set_horizontal_scale(double time_width) {
if (_time_width != time_width) {
if (_scroll_mode) {
_start_time += _time_width - time_width;
} else {
force_reset();
}
_time_width = time_width;
}
}
/**
* Returns the amount of total time the width of the horizontal axis
* represents.
*/
INLINE double PStatStripChart::
get_horizontal_scale() const {
return _time_width;
}
/**
* Changes the value the height of the vertical axis represents. This may
* force a redraw.
*/
INLINE void PStatStripChart::
set_vertical_scale(double value_height) {
if (_value_height != value_height) {
_value_height = value_height;
normal_guide_bars();
force_redraw();
}
}
/**
* Returns total value the height of the vertical axis represents.
*/
INLINE double PStatStripChart::
get_vertical_scale() const {
return _value_height;
}
/**
* Changes the scroll_mode flag. When true, the strip chart will update
* itself by scrolling to the left; when false, the strip chart will wrap
* around at the right and restart at the left end without scrolling.
*/
INLINE void PStatStripChart::
set_scroll_mode(bool scroll_mode) {
if (_scroll_mode != scroll_mode) {
_scroll_mode = scroll_mode;
_first_data = true;
}
}
/**
* Returns the current state of the scroll_mode flag. When true, the strip
* chart will update itself by scrolling to the left; when false, the strip
* chart will wrap around at the right and restart at the left end without
* scrolling.
*/
INLINE bool PStatStripChart::
get_scroll_mode() const {
return _scroll_mode;
}
/**
* Changes the average_mode flag. When true, the strip chart will average out
* the color values over pstats_average_time seconds, which hides spikes and
* makes the overall trends easier to read. When false, the strip chart shows
* the actual data as it is happening.
*/
INLINE void PStatStripChart::
set_average_mode(bool average_mode) {
if (_average_mode != average_mode) {
_average_mode = average_mode;
force_redraw();
}
}
/**
* Returns the current state of the average_mode flag. When true, the strip
* chart will average out the color values over pstats_average_time seconds,
* which hides spikes and makes the overall trends easier to read. When
* false, the strip chart shows the actual data as it is happening.
*/
INLINE bool PStatStripChart::
get_average_mode() const {
return _average_mode;
}
/**
* Converts a timestamp to a horizontal pixel offset.
*/
INLINE int PStatStripChart::
timestamp_to_pixel(double time) const {
return (int)((double)get_xsize() * (time - _start_time) / _time_width);
}
/**
* Converts a horizontal pixel offset to a timestamp.
*/
INLINE double PStatStripChart::
pixel_to_timestamp(int x) const {
return _time_width * (double)x / (double)get_xsize() + _start_time;
}
/**
* Converts a value (i.e. a "height" in the strip chart) to a vertical pixel
* offset.
*/
INLINE int PStatStripChart::
height_to_pixel(double value) const {
return get_ysize() - (int)((double)get_ysize() * value / _value_height);
}
/**
* Converts a vertical pixel offset to a value (a "height" in the strip
* chart).
*/
INLINE double PStatStripChart::
pixel_to_height(int x) const {
return _value_height * (double)(get_ysize() - x) / (double)get_ysize();
}
/**
* Returns true if the indicated collector appears anywhere on the chart at
* the current time, false otherwise.
*/
INLINE bool PStatStripChart::
is_label_used(int collector_index) const {
if (collector_index < (int)_label_usage.size()) {
return _label_usage[collector_index] > 0;
}
return false;
}