boinc/clientgui/common/wxPieCtrl.h

249 lines
8.2 KiB
C++

/////////////////////////////////////////////////////////////////////////////
// Name: wxPieCtrl.h
// Purpose: wxPieCtrl (v0.1.2)
// Author: Volodymir (T-Rex) Tryapichko
// Modified by: Frank Weiler, 10.10.2006
// Created: June-07-2005
// RCS-ID: $Id:
// Copyright: (c) Volodymir (T-Rex) Tryapichko
// Licence: wxWidgets license
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_PIE_CTRL
#define _WX_PIE_CTRL
#include <wx/wx.h>
#include <wx/image.h>
#include <wx/dynarray.h>
#ifndef M_PI
#define M_PI 3.14159265358979
#endif
#if ! wxCHECK_VERSION(2,8,0)
WX_DECLARE_OBJARRAY(double, wxArrayDouble);
#endif
// ========================================================================
// wxPiePart
// ------------------------------------------------------------------------
/// This class is used for storing data in wxPieCtrl.
class wxPiePart
{
double m_Value;
wxColour m_Colour;
wxString m_Label;
public:
/// Default constructor
wxPiePart();
/// Parametrized constructor
/*!
\param value used for drawing the pie. Specifies the size of the sector.
\param colour specifies the colour of the sector
\param label specifies the text to be shown in diagram legend
*/
wxPiePart(double value, wxColour colour, wxString label = wxEmptyString);
/// Copy constructor
wxPiePart(const wxPiePart & part);
/// Returns the colour of sector
wxColour GetColour() {return m_Colour;}
/// Sets the colour of sector
void SetColour(wxColour colour) {m_Colour = colour;}
/// Returns the size of sector
double GetValue() {return m_Value;}
/// Sets the size of sector
void SetValue(double value) {m_Value = fabs(value);}
/// Returns the label of sector
wxString GetLabel() {return m_Label;}
/// Sets the label of sector
void SetLabel(wxString value) {m_Label = value;}
};
WX_DECLARE_OBJARRAY(wxPiePart, wxPieSeries);
class wxPieCtrl;
// ========================================================================
// wxPieCtrlLegend
// ------------------------------------------------------------------------
/// The component draws a rectangle and outputs text information for
/// each sector of pie diagram
class wxPieCtrlLegend : public wxWindow
{
wxFont m_TitleFont;
wxFont m_LabelFont;
bool m_IsTransparent;
wxColour m_TitleColour;
wxColour m_LabelColour;
wxColour m_BackColour;
wxBitmap m_Background;
wxMemoryDC m_BackgroundDC;
unsigned int m_HorBorder;
unsigned int m_VerBorder;
wxString m_szTitle;
protected:
void RecreateBackground(wxMemoryDC & parentdc);
public:
/// Constructor
/*!
\param parent Pointer to a parent window
\param title Legend window title
\param pos Legend window position
\param sz Legend window size
\param style Window style
*/
wxPieCtrlLegend(wxPieCtrl * parent, wxString title = wxEmptyString,
wxPoint pos = wxPoint(10,10), wxSize sz = wxDefaultSize,
long style = 0);
/// Returns transparency flag of legend window
bool IsTransparent() {return m_IsTransparent;}
/// Sets transparency flag of legend window
void SetTransparent(bool value);
/// Returns the font used for displaying the labels of sectors
wxFont GetLabelFont() {return m_LabelFont;}
/// Sets the font used for displaying the labels of sectors
void SetLabelFont(wxFont font);
/// Returns the size of horizontal border of legend window
unsigned int GetHorBorder() {return m_HorBorder;}
/// Returns the size of vertical border of legend window
unsigned int GetVerBorder() {return m_VerBorder;}
/// Sets the size of horizontal border of legend window
void SetHorBorder(unsigned int value);
/// Sets the size of vertical border of legend window
void SetVerBorder(unsigned int value);
/// Returns the colour used for displaying the labels of sectors
wxColour GetLabelColour() {return m_LabelColour;}
/// Sets the colour used for displaying the labels of sectors
void SetLabelColour(wxColour colour);
/// Returns the colour used for displaying lagend window background
wxColour GetBackColour() {return m_BackColour;}
/// Sets the colour used for displaying legend window background
void SetBackColour(wxColour colour);
void SetLabel(const wxString& label);
DECLARE_EVENT_TABLE()
void OnPaint(wxPaintEvent & event);
void OnEraseBackground(wxEraseEvent & event);
friend class wxPieCtrl;
};
// ========================================================================
// wxPieCtrl
// ------------------------------------------------------------------------
/// The component for drawing pie diagrams
class wxPieCtrl : public wxWindow
{
double m_Angle;
double m_RotationAngle;
int m_Height;
wxArrayDouble m_Values;
wxBitmap m_Background;
wxBitmap m_CanvasBitmap;
wxMemoryDC m_CanvasDC;
wxColour m_BackColour;
wxPieCtrlLegend * m_Legend;
bool m_ShowEdges;
void GetPartAngles(wxArrayDouble & angles);
#if defined(__WXMSW__) || defined(__WXMAC__)
void DrawParts(wxMemoryDC & dc, int cx, int cy, int w, int h);
#endif
void RecreateCanvas();
protected:
bool m_CanRepaint;
bool m_bPaint3D;
bool m_bDrawCircle;
void Draw(wxPaintDC & pdc);
public:
/// An array of wxPiePart objects for storing information about sectors
wxPieSeries m_Series;
/// Constructor
/*!
\param parent Pointer to a parent window
\param id Window ID
\param pos Window position
\param sz Window size
\param style Window style
\param name Window name
*/
wxPieCtrl(wxWindow * parent, wxWindowID id = wxID_ANY, wxPoint pos = wxDefaultPosition,
wxSize sz = wxDefaultSize, long style = 0, wxString name = wxT("wxPieCtrl"));
/// Sets the angle of vertical rotation
void SetAngle(double angle);
/// Sets the angle of horizontal rotation
void SetRotationAngle(double angle);
/// Sets the height of pie diagram
void SetHeight(int value) {m_Height = abs(value);}
/// Sets the background bitmap of the control
void SetBackground(wxBitmap bmp);
/// Returns the background colour of the control
wxColour GetBackColour() {return m_BackColour;}
/// Sets the background colour of the control
void SetBackColour(wxColour colour);
//set 3D mode
void SetPaint3D(bool b3D);
//get 3D mode
bool GetPaint3D();
//set circle mode
void SetDrawCircle(bool bCircle);
//get circle mode
bool GetDrawCircle();
/// Returns true if the edges of diagram are shown, otherwise returns false
bool GetShowEdges() {return m_ShowEdges;}
/// Shows or hides edges of diagram
/*!
\param value Specifies the visibility of diagram edges
*/
void SetShowEdges(bool value);
/// Returns the pointer of diagram legend
wxPieCtrlLegend * GetLegend() {return m_Legend;}
virtual void Refresh(bool eraseBackground = true, const wxRect* rect = NULL);
DECLARE_EVENT_TABLE()
void OnPaint(wxPaintEvent & event);
void OnEraseBackground(wxEraseEvent & event);
void OnSize(wxSizeEvent & event);
};
// ========================================================================
// wxProgressPie
// ------------------------------------------------------------------------
/// A ProgressPie is a pie digram control which shows a quantity (often time).
class wxProgressPie : public wxPieCtrl
{
double m_MaxValue;
double m_Value;
wxColour m_FilledColour;
wxColour m_UnfilledColour;
public:
/// Constructor
/*!
\param parent Pointer to a parent window
\param id Window ID
\param maxvalue Maximal value of progress pie
\param value Initial value of progress pie
\param pos Window position
\param sz Window size
\param style Window style
*/
wxProgressPie(wxWindow * parent, wxWindowID id = wxID_ANY, double maxvalue = 100, double value = 50,
wxPoint pos = wxDefaultPosition, wxSize sz = wxDefaultSize, long style = 0);
/// Sets the value of progress pie
void SetValue(double value);
/// Returns the value of progress pie
double GetValue() {return m_Value;}
/// Sets maximal value of progress pie
void SetMaxValue(double value);
/// Returns maximal value of progress pie
double GetMaxValue() {return m_MaxValue;}
/// Sets the colour of sector that indicates the progress (filled)
void SetFilledColour(wxColour colour);
/// Sets the colour of sector that indicates the rest (unfilled)
void SetUnfilledColour(wxColour colour);
/// Returns the colour of sector that indicates the progress (filled)
wxColour GetFilledColour();
/// Returns the colour of sector that indicates the rest (unfilled)
wxColour GetUnfilledColour();
};
#endif