简体   繁体   English

Comobox 和 TextBox 在 ListView 中无法正确显示 WPF C#

[英]Comobox and TextBox not displaying properly in ListView WPF C#

The goal is to add a combobox and textbox to a listview so the user can select from or enter into each control.目标是将 combobox 和文本框添加到列表视图,以便用户可以 select 从或进入每个控件。 It doesn't show the control instead it displays a property of the control (for ComboBox it's the items.Count and for TextBox it's.Text) instead of the actual control.它不显示控件,而是显示控件的属性(对于 ComboBox,它是 items.Count,对于 TextBox,它是.Text)而不是实际控件。 I have looked at other examples online and I'm not sure what I'm doing wrong.我在网上查看了其他示例,但我不确定我做错了什么。

XAML: XAML:

<Window x:Class="CompoundListView.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:CompoundListView"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800" Loaded="Window_Loaded">
    <Grid>
        <ListView x:Name="Lstv_UserControls" Margin="0,0,0,0">
            <ListView.View>
                <GridView AllowsColumnReorder="True">
                    
                    <GridViewColumn Header="Index" Width="Auto" DisplayMemberBinding="{Binding Path=ItemIndex}" />
                    <GridViewColumn Header="Type" Width="Auto"  DisplayMemberBinding="{Binding Path=cmb_Type}" />
                    <GridViewColumn Header="Name" Width="Auto" DisplayMemberBinding="{Binding Path=txt_Name}" />
                </GridView>
            </ListView.View>
        </ListView>

    </Grid>
</Window>

C#: C#:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace CompoundListView
{
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();

        }

        private void Window_Loaded(object sender, RoutedEventArgs e)
        {

            ComboBox Cmb = new ComboBox();
            Cmb.Items.Add("Button");
            Cmb.Items.Add("TextBox");
            Cmb.Items.Add("Label");
            Cmb.Items.Add("CheckBox");
            Cmb.HorizontalAlignment = HorizontalAlignment.Stretch;

            TextBox txt = new TextBox();
            txt.Text = "Name";
            txt.HorizontalAlignment = HorizontalAlignment.Stretch;
            Lstv_UserControls.Items.Clear();// Clear the list view 

            for (int i = 0; i < 10; i++)
            {
                ListViewUserControl ListItem = new ListViewUserControl
                {
                    ItemIndex = i.ToString(),
                    cmb_Type = Cmb,
                    txt_Name = txt,
                };
                Lstv_UserControls.Items.Add(ListItem);
            }
        }
    }
}
public class ListViewUserControl
{
    public TextBox txt_Name { get; set; }
    public ComboBox cmb_Type { get; set; }
    public string ItemIndex { get; set; }
}

Thanks to the comments I think I figured it out.感谢评论,我想我明白了。 There were a couple things wrong:有几件事是错误的:

  • Add a <DataTemplate> to each of the listview items.<DataTemplate>添加到每个列表视图项。 One for the ComboBox and one for the TextBox一个用于 ComboBox,一个用于 TextBox
  • Corrected Binding for ComboBox ItemsSource="{Binding Path=cmb_Type.Items}"更正了 ComboBox ItemsSource="{Binding Path=cmb_Type.Items}"的绑定
  • Corrected Binding for TextBox Text="{Binding Path=txt_Name.Text}"更正了 TextBox Text="{Binding Path=txt_Name.Text}"的绑定

在此处输入图像描述

XAML: XAML:

<ListView x:Name="Lstv_UserControls" Margin="0,0,0,0">
    <ListView.View>
        <GridView AllowsColumnReorder="True">
            <GridViewColumn Header="Index" Width="Auto" DisplayMemberBinding="{Binding ItemIndex}" />

            <GridViewColumn x:Name="gridC_Type" Header="Type" Width="200">
                <GridViewColumn.CellTemplate >
                    <DataTemplate>
                        <ComboBox Margin="0,0,0,0" Width="{Binding Width, ElementName=gridC_Type,Converter={StaticResource PercentageConverter}}" ItemsSource="{Binding Path=cmb_Type.Items}" SelectedItem="{Binding Path=cmb_Type.SelectedItem}"  Height="Auto" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Foreground="Black"/>
                    </DataTemplate>
                </GridViewColumn.CellTemplate>
            </GridViewColumn>

            <GridViewColumn x:Name="gridC_Name" Header="Name" Width="200">
                <GridViewColumn.CellTemplate>
                    <DataTemplate>
                        <TextBox Text="{Binding Path=txt_Name.Text}" Width="{Binding Width, ElementName=gridC_Name,Converter={StaticResource PercentageConverter}}" Height="Auto" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/>
                    </DataTemplate>
                </GridViewColumn.CellTemplate>
            </GridViewColumn>
        </GridView>
    </ListView.View>
</ListView>

Helpful resource: https://www.codeproject.com/Questions/5246161/Wpf-binding-combobox-in-a-listview有用的资源: https://www.codeproject.com/Questions/5246161/Wpf-binding-combobox-in-a-listview

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM