WPF 使用Image控件显示图片

2022-05-28  本文已影响0人  Ritchie_Li

Image控件可以显示 .bmp, .gif, .ico, .jpg, .png, .wdp and .tiff  格式的图片文件。

1. 使用Source属性显示图片

UI 添加Image控件

<Image x:Name="ImageViewer1" Height="100" Width="200"/>

后台代码给Source属性赋值

ImageViewer1.Source = new BitmapImage(new Uri(@"Images\VS2015.jpg", UriKind.Relative));

效果图如下:

动态切换Source 指定的文件,使用OpenFileDialog 类来选择图片源文件

首先需要添加System.Windows.Forms的引用,来选择磁盘上其它图片文件来展示

private void btnUrl_Click(object sender, RoutedEventArgs e)

        {

            OpenFileDialog dlg = new OpenFileDialog();

            dlg.InitialDirectory = "c:\\";

            dlg.Filter = "Image files (*.jpg)|*.jpg|All Files (*.*)|*.*";

            dlg.RestoreDirectory = true;

            if (dlg.ShowDialog() == System.Windows.Forms.DialogResult.OK)

            {

                string selectedFileName = dlg.FileName;

                txtFile.Text = selectedFileName;

                BitmapImage bitmap = new BitmapImage();

                bitmap.BeginInit();

                bitmap.UriSource = new Uri(selectedFileName);

                bitmap.EndInit();

                ImageViewer1.Source = bitmap;

            }

        }

上述方法需要运行代码才能展示图片的。

2. 直接在WPF设计UI上展示图片

直接在XAML代码中

<Image x:Name="ImageViewer2" Source="Images\USA.png"/>

效果如下:

直接展示在界面上,无须运行代码。

可以设置图片显示的宽度和高度。

<Image x:Name="ImageViewer3" Source="Images\USA.png" Width="100" Height="100"/>

效果如下:

使用BitmapImage方式

<Image Width="100">

                <Image.Source>

                    <BitmapImage DecodePixelWidth="100"  UriSource="Images\USA.png" />

                </Image.Source>

      </Image>

3.动态添加Image控件,并显示图片

<StackPanel x:Name="sp1" Grid.Row="0" Grid.Column="2" Margin="5">

            <Button x:Name="btnDynamic" Click="btnDynamic_Click">动态加载</Button>

 </StackPanel>

后台代码:

        private void btnDynamic_Click(object sender, RoutedEventArgs e)

        {

            // Create Image and set its width and height 

            Image dynamicImage = new Image();

            dynamicImage.Width = 300;

            dynamicImage.Height = 200;

            // Create a BitmapSource 

            BitmapImage bitmap = new BitmapImage();

            bitmap.BeginInit();

            bitmap.UriSource = new Uri(@"C:\Users\WPF加载图片文件\WpfApp1\Images\VS2015.png");

            bitmap.EndInit();

            // Set Image.Source 

            dynamicImage.Source = bitmap;

            // Add Image to Window 

            sp1.Children.Add(dynamicImage);

        }

效果如下:

上一篇 下一篇

猜你喜欢

热点阅读