C# UWP:无法使ListView可滚动
我有一个带有简单网格(2x2)的页面。在左下角的一个网格中是另一个网格,在该网格中是绑定到集合的C# UWP:无法使ListView可滚动,c#,listview,uwp,scrollbar,vertical-scrolling,C#,Listview,Uwp,Scrollbar,Vertical Scrolling,我有一个带有简单网格(2x2)的页面。在左下角的一个网格中是另一个网格,在该网格中是绑定到集合的列表视图。可以将条目添加到集合中,使ListView的高度增加(ListView的高度设置为“自动”,以便使用所有可用空间) 我想要的是,如果使用了所有可用空间(从屏幕高度),ListView的滚动条应该出现并且应该可用。有趣(不有趣)的是:滚动条确实出现了,但我不能使用它们,我不能用悬停ListView时出现的垂直滚动条滚动ListView 当我将ListView的高度设置为固定值时,它可以工作,但
列表视图。可以将条目添加到集合中,使ListView的高度增加(ListView的高度设置为“自动”,以便使用所有可用空间)
我想要的是,如果使用了所有可用空间(从屏幕高度),ListView的滚动条应该出现并且应该可用。有趣(不有趣)的是:滚动条确实出现了,但我不能使用它们,我不能用悬停ListView时出现的垂直滚动条滚动ListView
当我将ListView的高度设置为固定值时,它可以工作,但我不希望这样,因为这样它就不会使用屏幕上的所有可用空间
这是页面的XAML(出于演示目的,我删除了一些部分):
...
...
...
...
有人能看出它为什么会这样吗?您需要为两个网格将第二行的高度设置为“*”
。网格行/单元格的高度设置为自动->其中的所有内容都将获得所需的所有空间。如果您有足够的空间,为什么要滚动?因此,我应该为放置ListView的网格的行设置高度,或者也为其他网格(例如主2x2网格)设置高度?为两个网格将第二行的高度设置为“*”。谢谢,它现在正按预期工作,将第二个网格行定义的高度设置为“*”。你应该把你的评论作为答案,这样我就可以接受他们作为答案。很高兴能帮上忙。
<Page
x:Class="Qooli.TimeTracker.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Qooli.TimeTracker"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d">
<Page.Resources>
...
</Page.Resources>
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Grid.RowDefinitions>
<RowDefinition Height="Auto"></RowDefinition>
<RowDefinition Height="Auto"></RowDefinition>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto"></ColumnDefinition>
<ColumnDefinition Width="Auto"></ColumnDefinition>
</Grid.ColumnDefinitions>
<StackPanel Name="spAddEntry" Grid.Row="0" Grid.Column="0" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="30">
<TextBlock Text="Add new entry:" Name="lblAddNewEntry" />
...
</StackPanel>
<StackPanel Grid.Row="0" Grid.Column="1" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="30">
<TextBlock Text="Allocated time:" Name="lblAllocatedTime" />
...
</StackPanel>
<Grid Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="1" Margin="30">
<Grid.RowDefinitions>
<RowDefinition Height="Auto"></RowDefinition>
<RowDefinition Height="Auto"></RowDefinition>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto"></ColumnDefinition>
</Grid.ColumnDefinitions>
<TextBlock Text="Daily overview:" Name="lblDailyOverview" Grid.Row="0" Grid.Column="0" />
<ListView Name="lvTimeEntries" Grid.Row="1" Grid.Column="0" HorizontalAlignment="Left"
Height="Auto"
MinHeight="100"
VerticalAlignment="Top"
MinWidth="300"
SelectionMode="Single"
ItemsSource="{x:Bind ViewModel.TimeEntriesAdvancedCollectionView, Mode=OneWay}"
ScrollViewer.VerticalScrollBarVisibility="Visible"
ScrollViewer.IsVerticalRailEnabled="True"
ScrollViewer.VerticalScrollMode="Enabled">
<ItemsControl.ItemsPanel>
<ItemsPanelTemplate>
<StackPanel></StackPanel>
</ItemsPanelTemplate>
</ItemsControl.ItemsPanel>
<ItemsControl.ItemTemplate>
<DataTemplate x:DataType="local:TimeEntry">
<Grid Background="{Binding Type, Converter={StaticResource TimeEntryTypeColorConverter}}" Padding="5">
<Grid.RowDefinitions>
<RowDefinition Height="200"></RowDefinition>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto"></ColumnDefinition>
<ColumnDefinition Width="Auto"></ColumnDefinition>
<ColumnDefinition Width="Auto"></ColumnDefinition>
<ColumnDefinition Width="*"></ColumnDefinition>
</Grid.ColumnDefinitions>
<TextBlock Text="{x:Bind Time, Mode=OneWay}" Style="{StaticResource TitleTextBlockStyle}"
MinWidth="60"
MaxWidth="60"
Grid.Row="0" Grid.Column="0">
</TextBlock>
<TextBlock Text="{x:Bind Title, Mode=OneWay}" Style="{StaticResource BodyTextBlockStyle}" Margin="5,0,0,0"
MinWidth="100"
MaxWidth="100"
Grid.Row="0" Grid.Column="1">
</TextBlock>
<Button Name="btnEditTimeEntry" Grid.Row="0" Grid.Column="2" Margin="5,5,5,5">
<SymbolIcon x:Name="edit" Symbol="Edit"/>
</Button>
<Button Name="btnDeleteTimeEntry" Grid.Row="0" Grid.Column="3" Margin="5,5,5,5">
<SymbolIcon x:Name="delete" Symbol="Delete"/>
</Button>
</Grid>
</DataTemplate>
</ItemsControl.ItemTemplate>
</ListView>
</Grid>
<StackPanel Grid.Row="1" Grid.Column="1" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="30">
<TextBlock Style="{StaticResource summaryTextStyle}" Text="Start time:" Name="lblDayStartTime" />
...
</StackPanel>
</Grid>
</Page>