zoukankan      html  css  js  c++  java
  • datagrid column width in silverlight.

    The possible values for DataGridLenth are:

    • Auto: This auto-sizes the column or row to grow to the size of the largest header or cell.  It is effectively a combination of the other two auto-size modes.  You might notice as you scroll when a new larger cell is encountered that this value increases.  It will however not decrease once that item is scrolled out of view.
    • SizeToHeader: This auto-sizes the column or row the grow to the size of the header.  This will ignore the contents of the cells when determining its size and will not change unless the size of the header changes.
    • SizeToCells: This auto-sizes the column or row to grow to the size of the largest visible cell.  It will ignore the header cell in this calculation.  You might notice as you scroll when a new larger cell is encountered that this value increases.  It will however not decrease once that item is scrolled out of view.
    • Numeric: Unlike the others this is not an enum value, but rather simply a numeric value such as 100.  This mode will behave the same way that Beta 1 did, however setting it in code behind is slightly different.

    ===============================

    private void setColumnWidth()
            {
                double steadyWidth = 470;
                double variableWidth = dgView.Width - steadyWidth;

                if (dgView.Columns.Count >= 11)
                {
                    int[] adjustColumnIndex = new int[] { 0, 6, 7, 8 };
                    double[] ratio = new double[4] { 0.14742, 0.61503, 0.08983, 0.10596 };
                    for (int i = 0; i < adjustColumnIndex.Length; i++)
                    {
                        dgView.Columns[adjustColumnIndex[i]].Width = new DataGridLength(ratio[i] * variableWidth);
                    }
                }
            }

    ===================

            private void adjustColumnWidth()
            {
                double totalActualWidth = 0;
                foreach(var column in dgView.Columns)
                {
                    if (column.Header != null && column.Header.ToString().ToLower().Trim() == "reg. no.")
                    {
                        column.Width = new DataGridLength(70);
                      
                        column.Width = DataGridLength.SizeToCells;

                        dgView.UpdateLayout();
                     
                    }
                    else if (column.Header != null && column.Header.ToString().ToLower().Trim() == "location")
                    {
                        column.Width = new DataGridLength(70);

                        column.Width = DataGridLength.SizeToCells;

                        dgView.UpdateLayout();

                    }
                    totalActualWidth += column.ActualWidth;
                }
                double difWidth = dgView.Width - totalActualWidth - 20;
                foreach (var column in dgView.Columns)
                {
                    if (column.Header !=null && column.Header.ToString().ToLower().Trim() == "location" && column.ActualWidth >= -difWidth)
                    {
                        column.Width  = new DataGridLength(column.ActualWidth + difWidth);
                        //column.Width = DataGridLength.SizeToCells;
                        break;
        }
                }

                //auto height the height row.
                dgView.RowHeight = 10;
                Dispatcher.BeginInvoke(delegate
                {
                    dgView.RowHeight = double.NaN;
                });

            }

  • 相关阅读:
    Solution -「洛谷 P5659」「CSP-S 2019」树上的数
    前端随心记---------接私活必备的 10 个开源项目!
    前端随心记---------Vue3.0马上就要来了,TypeScript学会了没?
    前端随心记---------vue3.0终于来了,作者已公布源码
    前端随心记---------vuex
    前端随心记---------为什么要使用Nodejs
    前端随心记---------Javascript系列(第三节.函数的变量提升)
    前端随心记---------Javascript系列(第二节----函数.事件处理程序)
    前端随心记---------Javascript系列(判断一个数是否为素数的三种解法)
    前端随心记---------Javascript系列(第一节)
  • 原文地址:https://www.cnblogs.com/visi/p/1886640.html
Copyright © 2011-2022 走看看