DrawTreeNodeExtendedEventArgs Constructor
Constructor
Namespace: EWSoftware.ListControlsAssembly: EWSoftware.ListControls (in EWSoftware.ListControls.dll) Version: 2024.12.18.0+3a863295c73252b22e8ab6862ed6bdc57bcbd0fc
public DrawTreeNodeExtendedEventArgs(
Graphics g,
TreeNode treeNode,
TreeNodeStates nodeState,
Rectangle bounds
)
Public Sub New (
g As Graphics,
treeNode As TreeNode,
nodeState As TreeNodeStates,
bounds As Rectangle
)
public:
DrawTreeNodeExtendedEventArgs(
Graphics^ g,
TreeNode^ treeNode,
TreeNodeStates nodeState,
Rectangle bounds
)
new :
g : Graphics *
treeNode : TreeNode *
nodeState : TreeNodeStates *
bounds : Rectangle -> DrawTreeNodeExtendedEventArgs
Parameters
- g Graphics
- The graphics object to use
- treeNode TreeNode
- The tree node to draw
- nodeState TreeNodeStates
- The current node state
- bounds Rectangle
- The node's bounds
/// <summary>
/// Test TreeNodeDrawing event handler. This occurs before the tree
/// view draws the node.
/// </summary>
/// <param name="sender">The sender of the event</param>
/// <param name="e">The event arguments</param>
private void tvExtTree_TreeNodeDrawing(object sender, DrawTreeNodeExtendedEventArgs e)
{
if(!chkFormDrawNode.Checked)
return;
// Use solid 2px lines
e.LinePen.DashStyle = DashStyle.Solid;
e.LinePen.Width = 2;
// Change the text by adding the node name. Assigning new text
// automatically recalculates the text and focus bounds. We could
// draw the text, but we'll let the base class handle it. Note that
// since the tree view doesn't know about the extra text, it won't
// show the horizontal scrollbar if it goes off the right edge.
e.Text += " (" + e.Node.Name + ")";
// If the item height is larger than 35, wrap the text too
if(tvExtTree.ItemHeight > 35)
{
e.StringFormat.FormatFlags = StringFormatFlags.NoClip;
// Limit the text to the right edge of the node bounds. Note
// that this won't stop the tree view from showing a horizontal
// scrollbar.
e.TextBounds = new Rectangle(e.TextBounds.Left, e.NodeBounds.Top,
e.NodeBounds.Width - e.TextBounds.Left, e.NodeBounds.Height);
}
// NOTE:
// If you choose to draw one or more parts of the node, you should
// draw the background first, then the node parts, and then turn
// off the NodeParts.Background flag along with the other node part
// flags in the e.NodeParts property before returning.
}
/// <summary>
/// Test TreeNodeDrawn event handler. This occurs after the tree view
/// has drawn the node.
/// </summary>
/// <param name="sender">The sender of the event</param>
/// <param name="e">The event arguments</param>
private void tvExtTree_TreeNodeDrawn(object sender, DrawTreeNodeExtendedEventArgs e)
{
Pen pen;
int top;
if(chkFormDrawNode.Checked && e.Node.Level == 0 && e.ImageIndex != -1)
{
// Nothing exciting, we'll just draw a line through
// top level nodes that have an image index set.
if((e.State & TreeNodeStates.Focused) != 0 && tvExtTree.FullRowSelect)
pen = SystemPens.ControlLightLight;
else
pen = SystemPens.ControlDarkDark;
top = e.NodeBounds.Top + (e.NodeBounds.Height / 2);
e.Graphics.DrawLine(pen, e.NodeBounds.Left, top,
e.NodeBounds.Left + e.NodeBounds.Width, top);
}
}
''' <summary>
''' Test TreeNodeDrawing event handler. This occurs before the tree
''' view draws the node.
''' </summary>
''' <param name="sender">The sender of the event</param>
''' <param name="e">The event arguments</param>
Private Sub tvExtTree_TreeNodeDrawing(ByVal sender As System.Object, _
ByVal e As DrawTreeNodeExtendedEventArgs) _
Handles tvExtTree.TreeNodeDrawing
If Not chkFormDrawNode.Checked Then
Return
End If
' Use solid 2px lines
e.LinePen.DashStyle = DashStyle.Solid
e.LinePen.Width = 2
' Change the text by adding the node name. Assigning new text
' automatically recalculates the text and focus bounds. We could
' draw the text, but we'll let the base class handle it. Note that
' since the tree view doesn't know about the extra text, it won't
' show the horizontal scrollbar if it goes off the right edge.
e.Text += " (" & e.Node.Name & ")"
' If the item height is larger than 35, wrap the text too
If tvExtTree.ItemHeight > 35 Then
e.StringFormat.FormatFlags = StringFormatFlags.NoClip
' Limit the text to the right edge of the node bounds. Note
' that this won't stop the tree view from showing a horizontal
' scrollbar.
e.TextBounds = new Rectangle(e.TextBounds.Left, e.NodeBounds.Top,
e.NodeBounds.Width - e.TextBounds.Left, e.NodeBounds.Height)
End If
' NOTE:
' If you choose to draw one or more parts of the node, you should
' draw the background first, then the node parts, and then turn
' off the NodeParts.Background flag along with the other node part
' flags in the e.NodeParts property before returning.
End Sub
''' <summary>
''' Test TreeNodeDrawn event handler. This occurs after the tree view
''' has drawn the node.
''' </summary>
''' <param name="sender">The sender of the event</param>
''' <param name="e">The event arguments</param>
Private Sub tvExtTree_TreeNodeDrawn(ByVal sender As System.Object, _
ByVal e As DrawTreeNodeExtendedEventArgs) _
Handles tvExtTree.TreeNodeDrawn
Dim pen As Pen
Dim top As Integer
If chkFormDrawNode.Checked And e.Node.Level = 0 And e.ImageIndex <> -1 Then
' Nothing exciting, we'll just draw a line through top level nodes
' that have an image index set.
If (e.State And TreeNodeStates.Focused) <> 0 And tvExtTree.FullRowSelect
pen = SystemPens.ControlLightLight
Else
pen = SystemPens.ControlDarkDark
End If
top = CType(e.NodeBounds.Top + (e.NodeBounds.Height / 2), Integer)
e.Graphics.DrawLine(pen, e.NodeBounds.Left, top, _
e.NodeBounds.Left + e.NodeBounds.Width, top)
End If
End Sub