![](/img/trans.png)
[英]Change the Background Color of an ListView Item on Xamarin Forms
[英]Change ListView Item Background Color based on the value of the Item C# Xamarin.Forms
我尝试在互联网上查找类似的问题,但似乎没有什么比我的。
我有一个ListView显示记录列表:
<ListView x:Name="TavoloListView" HasUnevenRows="true" Grid.Row="2" SeparatorColor="Black"
SelectedItem="{Binding SelectedTavoloItem, Mode=TwoWay}" >
<ListView.ItemTemplate>
<DataTemplate>
<ViewCell>
<Grid ColumnSpacing="0" RowSpacing="0">
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<BoxView x:Name="ItemsBackground" Grid.Column="0" Grid.ColumnSpan="6" Color="White" Opacity="0.5"/>
<Label Text="{Binding TavoloNo}" Grid.Row="0" Grid.Column="0" TextColor="Black" HorizontalOptions="Center"/>
<Label Text="{Binding CameraNo}" Grid.Row="0" Grid.Column="1" TextColor="Black" HorizontalOptions="Center"/>
<Label Text="{Binding Arrivo, StringFormat='\{0:dd/MM/yy}'}" Grid.Row="0" Grid.Column="2" TextColor="Black" HorizontalOptions="Center"/>
<Label Text="{Binding Partenza, StringFormat='\{0:dd/MM/yy}'}" Grid.Row="0" Grid.Column="3" TextColor="Black" HorizontalOptions="Center"/>
<Label Text="{Binding PersoneTot}" Grid.Row="0" Grid.Column="4" TextColor="Black" HorizontalOptions="Center"/>
<Label Text="{Binding Bambini, StringFormat='(\{0}\)'}" Grid.Row="0" Grid.Column="5" TextColor="Black" HorizontalOptions="Center"/>
</Grid>
</ViewCell>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
我需要根据两个Label
的Arrivo
和Partenza
的比较结果来更改ItemsBackground
BoxView
的颜色。 基本上,页面上有一个名为MainDatePicker
DatePicker
。 我想将记录的Arrivo
和Partenza
日期值与MainDatePicker.Date
。 如果Arrivo == MainDatePicker.Date
我想将ItemsBackground
BoxView
的颜色更改为绿色。 如果Partenza
与MainDatePicker.Date
匹配,则ItemsBackground
BoxView
的颜色应为红色。
如果以上都不是,则颜色保持白色。
有可能实现这一目标吗?
您可以像这样在侧面listViewBox颜色中设置`
<ListView Grid.Row="1" ItemsSource="{Binding BindListViewData}">
<ListView.ItemTemplate>
<DataTemplate>
<ViewCell>
<ViewCell.View>
<BoxView>
<BoxView.Triggers>
<DataTrigger TargetType="BoxView" Binding="{Binding BindBoolValueFromModel}" Value="True">
<Setter Property="BackgroundColor" Value="Green" />
</DataTrigger>
<DataTrigger TargetType="BoxView" Binding="{Binding BindBoolValueFromModel}" Value="False">
<Setter Property="BackgroundColor" Value="Red" />
</DataTrigger>
</BoxView.Triggers>
</BoxView>
</ViewCell.View>
</ViewCell>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
`
在您的SelectedTavoloItem中添加新属性(例如, color
并在初始化TavoloListView
数据源时验证条件
public void UpdateDataSourceForLIst()
{
List<SelectedTavoloItem> newListData=new List<SelectedTavoloItem>();
foreach(var item in DataSourceForList)
{
if(Arrivo == MainDatePicker.Date)
{
item.color=green;
newListData.Add(item);
}else{
item.color=red;
newListData.Add(item);
}
}
DataSourceForList=newListData;
}
并在绑定列表时,将以下代码添加到背景框中:
`<BoxView
x:Name="ItemsBackground"
Grid.Column="0"
Grid.ColumnSpan="6"
Color="{Binding color}" //// bind new created property
Opacity="0.5"/>`
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.