WPF-自定义瀑布流面板

效果

在这里插入图片描述子控件的宽度全部一样,新增的子控件会追加到当前最矮的列最下方。

源码

WaterfallPanel.cs

using System.Linq;
using System.Windows;
using System.Windows.Controls;

namespace WeChatInteract.CustomControls
{
   
    /// <summary>
    /// 瀑布流布局,等列宽
    /// </summary>
    public class WaterfallPanel : Panel
    {
   
        public WaterfallPanel()
        {
   
        }

        /// <summary>
        /// 列数
        /// </summary>
        public int ColumnCount
        {
   
            get {
    return (int)this.GetValue(ColumnCountProperty); }
            set {
    this.SetValue(ColumnCountProperty, value); }
        }

        public static readonly DependencyProperty ColumnCountProperty = DependencyProperty.Register("ColumnCount", typeof(int), typeof(WaterfallPanel), new PropertyMetadata(PropertyChanged));

        public static void PropertyChanged(DependencyObject sender, DependencyPropertyChangedEventArgs e)
        {
   
            if (sender == null || e.NewValue == e.OldValue)
                return;
            sender.SetValue(ColumnCountProperty, e.NewValue);

        }

        protected override Size MeasureOverride(Size availableSize)
        {
   
            if (Children.Count <= 0)
                return new Size(0,0);
            
            #region 测量值
            //Canvase、ScrollView等会给出无穷宽高
            Size childrenAvailableSize = new Size(double.IsPositiveInfinity(availableSize.Width) ? double.PositiveInfinity : availableSize.Width / ColumnCount, double.PositiveInfinity);
            Size[] childrenDesiredSizes = new Size[Children.Count];

            double[] columnH = new double[ColumnCount];
            double[] columnW = new double[ColumnCount];//列最宽元素的宽度
            for (int i = 0; i < ColumnCount; i++)
            {
   
                columnW[i] = 0;
                columnH[i] = 0;
            }
            for (int i = 0; i < Children.Count; i++)
     
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值