1998-10-20 01:39:29 +04:00
|
|
|
//
|
2023-01-16 00:16:50 +03:00
|
|
|
// Fl_Chart widget header file for the Fast Light Tool Kit (FLTK).
|
1998-10-20 01:39:29 +04:00
|
|
|
//
|
2023-01-16 00:16:50 +03:00
|
|
|
// Copyright 1998-2023 by Bill Spitzak and others.
|
1998-10-20 01:39:29 +04:00
|
|
|
//
|
2011-07-19 08:49:30 +04:00
|
|
|
// This library is free software. Distribution and use rights are outlined in
|
|
|
|
// the file "COPYING" which should have been included with this file. If this
|
|
|
|
// file is missing or damaged, see the license at:
|
|
|
|
//
|
2020-07-01 19:03:10 +03:00
|
|
|
// https://www.fltk.org/COPYING.php
|
1998-10-20 01:39:29 +04:00
|
|
|
//
|
2020-07-01 19:03:10 +03:00
|
|
|
// Please see the following page on how to report bugs and issues:
|
2005-04-16 04:13:17 +04:00
|
|
|
//
|
2020-07-01 19:03:10 +03:00
|
|
|
// https://www.fltk.org/bugs.php
|
1998-10-20 01:39:29 +04:00
|
|
|
//
|
1998-10-06 22:21:25 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/** \file FL/Fl_Chart.H
|
|
|
|
\brief Fl_Chart widget.
|
|
|
|
*/
|
2008-09-16 11:26:22 +04:00
|
|
|
|
1998-10-06 22:21:25 +04:00
|
|
|
#ifndef Fl_Chart_H
|
|
|
|
#define Fl_Chart_H
|
|
|
|
|
|
|
|
#ifndef Fl_Widget_H
|
|
|
|
#include "Fl_Widget.H"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// values for type()
|
2023-01-16 00:16:50 +03:00
|
|
|
#define FL_BAR_CHART 0 ///< type() for Bar Chart variant
|
|
|
|
#define FL_HORBAR_CHART 1 ///< type() for Horizontal Bar Chart variant
|
|
|
|
#define FL_LINE_CHART 2 ///< type() for Line Chart variant
|
|
|
|
#define FL_FILL_CHART 3 ///< type() for Fill Line Chart variant
|
|
|
|
#define FL_SPIKE_CHART 4 ///< type() for Spike Chart variant
|
|
|
|
#define FL_PIE_CHART 5 ///< type() for Pie Chart variant
|
|
|
|
#define FL_SPECIALPIE_CHART 6 ///< type() for Special Pie Chart variant
|
1998-10-06 22:21:25 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
#define FL_FILLED_CHART FL_FILL_CHART ///< for compatibility
|
1998-10-06 22:21:25 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
#define FL_CHART_MAX 128 ///< max entries per chart
|
|
|
|
#define FL_CHART_LABEL_MAX 18 ///< max label length for entry
|
1998-10-06 22:21:25 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/** For internal use only. */
|
1998-10-06 22:21:25 +04:00
|
|
|
struct FL_CHART_ENTRY {
|
2023-01-16 00:16:50 +03:00
|
|
|
float val; ///< For internal use only.
|
|
|
|
unsigned col; ///< For internal use only.
|
|
|
|
char str[FL_CHART_LABEL_MAX + 1]; ///< For internal use only.
|
1998-10-06 22:21:25 +04:00
|
|
|
};
|
|
|
|
|
2008-09-16 10:49:08 +04:00
|
|
|
/**
|
|
|
|
\class Fl_Chart
|
|
|
|
\brief Fl_Chart displays simple charts.
|
|
|
|
It is provided for Forms compatibility.
|
|
|
|
|
2020-07-01 19:03:10 +03:00
|
|
|
\image html charts.png
|
2010-12-09 02:53:04 +03:00
|
|
|
\image latex charts.png "Fl_Chart" width=10cm
|
2023-01-16 00:16:50 +03:00
|
|
|
|
2008-09-16 10:49:08 +04:00
|
|
|
\todo Refactor Fl_Chart::type() information.
|
|
|
|
|
|
|
|
The type of an Fl_Chart object can be set using type(uchar t) to:
|
2023-01-16 00:16:50 +03:00
|
|
|
|
|
|
|
| Chart Type | Description |
|
|
|
|
|---------------------|-------------------------------------------------------------------------------------------------|
|
|
|
|
| FL_BAR_CHART | Each sample value is drawn as a vertical bar. |
|
|
|
|
| FL_FILLED_CHART | The chart is filled from the bottom of the graph to the sample values. |
|
|
|
|
| FL_HORBAR_CHART | Each sample value is drawn as a horizontal bar. |
|
|
|
|
| FL_LINE_CHART | The chart is drawn as a polyline with vertices at each sample value. |
|
|
|
|
| FL_PIE_CHART | A pie chart is drawn with each sample value being drawn as a proportionate slice in the circle. |
|
|
|
|
| FL_SPECIALPIE_CHART | Like \c FL_PIE_CHART, but the first slice is separated from the pie. |
|
|
|
|
| FL_SPIKE_CHART | Each sample value is drawn as a vertical line. |
|
|
|
|
*/
|
2002-08-14 20:49:38 +04:00
|
|
|
class FL_EXPORT Fl_Chart : public Fl_Widget {
|
2023-01-16 00:16:50 +03:00
|
|
|
int numb;
|
|
|
|
int maxnumb;
|
|
|
|
int sizenumb;
|
|
|
|
FL_CHART_ENTRY *entries;
|
|
|
|
double min, max;
|
|
|
|
uchar autosize_;
|
|
|
|
Fl_Font textfont_;
|
|
|
|
Fl_Fontsize textsize_;
|
|
|
|
Fl_Color textcolor_;
|
|
|
|
|
1998-10-06 22:21:25 +04:00
|
|
|
protected:
|
2023-01-16 00:16:50 +03:00
|
|
|
void draw() FL_OVERRIDE;
|
|
|
|
|
|
|
|
// (static) protected draw methods (STR 2022)
|
|
|
|
// these methods are documented in src/Fl_Chart.cxx
|
|
|
|
|
|
|
|
static void draw_barchart(int x, int y, int w, int h, int numb, FL_CHART_ENTRY entries[],
|
|
|
|
double min, double max, int autosize, int maxnumb, Fl_Color textcolor);
|
|
|
|
|
|
|
|
static void draw_horbarchart(int x, int y, int w, int h, int numb, FL_CHART_ENTRY entries[],
|
|
|
|
double min, double max, int autosize, int maxnumb,
|
|
|
|
Fl_Color textcolor);
|
|
|
|
|
|
|
|
static void draw_linechart(int type, int x, int y, int w, int h, int numb,
|
|
|
|
FL_CHART_ENTRY entries[], double min, double max, int autosize,
|
|
|
|
int maxnumb, Fl_Color textcolor);
|
|
|
|
|
|
|
|
static void draw_piechart(int x, int y, int w, int h, int numb, FL_CHART_ENTRY entries[],
|
|
|
|
int special, Fl_Color textcolor);
|
|
|
|
|
1998-10-06 22:21:25 +04:00
|
|
|
public:
|
2023-01-16 00:16:50 +03:00
|
|
|
Fl_Chart(int X, int Y, int W, int H, const char *L = 0);
|
|
|
|
|
|
|
|
~Fl_Chart();
|
|
|
|
|
|
|
|
void clear();
|
|
|
|
|
|
|
|
void add(double val, const char *str = 0, unsigned col = 0);
|
|
|
|
|
|
|
|
void insert(int ind, double val, const char *str = 0, unsigned col = 0);
|
|
|
|
|
|
|
|
void replace(int ind, double val, const char *str = 0, unsigned col = 0);
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/**
|
|
|
|
Gets the lower and upper bounds of the chart values.
|
|
|
|
\param[out] a, b are set to lower, upper
|
|
|
|
*/
|
|
|
|
void bounds(double *a, double *b) const {
|
|
|
|
*a = min;
|
|
|
|
*b = max;
|
|
|
|
}
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
void bounds(double a, double b);
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/**
|
|
|
|
Returns the number of data values in the chart.
|
|
|
|
*/
|
|
|
|
int size() const { return numb; }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/**
|
|
|
|
Sets the widget size (width, height).
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
This is the same as calling Fl_Widget::size(int W, int H);
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
\param[in] W,H new width and height of the widget
|
|
|
|
*/
|
|
|
|
void size(int W, int H) { Fl_Widget::size(W, H); }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/**
|
|
|
|
Gets the maximum number of data values for a chart.
|
|
|
|
*/
|
|
|
|
int maxsize() const { return maxnumb; }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
void maxsize(int m);
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/** Gets the chart's text font */
|
|
|
|
Fl_Font textfont() const { return textfont_; }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/** Sets the chart's text font to \p s. */
|
|
|
|
void textfont(Fl_Font s) { textfont_ = s; }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/** Gets the chart's text size */
|
|
|
|
Fl_Fontsize textsize() const { return textsize_; }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/** Sets the chart's text size to \p s. */
|
|
|
|
void textsize(Fl_Fontsize s) { textsize_ = s; }
|
2008-09-21 01:04:28 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/** Gets the chart's text color */
|
|
|
|
Fl_Color textcolor() const { return textcolor_; }
|
2008-09-21 01:04:28 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/** Sets the chart's text color to \p n. */
|
|
|
|
void textcolor(Fl_Color n) { textcolor_ = n; }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/**
|
|
|
|
Gets whether the chart will automatically adjust the bounds of the chart.
|
|
|
|
\returns non-zero if auto-sizing is enabled and zero if disabled.
|
|
|
|
*/
|
|
|
|
uchar autosize() const { return autosize_; }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2023-01-16 00:16:50 +03:00
|
|
|
/**
|
|
|
|
Sets whether the chart will automatically adjust the bounds of the chart.
|
|
|
|
\param[in] n non-zero to enable automatic resizing, zero to disable.
|
|
|
|
*/
|
|
|
|
void autosize(uchar n) { autosize_ = n; }
|
1998-10-06 22:21:25 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|