wpf image resources and changing image in wpf control at runtime

后端 未结 2 1216
天涯浪人
天涯浪人 2021-02-08 06:46

I would like to know exactly how to dynamically use a Dictionary Resource in the C# code behind - ie.. I would like to load images at runtime from an image resource within a dic

相关标签:
2条回答
  • 2021-02-08 07:32

    This is an addition to the accepted answer: When working within a ViewModel from MVVM, make sure to use the FindResource from the view where the resource directory is added.

    <Window x:Class="My.MainWindow"
            xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
            xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
            xmlns:ViewModels="clr-namespace:My.ViewModels"
            Title="USA Hockey Player Evaluation tool" 
            Icon="/USAHockeyPlayerEval;component/View/Images/HET.ico"
            SizeToContent="WidthAndHeight"
            MinHeight="500px" MinWidth="800px">
        <Window.Resources>
            <ResourceDictionary>
                <ResourceDictionary.MergedDictionaries>
                    <ResourceDictionary Source="Images.xaml" />
                </ResourceDictionary.MergedDictionaries>
            </ResourceDictionary>
        </Window.Resources>
        <Window.DataContext>
            <ViewModels:MainWindowMV/>
        </Window.DataContext>
        <StackPanel>
            <Menu>
                <MenuItem Header="File">
                    <MenuItem Header="Save"></MenuItem>
    

    My view in this case is a window (I know not correct MVVM ;-) )

    Image img = new Image();                                    
    img.Source = (ImageSource)WindowReference.FindResource("Pluse"); 
    

    Here the WindowReference is a reference to My.MainWindow.

    0 讨论(0)
  • 2021-02-08 07:39

    First, make sure you've defined your image resources like this:

    <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
        <ImageSource x:Key="image1">images/image1.jpg</ImageSource>
        <ImageSource x:Key="image2">images/image2.jpg</ImageSource>
    </ResourceDictionary>
    

    Secondly, I'm assuming that your WPF dictionary is in its own file. Now you have to make sure you've merged your dictionary into your main window's XAML (skip this step if your resource dictionary is defined inside of the window's XAML). In your window's XAML file, make sure you have something like this:

    <Window.Resources>
        <ResourceDictionary>
            <ResourceDictionary.MergedDictionaries>
                <ResourceDictionary Source="myDictionary.xaml" />
            </ResourceDictionary.MergedDictionaries>
        </ResourceDictionary>
    </Window.Resources>
    

    Now, in your code-behind, you can use the FindResource() method to locate your image resource by it's key name (the value of the x:Key attribute on the ImageSource in the resource dictionary) like so:

    imageControl.Source = (ImageSource)FindResource("image1");
    

    Hope this helps!

    0 讨论(0)
提交回复
热议问题