如何填充GridView异步

时间:2016-08-02 17:08:47

标签: c# wpf entity-framework gridview mvvm

我有一个Gridview,其中的列是Combobox,Checkbox等控件。 GridView使用Entity Framework绑定到数据库的对象列表,绑定使用MVVM模式。 有时,查询只带来很少的元素,因此,Gridview上的负载很快,但有时查询带来的记录超过500条,负载变得非常非常慢。 是否有任何方法可以按记录加载Gridview记录?

这是我的Gridview代码:

<telerik:RadGridView x:Name="dtgResumen" AutoGenerateColumns="False" CellEditEnded="dtgResumen_CellEditEnded" GridLinesVisibility="Both" ItemsSource="{Binding LstAvancesCuvs, Mode=TwoWay, IsAsync=True}" RowIndicatorVisibility="Collapsed" SelectionMode="Multiple" SelectionUnit="FullRow">
  <telerik:RadGridView.Columns>

    <telerik:GridViewComboBoxColumn x:Name="colEstatus" Width="1.4*" Header="ESTATUS" IsFilterable="False" Tag="0">
        <telerik:GridViewComboBoxColumn.CellTemplate>
            <DataTemplate>
                <telerik:RadComboBox HorizontalAlignment="Stretch" VerticalAlignment="Stretch" SelectedIndex="{Binding EstatusCUV, Mode=TwoWay}" SelectionChanged="comboBox_SelectionChanged">
                    <telerik:RadComboBoxItem Content="Cancelada" Foreground="Red" />
                    <telerik:RadComboBoxItem Content="Activa" Foreground="Green" />
                </telerik:RadComboBox>
            </DataTemplate>
        </telerik:GridViewComboBoxColumn.CellTemplate>
    </telerik:GridViewComboBoxColumn>

    <telerik:GridViewDataColumn x:Name="colId" Width="Auto" DataMemberBinding="{Binding IdCUVExcel}" Header="ID" IsFilterable="False" IsReadOnly="True"/>

    <telerik:GridViewDataColumn x:Name="colMza" Width="Auto" DataMemberBinding="{Binding Manzana}" Header="MZA" IsFilterable="False" IsReadOnly="True"/>

    <telerik:GridViewDataColumn x:Name="colLot" Width="Auto" DataMemberBinding="{Binding Lote}" Header="LOT" IsFilterable="False" IsReadOnly="True"/>

    <telerik:GridViewDataColumn x:Name="colNo" Width="Auto" DataMemberBinding="{Binding NumeroExterior}" Header="No" IsFilterable="False" IsReadOnly="True"/>

    <telerik:GridViewDataColumn x:Name="colInt" Width="Auto" DataMemberBinding="{Binding NumeroInterior}" Header="INT" IsFilterable="False" IsReadOnly="True"/>

    <telerik:GridViewDataColumn x:Name="colEdif" Width="Auto" DataMemberBinding="{Binding Edificio}" Header="EDIF" IsFilterable="False" IsReadOnly="True"/>

    <telerik:GridViewDataColumn x:Name="colAvanceIndividual" Width="*" Background="{Binding ColorAvance}" DataMemberBinding="{Binding AvanceIndividual, Mode=TwoWay}" IsFilterable="True" IsReadOnly="True">
        <telerik:GridViewDataColumn.Header>
            <TextBlock Text="% Avance Individual" TextAlignment="Center" TextWrapping="Wrap" />
        </telerik:GridViewDataColumn.Header>
        <telerik:GridViewDataColumn.CellStyle>
            <Style TargetType="telerik:GridViewCell">
                <Setter Property="Foreground" Value="{Binding ColorAvance}" />
            </Style>
        </telerik:GridViewDataColumn.CellStyle>
    </telerik:GridViewDataColumn>

    <telerik:GridViewDataColumn x:Name="colDtu" DataMemberBinding="{Binding DTU, Mode=TwoWay}" Header="DTU" IsFilterable="False">
        <telerik:GridViewDataColumn.CellTemplate>
            <DataTemplate>
                <CheckBox HorizontalAlignment="Center" VerticalAlignment="Center" BorderThickness="5" Click="CheckBox_Click" IsChecked="{Binding DTU, Mode=TwoWay}" />
            </DataTemplate>
        </telerik:GridViewDataColumn.CellTemplate>
    </telerik:GridViewDataColumn>

    <telerik:GridViewDataColumn x:Name="colPC" Width="*" DataMemberBinding="{Binding PC, Mode=TwoWay}" IsFilterable="False" Tag="1"/>
    <telerik:GridViewDataColumn x:Name="colE" Width="*" DataMemberBinding="{Binding Estructura, Mode=TwoWay}" IsFilterable="False" Tag="1"/>
    <telerik:GridViewDataColumn x:Name="colIHS" Width="*" DataMemberBinding="{Binding IHS, Mode=TwoWay}" IsFilterable="False" Tag="1"/>
    <telerik:GridViewDataColumn x:Name="colIE" Width="*" DataMemberBinding="{Binding IE, Mode=TwoWay}" IsFilterable="False" Tag="1"/>
    <telerik:GridViewDataColumn x:Name="colIG" Width="*" DataMemberBinding="{Binding IGE, Mode=TwoWay}" IsFilterable="False" Tag="1"/>
    <telerik:GridViewDataColumn x:Name="colAlbanileria" Width="*" DataMemberBinding="{Binding Albañileria, Mode=TwoWay}" IsFilterable="False" Tag="1"/>
    <telerik:GridViewDataColumn x:Name="colAcabados" Width="*" DataMemberBinding="{Binding Acabados, Mode=TwoWay}" IsFilterable="False" Tag="1"/>
    <telerik:GridViewDataColumn x:Name="colCHC" Width="*" DataMemberBinding="{Binding CHC, Mode=TwoWay}" IsFilterable="False" Tag="1"/>
    <telerik:GridViewDataColumn x:Name="colELE" Width="*" DataMemberBinding="{Binding ELE, Mode=TwoWay}" IsFilterable="False" Tag="1"/>

  </telerik:RadGridView.Columns>
