DataGrid控制列宽

 

最近帮朋友写个wince 的程序,要用到DataGrid。wince不能用 datagridview,用datagrid不习惯。数据字段比较长的时候,需要手动拉datagrid,比较麻烦。

网上找来资料,改了改:

ContractedBlock.gif ExpandedBlockStart.gif Code
public  void AutoSizeTable(DataGrid dgData)
ExpandedBlockStart.gifContractedBlock.gif        
{
            
int numCols = dgData.TableStyles[0].GridColumnStyles.Count;
            
for (int i = 0; i < numCols; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                AutoSizeCol(dgData,i);
            }

        }


        
private static void AutoSizeCol(DataGrid dgData, int colIndex)
ExpandedBlockStart.gifContractedBlock.gif        
{
           
            
int rowNums = ((DataTable)dgData.DataSource).Rows.Count;
            Byte[] myByte 
= System.Text.Encoding.Default.GetBytes(dgData.TableStyles["ROW"].GridColumnStyles

[colIndex].HeaderText);
            
int textCount = myByte.Length;
            
int tempCount = 0;
                
            
for (int i = 0; i < rowNums; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
              
                
if (dgData[i, colIndex] != null)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
{
                    myByte 
= System.Text.Encoding.Default.GetBytes(dgData[i, colIndex].ToString().Trim());
                    tempCount 
= myByte.Length;

                    
if (tempCount > textCount)
ExpandedSubBlockStart.gifContractedSubBlock.gif                    
{
                        textCount 
= tempCount;
                    }

                }

            }

            dgData.TableStyles[
0].GridColumnStyles[colIndex].Width = textCount * 7;
          
        }

 

使用时候,报错 什么 索引column不能为负----莫名ing

研究下加入:

 

              // Create a table style that will hold the new column style
            // that we set and also tie it to our customer's table from our DB

      DataGridTableStyle tableStyle = new DataGridTableStyle();

 

            tableStyle.MappingName = "BOX";  

            // make the dataGrid use our new tablestyle and bind it to our table
            dataGrid1.TableStyles.Clear();
            dataGrid1.TableStyles.Add(tableStyle);

 

 

转载于:https://www.cnblogs.com/kakajun/archive/2009/04/10/1433083.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值