170 lines
4.3 KiB
Text
170 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;
|
||
|
}
|