1998-10-20 01:39:29 +04:00
|
|
|
//
|
2005-02-25 00:55:12 +03:00
|
|
|
// "$Id$"
|
1998-10-20 01:39:29 +04:00
|
|
|
//
|
|
|
|
// Forms chart header file for the Fast Light Tool Kit (FLTK).
|
|
|
|
//
|
2010-11-29 00:06:39 +03:00
|
|
|
// Copyright 1998-2010 by Bill Spitzak and others.
|
1998-10-20 01:39:29 +04:00
|
|
|
//
|
|
|
|
// This library is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU Library General Public
|
|
|
|
// License as published by the Free Software Foundation; either
|
|
|
|
// version 2 of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This library is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
// Library General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Library General Public
|
|
|
|
// License along with this library; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
|
|
// USA.
|
|
|
|
//
|
2005-04-16 04:13:17 +04:00
|
|
|
// Please report all bugs and problems on the following page:
|
|
|
|
//
|
|
|
|
// http://www.fltk.org/str.php
|
1998-10-20 01:39:29 +04:00
|
|
|
//
|
1998-10-06 22:21:25 +04:00
|
|
|
|
2008-10-15 17:46:06 +04:00
|
|
|
/* \file
|
2008-09-16 11:26:22 +04:00
|
|
|
Fl_Chart widget . */
|
|
|
|
|
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()
|
2008-09-21 01:04:28 +04: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
|
|
|
|
2008-09-21 01:04:28 +04:00
|
|
|
#define FL_FILLED_CHART FL_FILL_CHART /**< for compatibility */
|
1998-10-06 22:21:25 +04:00
|
|
|
|
2008-09-21 01:04:28 +04: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
|
|
|
|
2008-09-21 01:04:28 +04:00
|
|
|
/** For internal use only */
|
1998-10-06 22:21:25 +04:00
|
|
|
struct FL_CHART_ENTRY {
|
2008-09-21 01:04:28 +04: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.
|
|
|
|
|
2010-12-09 02:53:04 +03:00
|
|
|
\image html charts.png
|
|
|
|
\image latex charts.png "Fl_Chart" width=10cm
|
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:
|
|
|
|
\li \c FL_BAR_CHART: Each sample value is drawn as a vertical bar.
|
|
|
|
\li \c FL_FILLED_CHART: The chart is filled from the bottom of the graph
|
|
|
|
to the sample values.
|
|
|
|
\li \c FL_HORBAR_CHART: Each sample value is drawn as a horizontal bar.
|
|
|
|
\li \c FL_LINE_CHART: The chart is drawn as a polyline with vertices at
|
|
|
|
each sample value.
|
|
|
|
\li \c FL_PIE_CHART: A pie chart is drawn with each sample value being
|
|
|
|
drawn as a proportionate slice in the circle.
|
|
|
|
\li \c FL_SPECIALPIE_CHART: Like \c FL_PIE_CHART, but the first slice is
|
|
|
|
separated from the pie.
|
|
|
|
\li \c 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 {
|
1998-10-06 22:21:25 +04:00
|
|
|
int numb;
|
|
|
|
int maxnumb;
|
1999-02-01 23:15:00 +03:00
|
|
|
int sizenumb;
|
|
|
|
FL_CHART_ENTRY *entries;
|
1998-10-06 22:21:25 +04:00
|
|
|
double min,max;
|
|
|
|
uchar autosize_;
|
2008-04-23 23:09:28 +04:00
|
|
|
Fl_Font textfont_;
|
2008-08-16 01:11:21 +04:00
|
|
|
Fl_Fontsize textsize_;
|
2009-09-27 15:06:56 +04:00
|
|
|
Fl_Color textcolor_;
|
1998-10-06 22:21:25 +04:00
|
|
|
protected:
|
2002-08-14 20:49:38 +04:00
|
|
|
void draw();
|
1998-10-06 22:21:25 +04:00
|
|
|
public:
|
2008-09-16 10:49:08 +04:00
|
|
|
Fl_Chart(int X, int Y, int W, int H, const char *L = 0);
|
|
|
|
|
2002-09-05 00:33:18 +04:00
|
|
|
~Fl_Chart();
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2002-08-14 20:49:38 +04:00
|
|
|
void clear();
|
2008-09-16 10:49:08 +04:00
|
|
|
|
|
|
|
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);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the lower and upper bounds of the chart values.
|
|
|
|
\param[out] a, b are set to lower, upper
|
|
|
|
*/
|
1998-10-06 22:21:25 +04:00
|
|
|
void bounds(double *a,double *b) const {*a = min; *b = max;}
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2002-08-14 20:49:38 +04:00
|
|
|
void bounds(double a,double b);
|
2008-09-16 10:49:08 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the number of data values in the chart.
|
|
|
|
*/
|
1998-10-06 22:21:25 +04:00
|
|
|
int size() const {return numb;}
|
2008-09-16 10:49:08 +04:00
|
|
|
|
2003-06-15 08:47:28 +04:00
|
|
|
void size(int W, int H) { Fl_Widget::size(W, H); }
|
2008-09-16 10:49:08 +04:00
|
|
|
|
|
|
|
/**
|
2008-09-21 01:04:28 +04:00
|
|
|
Gets the maximum number of data values for a chart.
|
2008-09-16 10:49:08 +04:00
|
|
|
*/
|
1998-10-06 22:21:25 +04:00
|
|
|
int maxsize() const {return maxnumb;}
|
2008-09-16 10:49:08 +04:00
|
|
|
|
|
|
|
void maxsize(int m);
|
|
|
|
|
2008-09-21 01:04:28 +04:00
|
|
|
/** Gets the chart's text font */
|
2008-04-23 23:09:28 +04:00
|
|
|
Fl_Font textfont() const {return textfont_;}
|
2008-09-21 01:04:28 +04:00
|
|
|
/** Sets the chart's text font to \p s. */
|
2008-04-23 23:09:28 +04:00
|
|
|
void textfont(Fl_Font s) {textfont_ = s;}
|
2008-09-21 01:04:28 +04:00
|
|
|
|
|
|
|
/** Gets the chart's text size */
|
2008-08-16 01:11:21 +04:00
|
|
|
Fl_Fontsize textsize() const {return textsize_;}
|
2008-09-21 01:04:28 +04:00
|
|
|
/** gets the chart's text size to \p s. */
|
2008-08-16 01:11:21 +04:00
|
|
|
void textsize(Fl_Fontsize s) {textsize_ = s;}
|
2008-09-21 01:04:28 +04:00
|
|
|
|
|
|
|
/** Gets the chart's text color */
|
2009-09-27 15:06:56 +04:00
|
|
|
Fl_Color textcolor() const {return textcolor_;}
|
2008-09-21 01:04:28 +04:00
|
|
|
/** gets the chart's text color to \p n. */
|
2009-09-27 15:06:56 +04:00
|
|
|
void textcolor(Fl_Color n) {textcolor_ = n;}
|
2008-09-16 10:49:08 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
Get whether the chart will automatically adjust the bounds of the chart.
|
|
|
|
\returns non-zero if auto-sizing is enabled and zero if disabled.
|
|
|
|
*/
|
1998-10-06 22:21:25 +04:00
|
|
|
uchar autosize() const {return autosize_;}
|
2008-09-16 10:49:08 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
Set whether the chart will automatically adjust the bounds of the chart.
|
2008-10-03 16:00:21 +04:00
|
|
|
\param[in] n non-zero to enable automatic resizing, zero to disable.
|
2008-09-16 10:49:08 +04:00
|
|
|
*/
|
1998-10-06 22:21:25 +04:00
|
|
|
void autosize(uchar n) {autosize_ = n;}
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|
1998-10-20 01:39:29 +04:00
|
|
|
|
|
|
|
//
|
2005-02-25 00:55:12 +03:00
|
|
|
// End of "$Id$".
|
1998-10-20 01:39:29 +04:00
|
|
|
//
|