2007-12-30 17:41:49 +01:00
|
|
|
' Gambas class file
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Export
|
|
|
|
Create Static
|
|
|
|
Private $iStyle As Integer = ChartStyle.Default
|
|
|
|
|
|
|
|
Private bFirstColumnAsLabel As Boolean = False
|
|
|
|
Public _fProportionnal As Float = 1.0
|
|
|
|
Private $bProportionnal As Boolean = True
|
|
|
|
Property FirstColumnAsLabel As Boolean
|
|
|
|
Property DataOrientation As Integer
|
|
|
|
Private $oGraphStyle As Object
|
|
|
|
Private $iDataOrientation As Integer
|
|
|
|
Private $bLegendSeries As Boolean = False
|
2007-12-30 17:41:49 +01:00
|
|
|
'PRIVATE $aroColumns AS NEW Object[]
|
2008-04-19 22:58:23 +02:00
|
|
|
Private $aroSeries As New Object[]
|
|
|
|
Private $oTitle As New _CTitle
|
2007-12-30 17:41:49 +01:00
|
|
|
'PRIVATE $oColumns AS NEW _Column
|
2008-04-19 22:58:23 +02:00
|
|
|
Private $oYAxe As New _CYAxe
|
|
|
|
Private $oXAxe As New _CXAxe
|
2009-03-05 09:48:01 +01:00
|
|
|
Private $oLegend As New _CLegend(Me)
|
2008-04-19 22:58:23 +02:00
|
|
|
Private $oColors As New _Colors
|
|
|
|
Private $iType As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
'PRIVATE $iStyle AS Integer
|
2008-04-19 22:58:23 +02:00
|
|
|
Private $iWidth As Integer
|
|
|
|
Private $iHeight As Integer
|
2009-03-05 09:48:01 +01:00
|
|
|
Private $oHeaders As New _CHeaders(Me)
|
|
|
|
Private $iBackground As Integer = Color.White
|
2008-04-20 01:32:28 +02:00
|
|
|
Private $iBorder As Boolean = True
|
2008-04-20 00:32:23 +02:00
|
|
|
|
|
|
|
|
2008-04-20 01:32:28 +02:00
|
|
|
Property Border As Boolean
|
2009-03-05 09:48:01 +01:00
|
|
|
Property Background As Integer
|
2008-04-20 00:32:23 +02:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Property Height As Integer
|
|
|
|
Property Width As Integer
|
|
|
|
Property Type As Integer
|
|
|
|
Property {Picture} As Picture
|
|
|
|
Property Read Legend As _CLegend
|
|
|
|
Property Read YAxe As _CYAxe
|
|
|
|
Property Read XAxe As _CXAxe
|
|
|
|
|
|
|
|
Property Read Colors As _Colors
|
|
|
|
|
|
|
|
Property Read Title As _CTitle
|
2007-12-30 17:41:49 +01:00
|
|
|
'PROPERTY Style AS Integer
|
2008-04-19 22:58:23 +02:00
|
|
|
Property CountDataSets As Integer
|
|
|
|
Property Count As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Property Proportionnal As Boolean
|
|
|
|
Property Read Headers As _CHeaders
|
|
|
|
Property Style As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Public Sub _New()
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Me.CountDataSets = 1
|
2008-12-13 15:21:05 +01:00
|
|
|
Me.Type = ChartType.Columns
|
2007-12-30 17:41:49 +01:00
|
|
|
'MTools.ColorList = [color.Blue, color.Yellow, color.Red, color.Green, color.Orange, color.DarkBlue]
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Height_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $iHeight
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub Height_Write(Value As Integer)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$iHeight = Value
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Width_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $iWidth
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub Width_Write(Value As Integer)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$iWidth = Value
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Type_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $iType
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub Type_Write(Value As Integer)
|
2007-12-30 17:41:49 +01:00
|
|
|
$iType = Value
|
2008-04-19 22:58:23 +02:00
|
|
|
With ChartType
|
|
|
|
Select Case $iType
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Case .Columns, .ColumnsStacked, .ColumnsPercent, .ColumnsLineCombination
|
2009-03-05 09:48:01 +01:00
|
|
|
$oGraphStyle = New _CStyleColumns(Value, Me)
|
2008-04-19 22:58:23 +02:00
|
|
|
$bLegendSeries = False
|
|
|
|
Case .Pie, .PieRings, .PieOffSet1, .PieOffSet2
|
2009-03-05 09:48:01 +01:00
|
|
|
$oGraphStyle = New _CStylePie(Value, Me)
|
2008-04-19 22:58:23 +02:00
|
|
|
$bLegendSeries = False
|
|
|
|
Case .Lines, .LinesStacked, .LinesPercent, .LinesSymbols
|
2009-03-05 09:48:01 +01:00
|
|
|
$oGraphStyle = New _CStyleLine(Value, Me)
|
2008-04-19 22:58:23 +02:00
|
|
|
$bLegendSeries = True
|
|
|
|
Case .Areas, .AreasStacked, .AreasPercent, .AreasSymbols
|
2009-03-05 09:48:01 +01:00
|
|
|
$oGraphStyle = New _CStyleAreas(Value, Me)
|
2008-04-19 22:58:23 +02:00
|
|
|
$bLegendSeries = True
|
|
|
|
Case .Bars, .BarsPercent, .BarsStacked
|
2009-03-05 09:48:01 +01:00
|
|
|
$oGraphStyle = New _CStyleBar(Value, Me)
|
2008-04-19 22:58:23 +02:00
|
|
|
$bLegendSeries = False
|
2008-12-13 15:21:05 +01:00
|
|
|
Case .Plots
|
2009-03-05 09:48:01 +01:00
|
|
|
$oGraphStyle = New _CStylePlot(Value, Me)
|
2008-12-13 15:21:05 +01:00
|
|
|
$bLegendSeries = True
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End Select
|
|
|
|
End With
|
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Legend_Read() As _CLegend
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $oLegend
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Picture_Read() As Picture
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub Picture_Write(Value As Picture)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Title_Read() As _CTitle
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $oTitle
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Public Sub Draw()
|
|
|
|
Dim iClientHeight, iClientWidth As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Dim iTitleHeight As Integer
|
|
|
|
Dim iStaticSpace As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
'Draw.Font.Size = 12 * (Chart.Width / 640)
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
_fProportionnal = IIf(Me.Width <= Me.Height, Me.Width / (Desktop.Height * 2 / 3), Me.Height / (Desktop.Height * 2 / 3))
|
|
|
|
If Not $bProportionnal Then _fProportionnal = 1.0
|
2009-03-05 09:48:01 +01:00
|
|
|
iStaticSpace = 5 * Me._fProportionnal
|
2007-12-30 17:41:49 +01:00
|
|
|
'Draw the Legend and get the graph caneva size
|
|
|
|
$oLegend.Draw($bLegendSeries)
|
|
|
|
'Draw The Title
|
2008-12-13 15:21:05 +01:00
|
|
|
iTitleHeight = iStaticSpace
|
2008-04-19 22:58:23 +02:00
|
|
|
If Not IsNull(Me.Title.Text) And Me.Title.Visible Then
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
'Draw.Font.Grade = 4
|
2008-04-20 09:55:10 +02:00
|
|
|
Draw.Font = $oTitle.Font
|
2007-12-30 17:41:49 +01:00
|
|
|
Draw.Font.Size = $oTitle.Font.Size * _fProportionnal
|
2008-12-13 15:21:05 +01:00
|
|
|
iTitleHeight = Draw.Font.Height() * 2
|
2008-04-19 22:58:23 +02:00
|
|
|
Endif
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
iClientWidth = Me.Width - $oLegend._Width - 2 * iStaticSpace
|
2008-12-13 15:21:05 +01:00
|
|
|
iClientHeight = Me.Height - $oLegend._Height - 2 * iStaticSpace
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
Draw.FillColor = color.White
|
2008-12-13 15:21:05 +01:00
|
|
|
If $iBorder Then Draw.Rect(iStaticSpace, iStaticSpace, iClientWidth - iStaticSpace, iClientHeight - iStaticSpace)
|
2007-12-30 17:41:49 +01:00
|
|
|
'Draw.Font.Grade = 4
|
|
|
|
|
2008-12-13 15:21:05 +01:00
|
|
|
$oGraphStyle.Draw(iStaticSpace, iTitleHeight, iClientWidth, iClientHeight - iTitleHeight - iStaticSpace)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
If Not IsNull(Me.Title.Text) And Me.Title.Visible Then
|
2007-12-30 17:41:49 +01:00
|
|
|
Draw.ForeColor = Color.Black
|
2008-04-19 22:58:23 +02:00
|
|
|
Draw.Font.Size = Me.Title.Font.Size * _fProportionnal
|
2008-12-13 15:21:05 +01:00
|
|
|
Draw.Text(Me.Title.Text, iStaticSpace, iStaticSpace, iClientWidth, iTitleHeight, Align.Center)
|
2008-04-19 22:58:23 +02:00
|
|
|
Endif
|
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function CountDataSets_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $aroSeries.Count
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub CountDataSets_Write(Value As Integer)
|
|
|
|
Dim oSeries As _CSerie
|
|
|
|
Dim cnt As Integer
|
|
|
|
Dim i As Integer
|
|
|
|
If $aroSeries.Count < Value Then
|
|
|
|
For i = 0 To (Value - $aroSeries.Count) - 1
|
2009-03-05 09:48:01 +01:00
|
|
|
oSeries = New _CSerie(Me)
|
2007-12-30 17:41:49 +01:00
|
|
|
$aroSeries.Add(oSeries)
|
2008-04-19 22:58:23 +02:00
|
|
|
Next
|
|
|
|
Else If $aroSeries.Count > Value Then
|
2007-12-30 17:41:49 +01:00
|
|
|
cnt = $aroSeries.Count - Value
|
|
|
|
$aroSeries.Remove($aroSeries - cnt, cnt)
|
2008-04-19 22:58:23 +02:00
|
|
|
Endif
|
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Public Sub _Get(Index As Integer) As _CSerie
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $aroSeries[Index]
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function FirstColumnAsLabel_Read() As Boolean
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return bFirstColumnAsLabel
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub FirstColumnAsLabel_Write(Value As Boolean)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
bFirstColumnAsLabel = Value
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function DataOrientation_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $iDataOrientation
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub DataOrientation_Write(Value As Integer)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$iDataOrientation = Value
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Public Function _Next() As Variant
|
|
|
|
If enum.Index = Null Then enum.Index = -1
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
If enum.Index = $aroSeries.max Then
|
2007-12-30 17:41:49 +01:00
|
|
|
enum.Stop
|
2008-04-19 22:58:23 +02:00
|
|
|
Return
|
|
|
|
Endif
|
|
|
|
Inc enum.Index
|
|
|
|
Return $aroSeries[enum.Index]
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Proportionnal_Read() As Boolean
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $bProportionnal
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub Proportionnal_Write(Value As Boolean)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$bProportionnal = Value
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function YAxe_Read() As _CYAxe
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $oYAxe
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Headers_Read() As _CHeaders
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $oHeaders
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Count_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
'Alias vers Labels.count
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $oHeaders.Count
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub Count_Write(Value As Integer)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
'Alias vers Labels.count
|
|
|
|
$oHeaders.Count = Value
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Colors_Read() As _Colors
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $oColors
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Function Style_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Return $iStyle
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
Private Sub Style_Write(Value As Integer)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$iStyle = Value
|
|
|
|
|
2008-04-19 22:58:23 +02:00
|
|
|
End
|
|
|
|
|
|
|
|
Public Sub Resize(iWidth As Integer, iHeight As Integer)
|
|
|
|
|
|
|
|
|
|
|
|
$iWidth = iWidth
|
|
|
|
$iHeight = iHeight
|
|
|
|
End
|
|
|
|
|
|
|
|
Private Function XAxe_Read() As _CXAxe
|
|
|
|
|
|
|
|
Return $oXAxe
|
|
|
|
|
|
|
|
End
|
2008-04-20 00:32:23 +02:00
|
|
|
|
2009-03-05 09:48:01 +01:00
|
|
|
Private Function Background_Read() As Integer
|
2008-04-20 00:32:23 +02:00
|
|
|
|
2009-03-05 09:48:01 +01:00
|
|
|
Return $iBackground
|
2008-04-20 00:32:23 +02:00
|
|
|
|
|
|
|
End
|
|
|
|
|
2009-03-05 09:48:01 +01:00
|
|
|
Private Sub Background_Write(Value As Integer)
|
2008-04-20 00:32:23 +02:00
|
|
|
|
2009-03-05 09:48:01 +01:00
|
|
|
$iBackground = Value
|
2008-04-20 00:32:23 +02:00
|
|
|
|
|
|
|
End
|
2008-04-20 01:32:28 +02:00
|
|
|
|
|
|
|
Private Function Border_Read() As Boolean
|
|
|
|
|
|
|
|
Return $iBorder
|
|
|
|
|
|
|
|
End
|
|
|
|
|
|
|
|
Private Sub Border_Write(Value As Boolean)
|
|
|
|
|
|
|
|
$iBorder = Value
|
|
|
|
|
|
|
|
End
|