本記事の概要
この記事では、DataGrid の行高さの変更を許可する方法について説明します。
※データ表示方法については過去記事「データグリッドにデータを表示する方法」を参照してください。
公式サイト情報はコチラを参照してください。
行高さの変更を許可する
WPF の DataGrid は、行高さをマウスのドラッグで変更することができます。
行高さの変更を許可するには、CanUserResizeRows プロパティで制御することができます。true をセットすると行高さの変更を許可し、false をセットすると、行高さの変更をできなくします。
以下の例では 、チェックボックスがチェックされたときに CanUserResizeRows プロパティ に true をセットして行高さの変更を許可し、チェックを外したときは CanUserResizeRows プロパティ に false をセットして、行高さの変更をできなくします。
XAML の例
<Window x:Class="WpfSample.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:WpfSample"
mc:Ignorable="d"
Title="MainWindow" Height="450" Width="800">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="25"/>
<RowDefinition />
</Grid.RowDefinitions>
<CheckBox
Content="CanUserResizeRows"
Checked="ResizeRows_Checked"
Unchecked="ResizeRows_Unchecked" Grid.Row="0"/>
<DataGrid x:Name="dataGrid" AutoGenerateColumns="False"
Grid.Row="1">
<DataGrid.Columns>
<DataGridTextColumn Header="Id" Binding="{Binding Id}"/>
<DataGridTextColumn Header="氏名" Binding="{Binding Name}"/>
<DataGridTextColumn Header="年齢" Binding="{Binding Age}"/>
<DataGridTextColumn Header="郵便番号" Binding="{Binding ZipCode}"/>
<DataGridTextColumn Header="住所" Binding="{Binding Address}" />
</DataGrid.Columns>
</DataGrid>
</Grid>
</Window>
C# の例
private void ResizeRows_Checked(object sender, RoutedEventArgs e)
{
dataGrid.CanUserResizeRows = true;
}
private void ResizeRows_Unchecked(object sender, RoutedEventArgs e)
{
dataGrid.CanUserResizeRows = false;
}
以下に、行高さのリサイズ前後の実行例を示します。3行目の行高さを変更しています。
Please follow and like us:



コメント