wpf中listbox添加多个文件

wpf中listbox添加多个文件,第1张

wpf中listbox添加多个文件我有一个实现拖放的ListBox:它适用于单个项目(选择一个项目,然后将其拖动到另一个项目的顶部将其放置在正确的位置),但是当选择多个项目(使用shift或ctrl)时,我尚未能够使其工作。

我的主要问题是我不知道DragDrop.DoDragDrop函数如何处理一批项目。它适用于单个项目(指定FrameworkElement,然后指定数据格式和数据,最后指定拖动效果)。但是,如果我有多个项目,该如何使用DoDragDrop?由于我必须指定一种格式,难道它不会总是期望该格式的单个实例吗?我有几个要拖放的"实体",如何告诉DragDrop.DoDragDrop在一个 *** 作中接受所有这些数据?

当我仅将一个DataObject传递给DoDragDrop方法时,它可以完美地工作,但是我需要找到一种在一次调用中传递多个对象的方法。

到目前为止,我已经尝试创建多个DataObjects并尝试创建一个数组或列表以将其添加到DoDragDrop作为其数据,但这是行不通的。我还尝试了循环DoDragDrop,因此它为我拖动的每个项目调用了一次,但也无效。

1. 设置属性 IsEditable="True" Combobox就可编辑

2. 下拉框正常绑定数据就行,如果像上图每个Item都有个删除功能,那就需要重写样式,可参考下面的代码(带有动画效果,可删除)

<Style TargetType="{x:Type ComboBoxItem}">

<Setter Property="SnapsToDevicePixels"

Value="true"/>

<Setter

Property="HorizontalContentAlignment" Value="Stretch"/>

<Setter

Property="VerticalContentAlignment" Value="Center"/>

<Setter Property="Padding"

Value="3"/>

<Setter Property="Focusable"

Value="False"/>

<Setter Property="Template">

<Setter.Value>

<ControlTemplate

TargetType="{x:Type ComboBoxItem}">

<Grid SnapsToDevicePixels="true" FocusVisualStyle="{x:Null}">

<Rectangle x:Name="BackgroundHighlight" FocusVisualStyle="{x:Null}"

Margin="-1" Stroke="#A0FFFFFF"/>

<ContentPresenter

Content="{Binding LoginName}" FocusVisualStyle="{x:Null}"

HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"

VerticalAlignment="{TemplateBinding VerticalContentAlignment}"

SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"

x:Name="contentPresenter" Margin="{TemplateBinding Padding}"/>

<Button Width="30"

Height="30" HorizontalAlignment="Right" Tag="{Binding LoginName}"

Style="{StaticResource CloseButton}" Click="BtnDeleteRecord_Click"/>

</Grid>

<ControlTemplate.Triggers>

<Trigger

Property="IsMouseOver" Value="True">

<Trigger.ExitActions>

<BeginStoryboard

Storyboard="{StaticResource HoverOff}"

x:Name="HoverOff_BeginStoryboard"/>

</Trigger.ExitActions>

<Trigger.EnterActions>

<BeginStoryboard

Storyboard="{StaticResource HoverOn}"

x:Name="HoverOn_BeginStoryboard"/>

</Trigger.EnterActions>

</Trigger>

<Trigger

Property="IsHighlighted" Value="true"/>

<Trigger

Property="Selector.IsSelected" Value="True">

<Trigger.ExitActions>

<BeginStoryboard

Storyboard="{StaticResource SelectedOff}"

x:Name="SelectedOff_BeginStoryboard1"/>

</Trigger.ExitActions>

<Trigger.EnterActions>

<BeginStoryboard

Storyboard="{StaticResource SelectedOn}"

x:Name="SelectedOn_BeginStoryboard1"/>

</Trigger.EnterActions>

</Trigger>

</ControlTemplate.Triggers>

</ControlTemplate>

</Setter.Value>

</Setter>

</Style>


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11606530.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存