如何用Properties.Resources中的图像从WPF中的代码隐藏动态更改图像源?

如何用Properties.Resources中的图像从WPF中的代码隐藏动态更改图像源?

我有一个WPF应用程序,需要向用户提供关于内部状态的反馈。设计有三张图片,分别叫红色、黄色和绿色。这些图像中的一个将根据状态一次显示。以下是要点:

  • 这三个图像在Properties.Resources中
  • 一次只显示一幅图像。
  • 状态更改来自代码隐藏中的进程,而不是用户。
  • 我想绑定一个图像控件,这样我就可以从代码背后更改图像。

我假设需要一个图像转换器将JPG图像更改为图像源,如:


[ValueConversion(typeof(System.Drawing.Bitmap), typeof(ImageSource))]public class BitmapToImageSourceConverter : IValueConverter{
    public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
    {
        var bmp = value as System.Drawing.Bitmap;
        if (bmp == null)
            return null;
        return System.Windows.Interop.Imaging.CreateBitmapSourceFromHBitmap(
                    bmp.GetHbitmap(),
                    IntPtr.Zero,
                    Int32Rect.Empty,
                    BitmapSizeOptions.FromEmptyOptions());
    }

    public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
    {
        throw new NotSupportedException();
    }}

我倾向于在初始化期间转换一次图像,并保留图像源列表。我还假设需要一个依赖项属性来将控件绑定到,但我不知道如何使用以下图像源列表设置该属性:


    // Dependancy Property for the North Image
    public static readonly DependencyProperty NorthImagePathProperty
        = DependencyProperty.Register(
            "NorthImagePath",
            typeof(ImageSource),
            typeof(MainWindow),
            new PropertyMetadata("**Don't know what goes here!!!**"));

    // Property wrapper for the dependancy property
    public ImageSource NorthImagePath
    {
        get { return (ImageSource)GetValue(NorthImagePathProperty); }
        set { SetValue(NorthImagePathProperty, value); }
    }


一只萌萌小番薯
浏览 1153回答 2
2回答

jeck猫

虽然WPF项目中的图像资源会生成System.Drawing.Bitmap财产Resources.Designer.cs,您可以直接创建一个BitmapImage从那个资源。您只需设置建立行动图像文件的Resource(而不是默认的None).如果你有文件Red.jpg在Resources文件夹中的VisualStudio项目,创建BitmapImage如下所示。它使用一个WPF包URI.var&nbsp;uri&nbsp;=&nbsp;new&nbsp;Uri("pack://application:,,,/Resources/Red.jpg");var&nbsp;bitmap&nbsp;=&nbsp;new&nbsp;BitmapImage(uri);如果你有Image控件在XAML中的某个位置声明如下:<Image&nbsp;x:Name="image"/>您可以简单地设置Source属性设置为以下代码中的BitmapImage:image.Source&nbsp;=&nbsp;bitmap;如果您希望设置Source属性,可以通过绑定创建string属性,该属性返回图像URI。字符串将自动转换为BitmapImage被内置的TypeConverter在WPF。public&nbsp;partial&nbsp;class&nbsp;MainWindow&nbsp;:&nbsp;Window{ &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;MainWindow() &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;InitializeComponent(); &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;DataContext&nbsp;=&nbsp;this; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;ImageUri&nbsp;=&nbsp;"pack://application:,,,/Resources/Red.jpg"; &nbsp;&nbsp;&nbsp;&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;static&nbsp;readonly&nbsp;DependencyProperty&nbsp;ImageUriProperty&nbsp;= &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;DependencyProperty.Register("ImageUri",&nbsp;typeof(string),&nbsp;typeof(MainWindow)); &nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;string&nbsp;ImageUri &nbsp;&nbsp;&nbsp;&nbsp;{ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;get&nbsp;{&nbsp;return&nbsp;(string)GetValue(ImageUriProperty);&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;set&nbsp;{&nbsp;SetValue(ImageUriProperty,&nbsp;value);&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;}}在XAML中,您将绑定到该属性,如下所示:<Image&nbsp;Source="{Binding&nbsp;ImageUri}"/>当然,您也可以声明该属性为类型。ImageSourcepublic&nbsp;static&nbsp;readonly&nbsp;DependencyProperty&nbsp;ImageProperty&nbsp;= &nbsp;&nbsp;&nbsp;&nbsp;DependencyProperty.Register("Image",&nbsp;typeof(ImageSource),&nbsp;typeof(MainWindow));public&nbsp;ImageSource&nbsp;Image{ &nbsp;&nbsp;&nbsp;&nbsp;get&nbsp;{&nbsp;return&nbsp;(ImageSource)GetValue(ImageProperty);&nbsp;} &nbsp;&nbsp;&nbsp;&nbsp;set&nbsp;{&nbsp;SetValue(ImageProperty,&nbsp;value);&nbsp;}}并以同样的方式捆绑:<Image&nbsp;Source="{Binding&nbsp;Image}"/>现在您可以预加载图像,并根据需要将它们放入属性中:private&nbsp;ImageSource&nbsp;imageRed&nbsp;= &nbsp;&nbsp;&nbsp;&nbsp;new&nbsp;BitmapImage(new&nbsp;Uri("pack://application:,,,/Resources/Red.jpg"));private&nbsp;ImageSource&nbsp;imageBlue&nbsp;= &nbsp;&nbsp;&nbsp;&nbsp;new&nbsp;BitmapImage(new&nbsp;Uri("pack://application:,,,/Resources/Blue.jpg"));...Image&nbsp;=&nbsp;imageBlue;更新:毕竟,您的图像不需要是VisualStudio项目中的资源。您只需添加一个项目文件夹,将图像文件放入该文件夹,并将其构建操作设置为Resource..例如,如果您调用该文件夹Images,URI将是pack://application:,,,/Images/Red.jpg.

收到一只叮咚

这应该也适用于PNG文件。也许您不应该将它们作为资源添加到您的项目中(请参阅我的编辑)。只需使用您最喜欢的图像工具创建文件,并将它们添加到项目中的文件夹中即可。看见这里关于接受。
打开App,查看更多内容
随时随地看视频慕课网APP