WPF TextBlock in griglia in ListView non corretto dimensionamento?
-
20-09-2019 - |
Domanda
Ho un TextBlock che si trova in una griglia che è un ItemTemplate per un controllo ListView. Ho le voci in modo che crescano quando la finestra viene ridimensionata, ma non riesco a capire come avere TextBlock essere limitata a quella dimensione. Ho provato a fare questo con la larghezza sul ColumnDefinition - se ho impostato la larghezza su un numero fisso (ad esempio 350) il testo si correttamente, ma ovviamente il TextBlock non si espande quando la finestra viene espansa - se ho impostato il Larghezza a "*", il V'è poi una barra di scorrimento orizzontale e il testo corre a destra e non va a capo.
Qualche idea di cosa sto facendo male qui?
<GroupBox Header="Urgent Items" Margin="8,8,8,340" Name="UrgetItemsGroupBox">
<Grid>
<ListView Margin="6" Name="CriticalErrorsListView" HorizontalContentAlignment="Stretch" ItemsSource="{Binding Path=.}" MouseDoubleClick="CriticalErrorsListView_MouseDoubleClick">
<ListView.Background>
<LinearGradientBrush EndPoint="-0.192,0.529" StartPoint="0.998,0.519">
<GradientStop Color="#FFD2D2D2" Offset="0"/>
<GradientStop Color="#FFFFFFFF" Offset="1"/>
</LinearGradientBrush>
</ListView.Background>
<ListView.ItemTemplate>
<DataTemplate>
<Border Margin="2,2,2,3" BorderBrush="#FF847F6E" CornerRadius="10" BorderThickness="3">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="30" />
<ColumnDefinition Width="10" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="25" />
<RowDefinition Height="20" />
<RowDefinition Height="20" />
<RowDefinition Height="75" />
</Grid.RowDefinitions>
<Image Grid.Row="0" Grid.RowSpan="5" Grid.Column="0" Margin="2,2,2,2" Source="Images\errorIcon.png" />
<TextBlock Grid.Row="0" Grid.Column="2" Grid.ColumnSpan="2" Margin="2,2,2,2" Text="{Binding Path=ApplicationName}" FontFamily="Calibri" FontWeight="Bold" FontSize="18" />
<TextBlock Grid.Row="1" Grid.Column="2" Margin="10,2,10,2" Text="{Binding Path=ErrorTime}" FontFamily="Calibri" FontSize="12" />
<TextBlock Grid.Row="2" Grid.Column="2" Margin="10,2,10,2" Text="{Binding Path=ErrorPerson}" FontFamily="Calibri" FontSize="12" />
<TextBlock Grid.Row="3" Grid.Column="2" Margin="2,2,2,2" Text="{Binding Path=ShortDescription}" TextWrapping="Wrap" />
</Grid>
</Border>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
</Grid>
</GroupBox>
Soluzione
Si vede barra di scorrimento orizzontale perché ListView utilizza ScrollViewer nel suo modello per consentire lo scorrimento. Tutto quello che dovete fare è dire che ScrollViewer di non scorrere orizzontalmente. Basta impostare ScrollViewer.HorizontalScrollBarVisibility = "Disabilitato" sulla ListView. Così avrete qualcosa di simile:
<ListView Margin="6"
ScrollViewer.HorizontalScrollBarVisibility="Disabled"
Name="CriticalErrorsListView"
HorizontalContentAlignment="Stretch"
ItemsSource="{Binding Path=.}"
MouseDoubleClick="CriticalErrorsListView_MouseDoubleClick">
<!-- The rest goes here. -->
</ListView>
Spero che questo aiuti.