图像库 WPF 应用程序正在发生这种情况,该应用程序在列表框中显示缩略图并使用 xaml 显示所选图像
问题 - 有没有办法安全地删除当前选择的图像而不会得到 IOException ?
仅供参考 - 用户拥有该目录的所有权限,没有其他进程正在使用该文件
这是删除文件的代码
void deleteCurrentlySelectedImageClick()
{
var o = SelectedPhoto; // class MyPhoto with a string FilePath
string path = o.FilePath;
// ViewList is of type List<MyPhoto> bound to listbox for displaying thumbnails
// for the purists
// it can/should be of type ObservableCollection<>
// but this doesn't change that often here :)
ViewList.Remove(o);
o = null;
firePropertyChanged("ViewList");
firePropertyChanged("SelectedPhoto");
FileInfo fi = new FileInfo(path);
fi.Delete();
}
例外是
System.IO.IOException was unhandled by user code
HResult=-2147024864
Message=The process cannot access the file 'C:\<path>\US-wp2.jpg' because it is being used by another process.
Source=mscorlib
StackTrace:
at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
at System.IO.FileInfo.Delete()
缩略图的 XAML 是
<ListBox
IsSynchronizedWithCurrentItem="True"
Name="PhotosListBox"
Style="{StaticResource PhotoListBoxStyle}"
Margin="5"
SelectionMode="Extended"
ItemsSource="{Binding ViewList}"
SelectedIndex="0"
SelectionChanged="PhotosListBox_SelectionChanged"
>
.... // 资源 xaml 是 ....
<DataTemplate DataType="{x:Type sample1:MyPhoto}">
<Grid VerticalAlignment="Center" HorizontalAlignment="Center" Margin="6">
<!-- Drop Shadow -->
<Border HorizontalAlignment="Stretch" VerticalAlignment="Stretch" CornerRadius="4" Background="#44000000">
<Border.RenderTransform>
<TranslateTransform X="5" Y="5" />
</Border.RenderTransform>
<Border.BitmapEffect>
<BlurBitmapEffect Radius="8" />
</Border.BitmapEffect>
</Border>
<!-- Image Template -->
<Border Padding="4" Background="White" BorderBrush="#22000000" BorderThickness="1">
<StackPanel Orientation="Vertical">
<Image Source="{Binding FilePath}"/>
</StackPanel>
</Border>
</Grid>
</DataTemplate>
<!-- Main photo catalog view -->
<Style TargetType="{x:Type ListBox}" x:Key="PhotoListBoxStyle">
<Setter Property="Foreground" Value="White" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ListBox}" >
<WrapPanel Margin="5" IsItemsHost="True" Orientation="Horizontal"
ItemHeight="{Binding ElementName=ZoomSlider, Path='Value'}"
ItemWidth="{Binding ElementName=ZoomSlider, Path='Value'}"
VerticalAlignment="Top" HorizontalAlignment="Stretch" />
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
<!-- Style for an individual generic item -->
<Style TargetType="{x:Type ListBoxItem}">
<Setter Property="Background" Value="Transparent" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ListBoxItem}" >
<Border SnapsToDevicePixels="True" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Background="{TemplateBinding Background}">
<ContentPresenter />
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsSelected" Value="True">
<Setter Property="Background" Value="#445B6249" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
全尺寸图像 xaml 很简单
<Image Source="{Binding SelectedPhoto.FilePath}" HorizontalAlignment="Center" VerticalAlignment="Center" />