DataGrid.FrozenColumnCount Eigenschaft

Definition

Ruft die Anzahl der Spalten ohne Bildlauf ab, oder legt diese fest.Gets or sets the number of non-scrolling columns.

public:
 property int FrozenColumnCount { int get(); void set(int value); };
public int FrozenColumnCount { get; set; }
member this.FrozenColumnCount : int with get, set
Public Property FrozenColumnCount As Integer

Eigenschaftswert

Die Anzahl der Spalten ohne Bildlauf.The number of non-scrolling columns. Der registrierte Standardwert ist 0 (null).The registered default is 0. Weitere Informationen zu Einflüssen auf diesen Wert finden Sie unter DependencyProperty.For more information about what can influence the value, see DependencyProperty.

Beispiele

Im folgenden Beispiel wird gezeigt, wie eine Spalte eingefroren wird, wenn "Freeze Column" aus ContextMenuausgewählt wird.The following example shows how to make a column frozen when "Freeze Column" is selected from the ContextMenu. Die Spalten werden nach links verschoben, damit Sie in die fixierten Spalten eingeschlossen werden können.Columns are moved to the left in order to be included in the frozen columns.

<!--Defines the handlers for when the FreezeColumnCommand is executed-->
<Window.CommandBindings>
    <CommandBinding Command="{x:Static local:Window1.FreezeColumnCommand}" Executed="CommandBinding_Executed" />
</Window.CommandBindings>
<!--Defines the context menu for the ColumnHeaders and attaches the FreezeColumnCommand-->
<Window.Resources>
    <ContextMenu x:Key="ColumnHeaderMenu" IsEnabled="True"  >
        <MenuItem Header="Freeze Column" IsEnabled="True" Command="{x:Static local:Window1.FreezeColumnCommand}"
                  CommandTarget="{Binding RelativeSource={RelativeSource AncestorType=Popup}, Path=PlacementTarget}" 
                  CommandParameter="{Binding ElementName=DG1, Path=CurrentColumn.DisplayIndex}" />
    </ContextMenu>
</Window.Resources>

<Grid>
    <!--Creates a new DataGrid with a context menu for the column headers-->
    <DataGrid Name="DG1" ItemsSource="{Binding}"  >
        <DataGrid.ColumnHeaderStyle >
            <Style TargetType="DataGridColumnHeader">
                <Setter Property="ContextMenu" Value="{StaticResource ColumnHeaderMenu}" />
            </Style>
        </DataGrid.ColumnHeaderStyle>
    </DataGrid>
</Grid>
public partial class Window1 : Window
{
    
    public static RoutedUICommand FreezeColumnCommand = new RoutedUICommand();

    

    public Window1()
    {
        InitializeComponent();
        //GetData connects to the database and returns the data in a table.
        AdventureWorksLT2008DataSet.SalesOrderDetailDataTable dt = GetData();

        DG1.DataContext = dt;
    }
Class Window1
    Public Shared FreezeColumnCommand As New RoutedUICommand()

    Public Sub New()
        InitializeComponent()

        'GetData connects to the database and returns the data in a table.
        Dim dt As AdventureWorksLT2008DataSet.SalesOrderDetailDataTable = GetData()

        DG1.DataContext = dt
    End Sub
    private void CommandBinding_Executed(object sender, ExecutedRoutedEventArgs e)
    {
       //Get the column header that started the command and move that column left to freeze it.
       System.Windows.Controls.Primitives.DataGridColumnHeader header = (System.Windows.Controls.Primitives.DataGridColumnHeader)e.OriginalSource;
       if (header.Column.IsFrozen ==true)
       {
           return;
       }
       else
       {
           header.Column.DisplayIndex = DG1.FrozenColumnCount;
           DG1.FrozenColumnCount++;
       }


    }
 
}
Private Sub CommandBinding_Executed(ByVal sender As Object, ByVal e As ExecutedRoutedEventArgs)
    'Get the column header that started the command and move that column left to freeze it.
    Dim header As System.Windows.Controls.Primitives.DataGridColumnHeader = DirectCast(e.OriginalSource, System.Windows.Controls.Primitives.DataGridColumnHeader)
    If header.Column.IsFrozen = True Then
        Exit Sub
    Else
        header.Column.DisplayIndex = DG1.FrozenColumnCount
        DG1.FrozenColumnCount += 1


    End If
End Sub

Hinweise

Fixierte Spalten sind Spalten, die immer angezeigt werden und nicht aus Sichtbarkeit heraus scrollen können.Frozen columns are columns that are always displayed and cannot be scrolled out of visibility. Fixierte Spalten sind immer die am weitesten links stehenden Spalten in der Anzeigereihenfolge.Frozen columns are always the leftmost columns in display order. Sie können fixierte Spalten nicht in die Gruppe der nicht fixierten Spalten ziehen oder nicht fixierte Spalten in die Gruppe der fixierten Spalten ziehen.You cannot drag frozen columns into the group of unfrozen columns or drag unfrozen columns into the group of frozen columns.

Um Spalten zu fixieren, legen FrozenColumnCount Sie die-Eigenschaft fest.To freeze columns, set the FrozenColumnCount property. Die durch die FrozenColumnCount Zahl angegebenen linken Spalten werden fixiert.The leftmost columns specified by the FrozenColumnCount number will become frozen. Wenn Sie z. b. FrozenColumnCount auf 2 festlegen, werden die beiden linken Spalten in der Anzeige fixiert.For example, if you set the FrozenColumnCount to 2, the two left columns in the display are frozen. Um zu ermitteln, ob eine Spalte bereits eingefroren ist, IsFrozen überprüfen Sie DataGridColumndie-Eigenschaft auf.To determine whether a column is already frozen, check the IsFrozen property on the DataGridColumn.

Gilt für:

Siehe auch