【问题标题】:Preventing users from resizing columns widths in ListView?防止用户在 ListView 中调整列宽?
【发布时间】:2012-07-24 07:01:12
【问题描述】:

我的 Winform 中有一个 ListView,它有 4 列、名称、金钱、ID 和级别。

问题是当我运行我的应用程序时,我仍然可以弄乱列宽 并更改它们。

我搜索并发现我应该这样做:

private void listView1_ColumnWidthChanging(object sender, ColumnWidthChangingEventArgs e)
{
  e.Cancel = true;
  e.NewWidth = listView1.Columns[e.ColumnIndex].Width;
}

但问题是,当我调试和 Ccanged 列宽时,这个事件甚至没有触发!

为什么没有触发?

我怎样才能使列宽固定?

我制作了一个新的 winform 应用程序,以防万一我的旧应用程序出现问题, 它触发了,但只是第一次运行应用程序.. 这是代码:

namespace CsharpWinformTestingStuff
{
  public partial class Form1 : Form
  {
    public Form1()
    {
      InitializeComponent();
      listView1.ColumnWidthChanging += new ColumnWidthChangingEventHandler(listView1_ColumnWidthChanging);
    }

    void listView1_ColumnWidthChanging(object sender, ColumnWidthChangingEventArgs e)
    {

      e.Cancel = true;
      e.NewWidth = listView1.Columns[e.ColumnIndex].Width;
    }
  }
}

这里是初始化组件,以防你想知道:

private void InitializeComponent()
{
  this.listView1 = new System.Windows.Forms.ListView();
  this.columnHeader1 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
  this.columnHeader2 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
  this.columnHeader3 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
  this.SuspendLayout();
  // 
  // listView1
  // 
  this.listView1.Columns.AddRange(new System.Windows.Forms.ColumnHeader[] {
        this.columnHeader1,
        this.columnHeader2,
        this.columnHeader3});
  this.listView1.GridLines = true;
  this.listView1.Location = new System.Drawing.Point(12, 12);
  this.listView1.Name = "listView1";
  this.listView1.Size = new System.Drawing.Size(284, 275);
  this.listView1.TabIndex = 0;
  this.listView1.UseCompatibleStateImageBehavior = false;
  this.listView1.View = System.Windows.Forms.View.Details;
  // 
  // columnHeader1
  // 
  this.columnHeader1.Text = "Name";
  this.columnHeader1.Width = 97;
  // 
  // columnHeader2
  // 
  this.columnHeader2.Text = "Age";
  this.columnHeader2.Width = 52;
  // 
  // columnHeader3
  // 
  this.columnHeader3.Text = "Email";
  this.columnHeader3.Width = 157;
  // 
  // Form1
  // 
  this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
  this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
  this.ClientSize = new System.Drawing.Size(308, 299);
  this.Controls.Add(this.listView1);
  this.Name = "Form1";
  this.Text = "Form1";
  this.ResumeLayout(false);

}

【问题讨论】:

标签: c# winforms listview


【解决方案1】:

您需要在表单中注册 ColumnWidthChanging 事件:

public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();

        // This line registers the event, soc that the form can "hear" it and call the indicated handling code:
        this.listView1.ColumnWidthChanging += new ColumnWidthChangingEventHandler(listView1_ColumnWidthChanging);
    }

    void listView1_ColumnWidthChanging(object sender, ColumnWidthChangingEventArgs e)
    {
        Console.Write("Column Resizing");
        e.NewWidth = this.listView1.Columns[e.ColumnIndex].Width;
        e.Cancel = true;
    }
}

【讨论】:

  • 我的意思是,您的表单代码的其余部分。显然,有一些事情正在阻止事件正常发生。
  • 对于延迟的答案非常抱歉.. 你是对的,我的代码有问题,我做了一个新的 winform 项目,里面只有一个列表视图,只是为了检查事件是否触发,起初,它触发了,但后来它没有..(仅在我第一次运行它触发的程序时)
  • 在设置 e.NewWidth 值后尝试设置 e.Cancel = true
  • @XIVSolutions 这很完美,这就是我想要的。
【解决方案2】:

只需点击属性>>事件>>ColumnWidthChanging

然后添加这段代码:

private void lstItems_ColumnWidthChanging(object sender, ColumnWidthChangingEventArgs e)
    {
        e.Cancel = true;
        e.NewWidth = lstItems.Columns[e.ColumnIndex].Width;
    }

编码愉快! ^_^

【讨论】:

  • 我很惊讶取消不仅会阻止更改 - 你需要第二行吗?
  • 是的先生,通过获取 listView 列的 current 宽度并将其作为 NewWidth 传递,我们总是将宽度设置为当前宽度.顺便说一句,BRIDGE,是我当前程序的应用程序名称... ^_^
  • 别担心它还没有变得有知觉,我是一个人!
【解决方案3】:

您可以查看Better ListView Express。我们在列上实现了 AllowResize 属性,这正是您所需要的。

【讨论】:

    猜你喜欢
    • 2010-09-15
    • 1970-01-01
    • 2016-02-18
    • 2014-06-12
    • 2010-12-04
    • 2011-02-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多