Click here to Skip to main content
15,884,629 members
Articles / Multimedia / GDI+
Article

Drawing a Bar Chart

Rate me:
Please Sign up or sign in to vote.
2.93/5 (26 votes)
25 Jun 20041 min read 143.9K   1.2K   36   8
This is an article about drawing a bar chart for a given set of values.

Sample Image - DrawBarChart.gif

Introduction

This article describes a procedure that will be useful to draw a bar chart in a form, with all features. Using this procedure, any number of graphs can be drawn in a form, by setting the X axis and Y axis.

Input Parameters

  • objEnum As IDictionaryEnumerator - the data from which the graph has to be drawn.
  • intItemCount As Integer - number of items to show in a graph (you can get from the DictionaryEnumerator itself).
  • strGraphTitle As String - title has to be drawn for the graph.
  • Xaxis As Integer - starting X axis.
  • Yaxis As Integer - starting Y axis.
  • MaxWidth As Int16 - maximum width of the graph (for calculation purpose).
  • MaxHt As Int16 - maximum height of the graph (for calculation purpose).
  • clearForm As Boolean - whether the Form has to clear or not.
  • Optional ByVal SpaceRequired As Boolean - whether space is required in between 2 graphs.

The graph has to be called in the Paint event of the Form and the parameters should be resized in the Resize event of the Form.

LoadColorArray procedure is used to have required colors to draw the graph. Because, if we use RGB, overall the graph will not be good visibly.

The parameter clearForm can be used when you need to show 2 graphs in the same Form; it will be useful then...

VB
Public Sub drawBarChart(ByVal objEnum As IDictionaryEnumerator, _
          ByVal intItemCount As Integer, ByVal strGraphTitle As String, _
          ByVal Xaxis As Integer, ByVal Yaxis As Integer, _
          ByVal MaxWidth As Int16, ByVal MaxHt As Int16, _
          ByVal clearForm As Boolean, _
          Optional ByVal SpaceRequired As Boolean = False)

    Dim intGraphXaxis As Integer = Xaxis
    Dim intGraphYaxis As Integer = Yaxis
    Dim intWidthMax As Integer = MaxWidth
    Dim intHeightMax As Integer = MaxHt
    Dim intSpaceHeight As Integer
    Dim intMaxValue As Integer = 0
    Dim intCounter As Integer
    Dim intBarWidthMax
    Dim intBarHeight
    Dim strText As String
    Try
        Dim grfx As Graphics = CreateGraphics()
        If clearForm = True Then
            grfx.Clear(BackColor)
        End If

        grfx.DrawString(strGraphTitle, New Font("VERDANA", 12.0, _
          FontStyle.Bold, GraphicsUnit.Point), _
          Brushes.DeepPink, intGraphXaxis + (intWidthMax / 4), _
          (intGraphYaxis - intHeightMax) - 40)

        'Get the Height of the Bar        
        intBarHeight = CInt(intHeightMax / intItemCount)

        'Get the space Height of the Bar 
        intSpaceHeight = _
          CInt((intHeightMax / (intItemCount - 1)) - intBarHeight)

        'Find Maximum of the input value
        If Not objEnum Is Nothing Then
            While objEnum.MoveNext = True
                If objEnum.Value > intMaxValue Then
                    intMaxValue = objEnum.Value
                End If
            End While
        End If

        'Get the Maximum Width of the Bar
        intBarWidthMax = CInt(intWidthMax / intMaxValue)

        ' Obtain the Graphics object exposed by the Form.

        If Not objEnum Is Nothing Then
            intCounter = 1
            objEnum.Reset()
            'Draw X axis and Y axis lines
            grfx.DrawLine(Pens.Black, intGraphXaxis, _
              intGraphYaxis, intGraphXaxis + intWidthMax, _
              intGraphYaxis)
            grfx.DrawLine(Pens.Black, intGraphXaxis, _
              intGraphYaxis, intGraphXaxis, _
              (intGraphYaxis - intHeightMax) - 25)

            While objEnum.MoveNext = True
                'Get new Y axis
                intGraphYaxis = intGraphYaxis - intBarHeight
                'Draw Rectangle
                grfx.DrawRectangle(Pens.Black, _
                  New Rectangle(intGraphXaxis, intGraphYaxis, _
                  intBarWidthMax * objEnum.Value, intBarHeight))
                'Fill Rectangle
                grfx.FillRectangle(objColorArray(intCounter), _
                  New Rectangle(intGraphXaxis, intGraphYaxis, _
                  intBarWidthMax * objEnum.Value, intBarHeight))
                'Display Text and value
                strText = "(" & objEnum.Key & "," & objEnum.Value & ")"
                grfx.DrawString(strText, New Font("VERDANA", 8.0, _
                  FontStyle.Regular, GraphicsUnit.Point), _
                  Brushes.Black, intGraphXaxis + _
                  (intBarWidthMax * objEnum.Value), intGraphYaxis)
                intCounter += 1
                If SpaceRequired = True Then
                    intGraphYaxis = intGraphYaxis - intSpaceHeight
                End If
                If intCounter > objColorArray.GetUpperBound(0) Then
                    intCounter = 1
                End If
            End While
            If clearForm = True Then
                grfx.Dispose()
            End If
        End If
    Catch ex As Exception
        Throw ex
    End Try
End Sub

Advantages of the procedure

We can have any number of graphs in a single form, and settings of a graph can be changed at runtime. Using LoadColorArrays procedure (Not pasted here. But available in the demo project) we can give good colors in the graph which will attract the users very much.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


Written By
Web Developer
India India
Working as a S/W Engineer with 3+ years of experience
Having MCAD in .NET
Selected as Microsoft India Community Star

Comments and Discussions

 
GeneralobjColorArray Pin
joyce1629-Sep-10 23:53
joyce1629-Sep-10 23:53 
Generaldoing it in vb 6 Pin
Anupam Verma3-Jul-07 20:07
Anupam Verma3-Jul-07 20:07 
QuestionCan it draw in a panel? Pin
Member 35766449-Feb-07 5:19
Member 35766449-Feb-07 5:19 
Generaldrawing a vertical bar chart in Web Application Pin
M.Ramesh19-Jul-06 5:28
M.Ramesh19-Jul-06 5:28 
GeneralI have a problem with the first line Pin
tutananthanh27-Jan-05 20:20
tutananthanh27-Jan-05 20:20 
Generaljust another point maker... geeeeeee Pin
Anonymous18-Jun-04 9:09
Anonymous18-Jun-04 9:09 
GeneralPicture not visible Pin
Anonymous18-Jun-04 4:16
Anonymous18-Jun-04 4:16 
GeneralRe: Picture not visible Pin
Karthikeyan Muthurajan20-Jun-04 19:08
Karthikeyan Muthurajan20-Jun-04 19:08 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.