Spread for WinForms:根据 Spread 尺寸自适应行高列宽

发布时间:2014/11/14 00:11 发布者:iceman

返回博客中心

Spread COM 的 AutoSize 属性用于设置行列充满Spread的表格控件。Spread WinForms版本中没有相应的接口,但是我们可以通过自定义方法来实现这个功能,本篇文章中将阐述如何实现这个功能。

 

SpreadGrayArea

 

我们需要做的就是按照元素分割 Spread 表格控件,去除固定部分如滚动条、行列头,剩余部分平均分配给行列。

  • 计算行列头以及滚动条尺寸
  • 平均分配给 Spread 行列

代码如下:

int spreadW = this.fpSpread1.Width;
            int spreadH = this.fpSpread1.Height;
 
            //垂直滚动条宽度
            int vScrollBar = SystemInformation.VerticalScrollBarWidth;
            //水平滚动条高度
            int hScrollBar = SystemInformation.HorizontalScrollBarHeight;
 
            //列头高度
            float columnHeaderH = 0;
            for (int i = 0; i < this.fpSpread1.ActiveSheet.ColumnHeader.RowCount; i++)
            {
                columnHeaderH += this.fpSpread1.ActiveSheet.ColumnHeader.Rows[i].Height+1;
            }
 
            //行头宽度
            float rowHeaderW = 0;
            for (int i = 0; i < this.fpSpread1.ActiveSheet.RowHeader.ColumnCount; i++)
            {
                rowHeaderW += this.fpSpread1.ActiveSheet.RowHeader.Columns[i].Width+1;
            }
 
            //剩余宽度和高度
            int leftWidth = spreadW - vScrollBar - Convert.ToInt32(rowHeaderW);
            int leftHeight = spreadH - hScrollBar - Convert.ToInt32(columnHeaderH);
 
            //计算并设置平均列宽
            int averageColWidth = leftWidth / this.fpSpread1.ActiveSheet.ColumnCount;
            for (int i = 0; i < this.fpSpread1.ActiveSheet.ColumnCount; i++)
            {
                this.fpSpread1.ActiveSheet.Columns[i].Width = averageColWidth;
            }
 
            //计算并设置平均行高
            int averageRowHeight = leftHeight/ this.fpSpread1.ActiveSheet.RowCount;
            for (int i = 0; i < this.fpSpread1.ActiveSheet.RowCount; i++)
            {
                this.fpSpread1.ActiveSheet.Rows[i].Height = averageRowHeight;
            }

 

Demo1 

Demo 下载:

VS2013 + C# + .NET 4.0


关于葡萄城

赋能开发者!葡萄城是专业的集开发工具、商业智能解决方案、低代码开发平台于一身的软件和服务提供商,为超过 75% 的全球财富 500 强企业提供服务。葡萄城专注控件软件领域30年,希望通过模块化的开发控件、灵活的低代码应用开发平台等一系列开发工具、解决方案和服务,帮助开发者快速响应复杂多变的业务需求,最大程度地发挥开发者的才智和潜能,让开发者的 IT 人生更从容更美好。

了解详情,请访问葡萄城官网