Solved

Don't understand where to call MyBase.Paint

Posted on 2006-06-16
3
484 Views
Last Modified: 2010-05-18
Using Windows Forms, .NET 1.1, VS 2003

I understand that you call the base class method in vb.net to do some initializing or setting things up normally before you call your derived method but I am missing something from my understanding
I inherited from a datagridtextboxcolumn and override the paint method to color cells depending on their value etc. The problem I am having is deciding where to call the base paint method as I don't think I really understand.

If I call the paint method in one place, then some cells get colored while others don't, or the formatting gets messed up in one place and not in others. Below is my paint method. I initially got the code online and modified it to do what I want. Basically, I have been calling MyBase.Paint() at different points in my code to get it working but I don't know why. Help.


 Protected Overloads Overrides Sub Paint(ByVal g As Graphics, ByVal bounds As Rectangle, ByVal source As CurrencyManager, ByVal rowNum As Integer, ByVal backBrush As Brush, ByVal foreBrush As Brush, ByVal alignToRight As Boolean)

    Dim e As DataGridFormatCellEventArgs
    e = New DataGridFormatCellEventArgs(rowNum, Me._col, Me.DataGridTableStyle.DataGrid.Font, backBrush, foreBrush)
    RaiseEvent SetCellFormat(Me, e)

    'Note that UseBaseClassDrawing is the property of useBaseClassDrawing private data member
    'It is set to false by default
    If e.UseBaseClassDrawing Then
        MyBase.Paint(g, bounds, source, rowNum, backBrush, foreBrush, alignToRight)
    Else
        g.FillRectangle(e.BackBrush, bounds)
        g.DrawString(Me.GetColumnValueAtRow(source, rowNum).ToString, e.TextFont, e.ForeBrush, bounds.X, bounds.Y)
    End If

    If (e.TextFont Is Me.DataGridTableStyle.DataGrid.Font) = False Then
        e.TextFont.Dispose()
    End If

    Try
        'If the cell value is 0 or less than 0, color it red
        Dim cellVal As String = Me.GetColumnValueAtRow(source, rowNum)
        If (Not cellVal Is Nothing) Then
            Dim c As Integer
            c = CType(cellVal, Integer)
            If (c = 1 Or c < 1) Then
                e.ForeBrush = New SolidBrush(Color.Red)

                MyBase.Paint(g, bounds, source, rowNum, backBrush, e.ForeBrush, alignToRight)
            Else
                MyBase.Paint(g, bounds, source, rowNum, backBrush, e.ForeBrush, alignToRight)
            End If
        End If


        'Check for the cell date value and if less than now, draw lines in the cell
        cellDate = Me.DataGridTableStyle.DataGrid.Item(rowNum, 0)
        If (Not hourMinString Is Nothing) Then
            Dim cellToDisable As Boolean = CellDateLessToday(cellDate, DateTime.Now())
            If (cellToDisable = True) And (_col = 1) Then
                DrawLinesInCell(g, bounds)
            Else
                MyBase.Paint(g, bounds, source, rowNum, e.BackBrush, e.ForeBrush, alignToRight)
            End If
        End If

        'Change the background of the grids to blue to indicate the cell that was
        'clicked in the mousedown event
        If (Me.DataGridTableStyle.DataGrid.CurrentRowIndex = rowNum)_
            And (Me.DataGridTableStyle.DataGrid.CurrentCell.ColumnNumber = _col) And _
            ((rowNum <> 0) And (Me._col <> 0)) Then
            If (cellToDisable = False Or _col <> 1) Then
                e.BackBrush = New SolidBrush(Color.Blue)
                e.ForeBrush = New SolidBrush(Color.White)
                g.FillRectangle(e.BackBrush, bounds)
                'Make the font bigger in the clicked cell
                e.TextFont = New Font("Arial", 24, FontStyle.Bold)
                Dim intX As Integer = bounds.X + (bounds.Width / 3)
                Dim intY As Integer = bounds.Y + (bounds.Height / 4)
                g.DrawString(Me.GetColumnValueAtRow(source, rowNum).ToString, e.TextFont, e.ForeBrush, intX, intY)
                'MyBase.Paint(g, bounds, source, rowNum, e.BackBrush, e.ForeBrush, alignToRight)
            End If
        End If

        'MyBase.Paint(g, bounds, source, rowNum, e.BackBrush, e.ForeBrush, alignToRight)
    Catch ex As Exception
        'Empty catch
    Finally
        'make sure the base class gets called to do the drawing with the possibly
        'changed brushes
        'MyBase.Paint(g, bounds, source, rowNum, e.BackBrush, e.ForeBrush, alignToRight)
    End Try
    'MyBase.Paint(g, bounds, source, rowNum, e.BackBrush, e.ForeBrush, alignToRight)
