Wpf Listbox 自增序号的实现

本文介绍了如何在WPF的ListBox中实现自动生成并显示每个项目的序号,详细解析了相关代码实现过程,帮助开发者提升用户体验。

    /// <summary>
    /// 自动列表序号
    /// </summary>
    [ValueConversion(typeof(Int32), typeof(ListViewItem))]
    public class IndexConverter : IValueConverter
    {
        public object Convert(object value, Type TargetType, object parameter, CultureInfo culture)
        {
            ListBoxItem item = (ListBoxItem)value;
            ListBox listView = ItemsControl.ItemsControlFromItemContainer(item) as ListBox;
            return listView.ItemContainerGenerator.IndexFromContainer(item) + 1;
        }

        public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
        {
            throw new NotImplementedException();
        }
    }
                 <ListBox.ItemTemplate>
                        <DataTemplate>
                            <Grid Margin="3" Width="480" Background="{Binding MoveCommand,Converter={StaticResource listBackgroundConverter}}">
                                <Grid.ColumnDefinitions>
                                    <ColumnDefinition Width="50"/>
                                    <ColumnDefinition Width="150"/>
                                    <ColumnDefinition Width="100"/>
                                    <ColumnDefinition Width="50"/>
                                    <ColumnDefinition Width="30"/>
                                    <ColumnDefinition Width="30"/>
                                    <ColumnDefinition Width="30"/>
                                </Grid.ColumnDefinitions>
                                <Label  FontStyle="Italic"  Width="50" FontSize="20" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"  Foreground="White" Background="#E67E22" Content="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type ListBoxItem}}, Converter={StaticResource MyIndexConverter}}"/>
                               
                                
                                <Label Grid.Column="1" Width="150"   Background="Transparent" FontSize="20" VerticalContentAlignment="Center" HorizontalContentAlignment="Left">
                                    <Label.Content>
                                        <MultiBinding Converter="{StaticResource labelConverter}">
                                            <Binding Path="MoveCommand"/>
                                            <Binding Path="Signal"/>
                                        </MultiBinding>
                                    </Label.Content>
                                </Label>
                                <TextBox Grid.Column="2" Width="100" Text="{Binding DalayTime, Mode=TwoWay}"  FontSize="20" HorizontalAlignment="Right" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></TextBox>
                                <Button Grid.Column="3" Width="40" Content="&#xf01d;" FontSize="32" Foreground="LawnGreen" Background="Transparent" HorizontalAlignment="Right"   Click="btnRunOneStep_Click"></Button>
                                <Button Content="&#xf062;" Grid.Column ="4" Foreground = "#ff0066" Background="Transparent" Margin="2" Height="20"   ToolTip="上移" Click="btnItemUnloadUp_Click"></Button>
                                <Button Content="&#xf063;" Grid.Column ="5" Foreground = "#3333ff" Background="Transparent" Margin="2" Height="20"   ToolTip="下移" Click="btnItemUnloadDown_click"></Button>
                                <Button Content="&#xf00d;" Grid.Column ="6" Foreground = "#ff0000" Background="Transparent" Margin="2" Height="20"   ToolTip="删除" Click="btn_ItemUnload_click"></Button>

                            </Grid>
                        </DataTemplate>
                    </ListBox.ItemTemplate>
效果
效果

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值