繁体   English   中英

如何针对这些要求制作类似于自定义控件的网格

[英]How to make a Grid like custom control for these requirements

我需要具有以下功能的控件:

  1. 应该可以在xaml中使用它进行设计。
  2. 它应该能够容纳单个类型的多个子元素。 例如说Button
  3. 这些子元素将具有固定的尺寸。 控件必须弄清楚可以完全垂直和水平显示的最大子级数量(不能部分显示任何子级)。 并且仅显示那些孩子,但保留不可见的孩子供以后使用。 -我认为我可以通过Grid完成此要求。
  4. 应该可以为这些子元素设置动画-我想这不是问题。

我试图编写一个自定义控件来执行此操作。 我从Grid继承而来,看到Grid实现了IAddChild我认为如果我覆盖AddChild就可以捕获正在添加的元素。 但是现在我发现Grid也没有针对AddChild实现! 所以看来我不能那样做。 我应该从哪里开始?

编辑:由于艾伦的指针,我得到了它的工作...

public class AutoLayoutingPanel : Panel
{
    protected override Size MeasureOverride(Size availableSize)
    {
        Size size = new Size();
        size.Height = double.MaxValue;
        size.Width = double.MaxValue;

        foreach (UIElement child in Children)
        {
            child.Measure(size);
            size.Height += child.DesiredSize.Height;
            size.Width += child.DesiredSize.Width;
        }

        return availableSize;
    }

    protected override Size ArrangeOverride(Size finalSize)
    {
        ArrangeGrid(finalSize);
        return finalSize;
    }

    private void ArrangeGrid(Size finalSize)
    {
        foreach (UIElement child in Children)
        {
            child.Visibility = Visibility.Hidden;
        }

        Size maxCellSize = new Size();

        foreach (UIElement child in Children)
        {
            maxCellSize.Height = Math.Max(child.DesiredSize.Height, maxCellSize.Height);
            maxCellSize.Width = Math.Max(child.DesiredSize.Width, maxCellSize.Width);
        }

        int rowCount = (int)Math.Floor(finalSize.Height / maxCellSize.Height);
        int colCount = (int)Math.Floor(finalSize.Width / maxCellSize.Width);

        int row = 0, col = 0;
        foreach (UIElement child in Children)
        {
            if (row < rowCount && col < colCount)
            {
                Rect pos = new Rect(col * maxCellSize.Width, row * maxCellSize.Height, maxCellSize.Width, maxCellSize.Height);
                child.Visibility = System.Windows.Visibility.Visible;
                child.Arrange(pos);
            }
            else
            {
                break;
            }

            if (++row >= rowCount)
            {
                row = 0;
                ++col;
            }
        }
    }
}

我认为您需要创建一个自定义布局面板,而不是尝试从Grid继承(就IAddChild接口而言,它是使用EIMI实现的,因此从外部看不到或无法覆盖)。 是一个很好的起点。

(此外,您还需要考虑如何限制控件可以容纳的子控件的类型。可以选择使用泛型,但我对XAML泛型支持感到怀疑。)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM