根据滚动条的位置动态增加行列数

本文主要通过代码介绍如何根据滚动条的位置动态增加行列数

发布于 2012/11/13 00:00

Spread中默认会显示没有数据的行和列,不过有时候我们只希望显示有数据的最大区域,这时候我们通过以下代码来实现:

 
fpSpread1.ActiveSheet.RowCount = fpSpread1.ActiveSheet.NonEmptyRowCount;

    fpSpread1.ActiveSheet.ColumnCount = fpSpread1.ActiveSheet.NonEmptyColumnCount;

复制代码

然而,有时候我们不仅需要只显示有数据的区域,我们还希望【当滚动条滚动到最大显示范围时,能够动态增加行/列数】,比如:当前SheetView的 RowCount = 50;ColumnCount=20;,当滚动横向滚动条至最右边时,已经显示第20列,此时我再滚动横向滚动条,我希望能够增加一列。

这时候我们可以通过Spread滚动条的事件来实现这一需求:

  1.        
    private void Form1_Load(object sender, EventArgs e)
    
            {
    
    
    
                fpSpread1.ActiveSheet.RowCount = 50;
    
                fpSpread1.ActiveSheet.ColumnCount = 20;
    
    
    
                //fpSpread1.ActiveSheet.RowCount = fpSpread1.ActiveSheet.NonEmptyRowCount;
    
                //fpSpread1.ActiveSheet.ColumnCount = fpSpread1.ActiveSheet.NonEmptyColumnCount;
    
    
    
    
    
                fpSpread1.HorizontalScrollBar.ButtonClick += new FarPoint.Win.Spread.FpScrollBarButtonClickEventHandler(HorizontalScrollBar_ButtonClick);
    
                fpSpread1.VerticalScrollBar.ButtonClick += new FarPoint.Win.Spread.FpScrollBarButtonClickEventHandler(VerticalScrollBar_ButtonClick);
    
            }
    
    
    
            void VerticalScrollBar_ButtonClick(object sender, FarPoint.Win.Spread.FpScrollBarButtonClickEventArgs e)
    
            {
    
                if (fpSpread1.GetViewportBottomRow(0) == fpSpread1.ActiveSheet.RowCount)
    
                {
    
                    if (e.Button.ChangeType == FarPoint.Win.Spread.ChangeType.SmallChange)
    
                    {
    
                        fpSpread1.ActiveSheet.RowCount += 1;
    
                    }
    
                }
    
            }
    
    
    
            void HorizontalScrollBar_ButtonClick(object sender, FarPoint.Win.Spread.FpScrollBarButtonClickEventArgs e)
    
            {
    
                if (fpSpread1.GetViewportRightColumn(0) == fpSpread1.ActiveSheet.ColumnCount)
    
                {
    
                    if (e.Button.ChangeType == FarPoint.Win.Spread.ChangeType.SmallChange)
    
                    {
    
                        fpSpread1.ActiveSheet.ColumnCount += 1;
    
                    }
    
                }            
    
            }
    
    复制代码
    Vs2010 + Spread .NET 6.0.3505 + C#

关于葡萄城

葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的用户社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。

推荐相关案例
推荐相关资源
关注微信
葡萄城社区二维码

关注“葡萄城社区”

活字格低代码二维码

关注“活字格低代码”

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态