zoukankan      html  css  js  c++  java
  • C# WinForm 扩展指定列宽适应DataGridView显示行数

    C# WinForm DataGridView用于显示组织到的数据,在数据行记录数不足Grid的屏显示行数时,右侧的垂直滚动条此时是无用的,是不需要显示的,特别是对于某些(较真、执着,呵呵)人很是如此。前段时间就又碰到一例,问我有否解决办法,说是每个Grid的各列宽都不同,调试比较麻烦,便弄了下面这些代码来解决这个问题。

    需要注意的是,一般情况下,Grid在设计时,都只会用到:列宽、列头名、数据源属性或列名、可视否等几个基本属性。而DataGridView有个列的MinimumWidth属性用于记录列最小宽度,这个属性在涉及到列宽度变化时是很有用的。在设计Grid时,通常都是已经将Grid显示的宽度等样式已经固定了,而且通常情况下都是不再变化,碰到我们今天要说的这种随数据行总数小于等于或大于Grid可显示行数时需要扩展或收缩列宽时,是需要有个列宽的原始不变值的,这个MinimumWidth就是用于此,而一般情况下,我们都不会在设计Grid时更改这个MinimumWidth。

    故:在Grid初始化后,我们需要先将每列的MinimumWidth记录下此列的原始列宽,用于Grid记录数变化时用比较。然后按指定扩展列号以及垂直滚动条宽度改变该列列宽,以适应总记录数变化与屏显行数,达到美化界面的目的。

    实现步骤及代码:

    1、初始化Grid时,设置各列的MinimumWidth:
    InitGridColumnWidth(dataGridView1);

    private void InitGridColumnWidth(DataGridView dgv)
    {
        foreach (DataGridViewColumn col in dgv.Columns) //设置最小列宽为原列宽
            col.MinimumWidth = col.Width;
    }

    2、扩展Grid指定列的代码:

    /// <summary>
    /// 当记录数小于等于可显示行数时自动扩展Grid指定列宽度
    /// </summary>
    /// <param name="dgv">指定Grid</param>
    /// <param name="nCol">指定列(从1起自然序号)</param>
    private void ExtendGridColumnWidth(DataGridView dgv, int nCol = 0)
    {
        nCol--;
        if (nCol == -1)
            nCol = dgv.ColumnCount - 1;
        int colWidth = dgv.Columns[nCol].MinimumWidth;        //原列宽
        int nVScrollWidth = SystemInformation.VerticalScrollBarWidth;   //垂直滚动条宽度
        dgv.Columns[nCol].Width = dgv.RowCount <= dgv.DisplayedRowCount(false) ? colWidth + nVScrollWidth : colWidth;
    }

    3、何时调用扩展代码段:

    每当重新获取Grid数据后,调用该代码段即可。

    ......
    GetGridData(sql,plist);
    ExtendGridColumnWidth(dataGridView1);    //扩展Grid的最后一列
    //ExtendGridColumnWidth(dataGridView1, 1);     //扩展Grid的第1列
    ......

    至此,强迫症适应完毕!呵呵

  • 相关阅读:
    《程序员修炼之道》阅读笔记2
    《程序员修炼之道》阅读笔记1
    Ubuntu16桥接模式上网并设置静态ip
    读《架构漫谈》有感
    质量属性6个常见属性的场景分析
    sql注水
    python版本切换
    使用vue-cli构建 webpack打包工具时,生产环境下,每次build时,删除dist目录,并重新生成,以防dist目录文件越来越多。
    Java栈与堆
    从一个字符串s的第i个字符(不包括此字符)开始删除n个字符
  • 原文地址:https://www.cnblogs.com/hnllhq/p/12785541.html
Copyright © 2011-2022 走看看