2007-12-30 17:41:49 +01:00
|
|
|
' Gambas class file
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Export
|
2007-12-30 17:41:49 +01:00
|
|
|
'PUBLIC CONST Top AS Integer = 1
|
2008-04-20 00:32:23 +02:00
|
|
|
'Public Const Bottom As Integer = Align.Bottom
|
2007-12-30 17:41:49 +01:00
|
|
|
'PUBLIC CONST {Left} AS Integer = 3
|
2008-04-20 00:32:23 +02:00
|
|
|
'Public Const {Right} As Integer = Align.Right
|
|
|
|
Private $iWidth As Integer
|
|
|
|
Private $iHeight As Integer
|
|
|
|
Private $iPosition As Integer = Align.Right 'Me.Right
|
|
|
|
Private $sTitle As String
|
|
|
|
Private $bVisible As Boolean = False
|
|
|
|
Private $oFont As New Font
|
|
|
|
Property {Font} As Font
|
|
|
|
|
|
|
|
Property Title As String
|
|
|
|
Property Position As Integer
|
|
|
|
Property Visible As Integer
|
|
|
|
Property Read _Width As Integer
|
|
|
|
Property Read _Height As Integer
|
|
|
|
|
|
|
|
|
|
|
|
Public Sub _New()
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Me.Font.Size = 11
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Function Title_Read() As String
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Return $sTitle
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Sub Title_Write(Value As String)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$sTitle = Value
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Function Position_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Return $iPosition
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Sub Position_Write(Value As Integer)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$iPosition = Value
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Function Visible_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Return $bVisible
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Sub Visible_Write(Value As Integer)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$bVisible = Value
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Public Sub Draw(bSeries As Boolean)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Dim x, y, w, h As Integer
|
|
|
|
Dim S As String
|
|
|
|
Dim i, cnt As Integer
|
|
|
|
Dim SQUARESIZE As Integer
|
|
|
|
Dim TitleH As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
'DIM hColumn AS _Column
|
2008-04-20 00:32:23 +02:00
|
|
|
Dim iStaticSpace As Integer = 5 * Chart._fProportionnal
|
|
|
|
Dim arsInt As String[]
|
|
|
|
Dim oSerie As _CSerie
|
2007-12-30 17:41:49 +01:00
|
|
|
$iWidth = 0
|
|
|
|
$iHeight = 0
|
|
|
|
'Créé un tableau interne contenant soit les série soit les entête
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
If bSeries Then
|
|
|
|
arsInt = New String[]
|
|
|
|
For Each oSerie In Chart
|
2007-12-30 17:41:49 +01:00
|
|
|
arsInt.Add(oSerie.Text)
|
2008-04-20 00:32:23 +02:00
|
|
|
Next
|
|
|
|
Else
|
2007-12-30 17:41:49 +01:00
|
|
|
arsInt = Chart.Headers.Values
|
2008-04-20 00:32:23 +02:00
|
|
|
Endif
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
If Not $bVisible Then Return
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
w = Chart.Width
|
|
|
|
h = Chart.Height
|
|
|
|
'draw.Font = Chart.Font
|
|
|
|
'Get the max text length
|
2008-04-20 00:32:23 +02:00
|
|
|
For Each s In arsInt
|
2007-12-30 17:41:49 +01:00
|
|
|
i = draw.TextWidth(s)
|
2008-04-20 00:32:23 +02:00
|
|
|
If i > cnt Then cnt = i
|
|
|
|
Next
|
2008-04-20 09:55:10 +02:00
|
|
|
draw.Font = $oFont
|
2007-12-30 17:41:49 +01:00
|
|
|
draw.Font.Size = $oFont.Size * Chart._fProportionnal
|
|
|
|
SQUARESIZE = draw.TextHeight("T")
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Select Case $iPosition
|
|
|
|
Case Align.Right 'Me.Right
|
|
|
|
If draw.TextWidth(Chart.Legend.Title) > cnt Then cnt = draw.TextWidth(Chart.Legend.Title)
|
2007-12-30 17:41:49 +01:00
|
|
|
w = iStaticSpace + SQUARESIZE + iStaticSpace + cnt + iStaticSpace
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
If $sTitle <> "" Then TitleH = draw.TextHeight($sTitle)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
h = TitleH + iStaticSpace + arsInt.Count * (draw.Font.Height() + iStaticSpace)
|
|
|
|
x = Chart.Width - w - iStaticSpace
|
|
|
|
y = (Chart.Height - h) / 2
|
|
|
|
draw.ForeColor = Color.Black
|
|
|
|
Draw.Rect(x, Y, w, h)
|
|
|
|
Draw.Text(Chart.Legend.Title, x + iStaticSpace + (w - cnt) / 2, Y)
|
|
|
|
draw.Font.Size = $oFont.Size * Chart._fProportionnal
|
|
|
|
cnt = 0
|
2008-04-20 00:32:23 +02:00
|
|
|
For i = 0 To arsInt.max
|
2007-12-30 17:41:49 +01:00
|
|
|
Draw.FillColor = Chart.Colors[i]
|
|
|
|
Draw.FillStyle = Fill.Solid
|
|
|
|
Draw.Rect(x + iStaticSpace, Y + TitleH + iStaticSpace + cnt, SQUARESIZE, SQUARESIZE)
|
|
|
|
Draw.Text(arsInt[i], x + iStaticSpace + SQUARESIZE + iStaticSpace, Y + TitleH + iStaticSpace + cnt)
|
|
|
|
cnt += Draw.Font.Height() + iStaticSpace
|
2008-04-20 00:32:23 +02:00
|
|
|
Next
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
$iWidth = w + iStaticSpace
|
|
|
|
$iHeight = 0
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Case Align.Bottom
|
|
|
|
If $sTitle <> "" Then TitleH = draw.TextHeight($sTitle)
|
2007-12-30 17:41:49 +01:00
|
|
|
h = iStaticSpace + TitleH + iStaticSpace + SQUARESIZE + iStaticSpace
|
|
|
|
w = 0
|
2008-04-20 00:32:23 +02:00
|
|
|
For Each s In arsInt
|
2007-12-30 17:41:49 +01:00
|
|
|
w += iStaticSpace + SQUARESIZE + 5 + draw.TextWidth(s) + iStaticSpace
|
2008-04-20 00:32:23 +02:00
|
|
|
Next
|
2007-12-30 17:41:49 +01:00
|
|
|
w += iStaticSpace
|
|
|
|
Draw.Rect((Chart.Width - w) / 2, Chart.Height - h - iStaticSpace, w, h)
|
|
|
|
Draw.Text($sTitle, (Chart.Width - Draw.TextWidth($sTitle)) / 2, Chart.Height - h)
|
|
|
|
x = (Chart.Width - w) / 2
|
|
|
|
y = Chart.Height - h + TitleH + iStaticSpace
|
|
|
|
i = 0
|
|
|
|
draw.Font.Size = $oFont.Size * Chart._fProportionnal
|
2008-04-20 00:32:23 +02:00
|
|
|
For Each s In arsInt
|
2007-12-30 17:41:49 +01:00
|
|
|
x += iStaticSpace
|
|
|
|
draw.FillColor = Chart.Colors[i]
|
|
|
|
Draw.FillStyle = Fill.Solid
|
|
|
|
draw.Rect(x, y, SQUARESIZE, SQUARESIZE)
|
|
|
|
x += SQUARESIZE + iStaticSpace
|
|
|
|
draw.Text(s, x, y)
|
|
|
|
|
|
|
|
x += draw.TextWidth(s) + iStaticSpace
|
2008-04-20 00:32:23 +02:00
|
|
|
Inc i
|
|
|
|
Next
|
2007-12-30 17:41:49 +01:00
|
|
|
$iWidth = 0
|
|
|
|
$iHeight = h + iStaticSpace
|
2008-04-20 00:32:23 +02:00
|
|
|
End Select
|
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Function _Width_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Return $iWidth
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Function _Height_Read() As Integer
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Return $iHeight
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Function Font_Read() As Font
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Return $oFont
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
Private Sub Font_Write(Value As Font)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
$oFont = Value
|
|
|
|
|
2008-04-20 00:32:23 +02:00
|
|
|
End
|