</telerik:RadGridView>

这是我的模特:

public class MainWindowViewModel : BindableBase
{
    private ObservableCollection<AvanceObra> _lstAvancesCuvs;
    public ObservableCollection<AvanceObra> LstAvancesCuvs
    {
        get { return _lstAvancesCuvs; }
        set
        {
            _lstAvancesCuvs = value;
            OnPropertyChanged();
        }
    }

    public MainWindowViewModel()
    {
        _lstAvancesCuvs = new ObservableCollection<AvanceObra>();
    }
}

1 个答案:

答案 0 :(得分:2)

以下是一个非常简单的示例,介绍如何处理异步操作:

<强> XAML的片段

<StackPanel >
        <Button Content="FillData" Click="ButtonBase_OnClick"></Button>
        <ListView ItemsSource="{Binding Files, Mode=OneWay, IsAsync=True}"></ListView>
    </StackPanel>

<强>代码

public partial class Window1 
    {
        private object _lock = new object();
        public Window1()
        {
            InitializeComponent();
            BindingOperations.EnableCollectionSynchronization(this.Files, this._lock);

            this.DataContext = this;
        }

        public ObservableCollection<string> Files => this._files;

        private ObservableCollection<string> _files = new ObservableCollection<string>();

        private async void ButtonBase_OnClick(object sender, RoutedEventArgs e)
        {
            await Task.Run(() =>
            {
                foreach (var file in Directory.GetFiles(yourPath)
                {
                    this.Files.Add(file);
                }
            });
        }
    }

我做得很快,很脏,这就是代码隐藏的原因。

注意BindingOperations.EnableCollectionSynchronization(this.Files, this._lock);

这使异步机制能够从另一个线程更新您的集合。那应该是。

玩得开心