0

我在创建列表视图时遇到问题。我也是 C# 和 wpf 的新手。我尝试了不同的填充 ListView 项目的方法,但我无法解决它,因为输入数组是 NxN 维度。我在 Bindig 上找到了说明,但我无法应用它们,因为我无法创建该类型的对象,因为输入数组是动态的。我可以填充标题列,但不能用值填充行和列。此代码有效,但所有值都在一列中。

public void PrintListView(ResultsTable results)
    {
        System.Windows.Controls.GridView gv = new System.Windows.Controls.GridView();
        gv.AllowsColumnReorder = true;

        int j=0;
        foreach (DataColumn dc in results.Columns)
        {
            GridViewColumn gvCol = new GridViewColumn(); 
            gvCol.Header = results.Columns[j].ColumnName;
            gvCol.Width = 200;             
            gv.Columns.Add(gvCol); 
            j++;           
        }
        lbVysledky.View = gv;

        foreach (DataRow dr in results.Rows)
        {
            string[] array1 = new string[1000];
           // List<string> zoznam = new List<string>();
         //   ObservableCollection<string> kolekcia = new ObservableCollection<string>();
            int i = 0;
            foreach (DataColumn dc in results.Columns)
            {         
                array1[i] = dr[dc].ToString();
           //     zoznam.Add (dr[dc].ToString());
           //     kolekcia.Add(dr[dc].ToString());                 
                i++;
            }
           this.lbVysledky.Items.Add(new ListViewItem { Content = pole[0] + pole[1]});                 
        }                
    }

有人能帮我吗?谢谢

4

1 回答 1

0

看起来您正试图ListView通过一次添加行和列来填充。这不是填充ListView. 相反,您添加ItemsSource(在这种情况下,您的结果对象)并告诉每列的内容是ListView什么DisplayMemberBinding,它将在每列的每一行中显示正确的值。

这可能只是意味着修改你的循环,在其中将列添加到ListView如下所示:

foreach (DataColumn dc in results.Columns)
{
    GridViewColumn gvCol = new GridViewColumn(); 
    gvCol.DisplayMemberBinding = new Binding(dc.ColumnName);        
    gvCol.Header = results.Columns[j].ColumnName;
    gvCol.Width = 200;     
    gv.Columns.Add(gvCol); 
    j++;           
}
lbVysledky.View = gv;

然后只需将 的 设置ItemsSourceListView您的结果对象,如下所示:

lbVysledky.ItemsSource = results;

另外,作为旁注,您似乎没有foreach正确使用该构造。您正在枚举每一列,但您保留自己的计数器并像这样访问该列:

gvCol.Header = results.Columns[j].ColumnName;

在一个foreach循环中,您已经使用 dc 变量枚举列,因此您可以像这样访问该列:

gvCol.Header = dc.ColumnName;

并且您不需要手动计算列数(使用 j)。

于 2013-05-07T14:48:27.480 回答