我有一个从Oracle Query创建的数据集。 我从函数中获取数据表并将其添加到数据集中。
现在我尝试将树视图绑定到ds。 我的代码背后:
private void init_TreeView()
{
//TreeViewItem parent = PM_TreeView.Items.Add("Requirements");
DataTable dt = DataBases.RunQuery();
dt.TableName = "REQ";
DataSet ds = new DataSet();
ds.Tables.Add(dt);
//ds.Relations.Add("rsParentChild", ds.Tables["REQ"].Columns["RQ_REQ_ID"], ds.Tables["REQ"].Columns["RQ_FATHER_ID"]);
var dataSet = ds;
_rootNodes = dataSet.Tables["REQ"].DefaultView;
_rootNodes.RowFilter = "RQ_FATHER_ID = -1";
this.DataContext = this;
}
和
private DataView _rootNodes;
和
public DataView RootNodes
{
get { return _rootNodes; }
}
和我的XAML:
<TreeView x:Name="PM_TreeView" ItemsSource="{Binding RootNodes}" HorizontalAlignment="Left" Height="445" Margin="44.847,68.285,0,0" VerticalAlignment="Top" Width="320" Foreground="{x:Null}" BorderBrush="{x:Null}" Background="#FFBBB6B6" FontFamily="Segoe UI" FontSize="13.333">
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemsSource="{Binding rsParentChild}">
<TextBlock Text="{Binding NodeDescription}" />
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
我的数据表是:
RQ_REQ_ID RQ_FATHER_ID RQ_REQ_NAME
0 -1 REQ
1 0 QC11
但我对树视图一无所知:)
提前10倍。答案 0 :(得分:1)
我尝试了以下内容:
<TreeView Name="tv" ItemsSource="{Binding Root}">
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemsSource="{Binding Parents}">
<TextBlock Text="{Binding Value}"/>
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
在我的窗口中我有:
DataSet ds = new DataSet("Data");
DataTable t = new DataTable("Table");
t.PrimaryKey = new DataColumn[] { t.Columns.Add("Key", typeof(int)) };
t.Columns.Add("Value", typeof(string));
t.Columns.Add("Father", typeof(int));
ds.Tables.Add(t);
ds.Relations.Add("Parents", t.Columns["Key"], t.Columns["Father"], false);
t.Rows.Add(1, "First", -1);
t.Rows.Add(2, "Second", -1);
t.Rows.Add(3, "Third", 2);
Root = new DataView(t);
Root.RowFilter = "[Father]<0";
t.DefaultView.RowFilter = "[Father] < 0";
tv.DataContext = this;
其中Root
被声明为:
public DataView Root { get; private set; }
结果与预期一致。