Редактируем комбобокс в wpf datagrid

Имам проблем с wpf datagrid combobox. Имам следния код, в който елементите не се попълват в разгъващ се списък, моля, помогнете ми, ако някой е направил това в wpf toolkit datagrid (НЕ в Infragistics), а също така ме уведомете как да направя тази колона от разгъващ се списък като редактируема?

  <DataGrid Name="dataGridResultsAdded" AutoGenerateColumns="False" FontWeight="Normal" IsReadOnly="True" ItemsSource="{Binding UserResults,Mode=Default}" SelectedIndex="{Binding SelectedIndexUserResults}" SelectionMode="Single" Margin="0,0,0,0" Height="178" GridLinesVisibility="None">
                <DataGrid.Columns>
                    <DataGridTextColumn Header="RFC ID" Binding="{Binding RFCID}"></DataGridTextColumn>
                    <DataGridTextColumn Header="RFC Title" Binding="{Binding RFCTitle}"></DataGridTextColumn>
                    <DataGridTextColumn Header="RFC Revision" Binding="{Binding RFCRevision}"></DataGridTextColumn>
                    <DataGridTextColumn Header="Trigger Association" Binding="{Binding TriggerAssociation}"></DataGridTextColumn>
                    <DataGridTemplateColumn Header="OrderStatus1" IsReadOnly="False">
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <TextBlock Text="{Binding Status, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"></TextBlock>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>

                        <DataGridTemplateColumn.CellEditingTemplate>
                            <DataTemplate>
                                <ComboBox IsEditable="True" ItemsSource="{Binding Path=DataContext.OrderStatus,
                                        RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type UserControl}}}"                                           SelectedItem="{Binding Path=Status, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellEditingTemplate>
                    </DataGridTemplateColumn>
                    <DataGridComboBoxColumn IsReadOnly="False" Header="OrderStatus"  SelectedItemBinding="{Binding Status,Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" ItemsSource="{Binding OrderStatus, Mode=TwoWay}" />
                    <DataGridTextColumn Header="Status" Binding="{Binding TriggerStatus}"></DataGridTextColumn>
                </DataGrid.Columns>
            </DataGrid>

private List orderStatus = default(List);

    public List<string> OrderStatus
    {
        get
        {
            if (orderStatus == null)
            {
                orderStatus = new List<string>();
                orderStatus.Add("None");
                orderStatus.Add("New");
                orderStatus.Add("Processing");
                orderStatus.Add("Shipped");
            }
            return orderStatus;
        }
        set
        {
            orderStatus = value;
            NotifyPropertyChanged("OrderStatus");
        }
    }

` public DataTable dtUserResults = default(DataTable);

    public DataTable UserResults
    {
        get
        {
            return dtUserResults;
        }
        set
        {
            dtUserResults = value;
            NotifyPropertyChanged("UserResults");
        }
    }

`Вижте кода на модела по-долу

    public void AddExecute()
    {
        InfoHandler.LogInfo("Entering AddExecute");
        try
        {
            DataTable dtUserRes = new DataTable();
            DataColumn dColumn = default(DataColumn);
            DataRow dRow = default(DataRow);

            DataRow dRowSelected = dtSearchResults.NewRow();
            dRowSelected = dtSearchResults.Rows[intSelectedIndexSearchRes];

            if (dtSearchResults.Rows.Count > 0 && IsRFCAlreadyAdded(dRowSelected))
            {
                dColumn = new DataColumn("RFCID", Type.GetType("System.String"));   
                dtUserRes.Columns.Add(dColumn);

                dColumn = new DataColumn("RFCTitle", Type.GetType("System.String"));
                dtUserRes.Columns.Add(dColumn);

                dColumn = new DataColumn("RFCRevision", Type.GetType("System.String"));
                dtUserRes.Columns.Add(dColumn);

                dColumn = new DataColumn("TriggerAssociation", Type.GetType("System.String"));
                dtUserRes.Columns.Add(dColumn);

                dColumn = new DataColumn("TriggerStatus", Type.GetType("System.String"));
                dtUserRes.Columns.Add(dColumn);

                //setting RFCID as primary key for the datatable UserResults
                dtUserRes.PrimaryKey = new DataColumn[] { dtUserRes.Columns[0] };

                dRow = dtUserRes.NewRow();
                dRow["RFCID"] = dRowSelected["RFCID"];
                dRow["RFCTitle"] = dRowSelected["RFCTitle"];
                dRow["RFCRevision"] = dRowSelected["RFCRevision"];
                dRow["TriggerAssociation"] = "Manual";
                dRow["TriggerStatus"] = "N";
                dtUserRes.Rows.Add(dRow);

                if (UserResults == null)
                {
                    UserResults = new DataTable();
                }
                UserResults.Merge(dtUserRes, true);

            }
        }
        catch (Exception objEx)
        {
            ErrorHandler.ShowErrorMessage(strErrorCaption, "Error occured while Adding RFC from Search results to Execution List", objEx.Message);
        }
        InfoHandler.LogInfo("Exiting AddExecute");
    }

`

Благодаря NallsKarthi


person nallskarthi    schedule 27.04.2011    source източник
comment
Бихте ли добавили някакъв код на вашия изгледмодел, като например: какво е ItemsSource?   -  person Damascus    schedule 27.04.2011


Отговори (1)


Нормално е, не искате ComboBox да бъде попълнено с много стойности.

Доколкото разбирам правилно проблема ви, имате

<ComboBox ItemsSource="{Binding Path=OrderStatus, Mode=TwoWay}" SelectedItem="{Binding Path=Status, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" />

Какъв е типът на обекта OrderStatus? И освен това, къде се намира OrderStatus?

Бих казал като предложение:

<ComboBox ItemsSource="{Binding Path=DataContext.OrderStatus,
  RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type UserControl}}}" 
  SelectedItem="{Binding Path=Status, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" />

(ако сте в прозорец, променете AncestorType на Window)

За да съм сигурен, ще ми трябва повече код тук, особено: декларацията на вашия ItemsSource и декларацията на OrderStatus

person Damascus    schedule 27.04.2011
comment
OrderStatus е List‹string› това правилно ли е? Той е във Viewmodel. - person nallskarthi; 27.04.2011
comment
Добре, разбрах. Проблемът тук е, че трябва да знаете, че когато приложите Binding в колона DataGrid, действителното DataContext е ItemSource на DataGrid. Така че няма да намери вашия списък OrderStatus, защото се намира във вашия ViewModel. За достъп до него използвайте предложението, което ви дадох: добавяне на RelativeSource, което ще търси родителския DataContext на DataGrid и ще намери по подходящ начин правилния списък :) - person Damascus; 27.04.2011
comment
@damascus: Все още не работи, промених всичко, което споменахте по-горе :( Използвах и Относителен източник, но все още списъкът не се попълва. Правилният начин ли е да използвам list‹string› или друг тип, който трябва да използвам? - person nallskarthi; 27.04.2011
comment
Къде точно се намира вашият DataGrid? в UserControl или Window ? - person Damascus; 27.04.2011
comment
Освен това можете ли да проверите какво се показва в изходния прозорец на Visual Studio? Трябва да ви даде обвързваща грешка, ако не намери списъка - person Damascus; 27.04.2011
comment
Не, той също не извежда никаква грешка и **get { } ** getter дори не се извиква в свойството OrderStatus - person nallskarthi; 27.04.2011
comment
@damascus: работи :) добре, благодаря :) проблемът е, че направих Datagrid като non editable, зададох свойството IsReadonly=True, така че сега промених на false< /b> работи страхотно благодаря :) - person nallskarthi; 27.04.2011