End Sub
0
Comment
Question by:Sanmarie
3 Comments
 
LVL 2

Assisted Solution

by:cmjwebservices
cmjwebservices earned 200 total points
ID: 16925927
Some example code on how to do this is to create a seperate class like so (that way it doesn't conflict with the Paint event of the same name):

'~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Public Class DataGridColoredTextBoxColumn
    Inherits DataGridTextBoxColumn

    Public Sub New()
    End Sub

    Protected Overloads Overrides Sub Paint(ByVal g As Graphics, ByVal bounds As Rectangle, ByVal source As CurrencyManager, ByVal rowNum As Integer, ByVal backBrush As Brush, ByVal foreBrush As Brush, ByVal alignToRight As Boolean)
'Do stuff here
    End Sub

End Class

'~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

And then use it as follows:

'~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Private Sub DataGridColoredTextBoxColumnImplementation()
        Dim tbColumn As DataGridColoredTextBoxColumn
        tbColumn = New DataGridColoredTextBoxColumn
        tbColumn .HeaderText = "Description"
        'etc, etc
    End Sub

'~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

I was easily able to reference the class by pasting "Public Class DataGridColoredTextBoxColumn" after the "End Class" of the form I was planning to use it in.  Hope it works for you!

Chris
0
 
LVL 96

Accepted Solution

by:
Bob Learned earned 300 total points
ID: 16934884
Here is an example:

Public Class DataGridColorTextBoxColumn
  Inherits DataGridTextBoxColumn

  Protected Overloads Overrides Sub Paint(ByVal g As Graphics, _
   ByVal bounds As Rectangle, ByVal source As CurrencyManager, _
   ByVal rowNum As Integer, ByVal backBrush As Brush, ByVal foreBrush As Brush, ByVal alignToRight As Boolean)

    Try

      Dim columnValue As Double = Me.GetColumnValueAtRow(source, rowNum)

      If columnValue > 20 Then
        foreBrush = New SolidBrush(Color.Red)
      End If

    Catch ex As Exception

      MessageBox.Show(ex.ToString())

    Finally

      MyBase.Paint(g, bounds, source, rowNum, backBrush, foreBrush, alignToRight)

    End Try

  End Sub

End Class

Bob
0
 

Author Comment

by:Sanmarie
ID: 16937360
Sorry for getting back to you guys so late.

cmjwebservices I tried your approach  and I still had some problems.
Bob, I tried your way and everything worked fine but now my font is messed up. I probably deleted something

Thanks for your help.
0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
.NET 2008 VB and C# 6 39
vb.net class 3 22
vb.net cycle through results of a sql query and capture variables 3 18
VB.Net. Reading xml value 6 30
Article by: Kraeven
Introduction Remote Share is a simple remote sharing tool, enabling you to see, add and remove remote or local shares. The application is written in VB.NET targeting the .NET framework 2.0. The source code and the compiled programs have been in…
It was really hard time for me to get the understanding of Delegates in C#. I went through many websites and articles but I found them very clumsy. After going through those sites, I noted down the points in a easy way so here I am sharing that unde…
This video shows how to quickly and easily add an email signature for all users on Exchange 2016. The resulting signature is applied on a server level by Exchange Online. The email signature template has been downloaded from: www.mail-signatures…
In a recent question (https://www.experts-exchange.com/questions/29004105/Run-AutoHotkey-script-directly-from-Notepad.html) here at Experts Exchange, a member asked how to run an AutoHotkey script (.AHK) directly from Notepad++ (aka NPP). This video…

831 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question