!48 修复UITreeView横向滚动条滚动无效的问题

Merge pull request !48 from dazuo0312/master
This commit is contained in:
Sunny 2021-10-08 02:10:12 +00:00 committed by Gitee
commit 904aa0bb9e

View File

@ -740,9 +740,9 @@ namespace Sunny.UI
}
else
{
var drawLeft = (e.Node.Level + 1) * Indent + 3;
var checkBoxLeft = (e.Node.Level + 1) * Indent + 1;
var drawOffsetX = e.Node.Bounds.X-57-e.Node.Level * Indent;
var drawLeft = (e.Node.Level + 1) * Indent + 3+ drawOffsetX;
var checkBoxLeft = (e.Node.Level + 1) * Indent + 1+ drawOffsetX;
var imageLeft = drawLeft;
var haveImage = false;
var sf = e.Graphics.MeasureString(e.Node.Text, Font);
@ -801,9 +801,7 @@ namespace Sunny.UI
}
if (CheckBoxes)
{
{
if (!e.Node.Checked)
{
e.Graphics.DrawRectangle(checkboxColor,
@ -840,7 +838,7 @@ namespace Sunny.UI
}
var lineY = e.Bounds.Y + e.Node.Bounds.Height / 2 - 1;
var lineX = 3 + e.Node.Level * Indent + 9;
var lineX = 3 + e.Node.Level * Indent + 9+drawOffsetX ;
if (ShowLinesEx)
{
@ -894,7 +892,7 @@ namespace Sunny.UI
}
}
lineX = 3 + e.Node.Level * Indent + 9;
lineX = 3 + e.Node.Level * Indent + 9 + drawOffsetX;
//绘制左侧+号
if (ShowPlusMinus && e.Node.Nodes.Count > 0)
{
@ -933,8 +931,7 @@ namespace Sunny.UI
private Dictionary<int, bool> DicNodeStatus = new Dictionary<int, bool>();
protected override void OnAfterCheck(TreeViewEventArgs e)
{
{
base.OnAfterCheck(e);
if (e.Action == TreeViewAction.ByMouse) //鼠标点击
{
@ -956,9 +953,12 @@ namespace Sunny.UI
TreeNode parentNode = currNode.Parent; //获得当前节点的父节点
var count = parentNode.Nodes.Cast<TreeNode>().Where(n => n.Checked).ToList().Count;
parentNode.Checked = count == parentNode.Nodes.Count;
//判断节点Checked是否改变只有改变时才赋值否则不变更以防止频繁触发OnAfterCheck事件
bool bChecked = count == parentNode.Nodes.Count;
if(parentNode.Checked != bChecked)
{
parentNode.Checked = bChecked;
}
var half = parentNode.Nodes.Cast<TreeNode>().Where(n => (DicNodeStatus.ContainsKey(n.GetHashCode()) ? DicNodeStatus[n.GetHashCode()] : false)).ToList().Count;
if ((count > 0 && count < parentNode.Nodes.Count) || half > 0)