WPF获取图片保存、回填图片

首先,我们在wpf中的xaml页面给它一个Image 图片标签,然后命名X:Name=“名称”;然后我们可以再给它一个按钮标签 Button 用来打开本电脑上的图片目录在标签里面给一个 Click,看下图例子:

 <Image Grid.Column="7" Grid.Row="1" Width="150" Height="150" Margin="0,0,0,0" Grid.RowSpan="7" x:Name="Format" Cursor="Hand" MouseLeftButtonDown="Image_Click"></Image>
 <Button Content="浏览图片" Grid.Column="7" Grid.Row="8" HorizontalAlignment="Center" VerticalAlignment="Top" Click="Image_Click"/>

第二种写法:当然我们也可以在Image 标签里面添加一个 MouseLeftButtonDown标签点击;再给它一个鼠标手指样式 Cursor=”Hand”;

<Image Grid.Column="7" Grid.Row="1" Width="150" Height="150" Margin="0,0,0,0" Grid.RowSpan="7" x:Name="Format"></Image>

回到CS页面中在Click中转定义一个引用:然后实例化,给一个局部变量用来过滤掉与图片后缀不是图片格式的文件,再用if来判断是否有照片文件,有为true就将图片转换为流的形式然后将数据存放到数组中,方便用来保存的时候使用。最后将选择的图片显示在页面中。看下图代码:
实例化存放数组

List<byte[]> lstBytes = new List<byte[]>();
 private void Image_Click(object sender, RoutedEventArgs e)
        {
            OpenFileDialog Open = new OpenFileDialog();
            //过滤上传图片的类型              
            Open.Filter = "ALL Image Files(*.BMP;*.JPG;*.GIF)|*.BMP;*.JPG;*.GIF|AII Files(*.*)|*.*";
            if (Open.ShowDialog() == true)
            {
                //将图片转为流的形式 Open.FileName 是图片的地址
                byte[] image = File.ReadAllBytes(Open.FileName);
                //将对象存放到 lstBytes
                lstBytes.Add(image);
                //将选中的照片显示在 image 框中   
                Format.Source = new BitmapImage(new Uri(Open.FileName));
            }
        }

图片已经显示出来了,我们就把图片以二进制的方法见图片保存在数据库中;在保存的引用中先把图片提取出来,上面说了把它存放在LstBytes数组中,for循环提取出图片:

 private void Button_Click(object sender, RoutedEventArgs e)
        {
                //提取上传的文件
                byte[][] bytepicture = new byte[lstBytes.Count][];
                for (int i = 0; i < lstBytes.Count; i++)
                {
                    bytepicture[i] = lstBytes[i];//提取图片
                }
                 SYS_Message mymessage = new SYS_Message();
                 mymessage.Format = bytepicture[0];
                 myModel.SYS_Message.Add(mymessage);
                 if (myModel.SaveChanges() > 0)
                 {
                  //页面控件初始化
                  EmptyControl();
                 this.Close();
                 }
         }

然后进行赋值,就可以保存在数据库中了。可以去数据库中查看“<二进制数据>”表示已经成功了。我们再把数据库中的图片查询出来。
查询数据库存放的表数据,然后进行回填图片;将数据库的图片字符数组载入缓冲流中,实例化一个变量bitmapImage 然后将位置设置为流,获取到缓冲流的源,在将图片显示在Image标签框中:

            ///数据库回填图片
            //实例化 BitmapImage 
            BitmapImage bitmapImage = new BitmapImage();
            //将数据库图片字节数组加载入缓冲流           
            MemoryStream imageStream = new MemoryStream(user.Format);
            //将位置设置为流的开头。               
            imageStream.Seek(0, System.IO.SeekOrigin.Begin);
            //用信号通知 BitmapImage 初始化开始            
            bitmapImage.BeginInit();
            //获取或设置 BitmapImage 的流的源。         
            bitmapImage.StreamSource = imageStream;
            //用信号通知 BitmapImage 初始化结束           
            bitmapImage.EndInit();
            //将照片显示在 Image 框中  
            Format.Source = bitmapImage;

谢谢收看!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: WPF DataGrid 的图片显示可以通过在 DataGrid 的列定义中添加 Image 类型的列来实现。这个 Image 列需要指定宽度和高度以确保图片可以正确地显示在 DataGrid 中。可以在 Image 列中使用 DataTrigger 来绑定数据并显示不同的图片。 另外,还可以使用 Converter 来将绑定数据转换为图片路径,然后在 Image 列中使用该路径来显示图片。这种方法可以用于将绑定数据转换为不同的图片格式,同时也可以用于异步加载图片,避免 UI 在加载大量图片时出现卡顿情况。 虽然 WPF DataGrid 可以很容易地显示图片,但是在使用图片时需要注意一些问题。对于大量图片的情况,应该考虑使用虚拟化以避免内存不足情况。同时,如果需要对图片进行处理或编辑,则应该先将图片加载到内存中,处理完后再保存回磁盘。 总之,WPF DataGrid 可以很方便地实现图片显示功能,但在使用时需要考虑到一些细节问题。 ### 回答2: WPF(Windows Presentation Foundation)是Windows操作系统的图形用户界面(GUI)框架,它提供了许多UI控件来帮助开发者创建各种功能强大的应用程序。其中,DataGrid控件是WPF中非常重要的一个控件,它允许开发者将数据以表格形式呈现出来,方便用户进行查看、编辑或删除等操作。 在使用DataGrid控件时,有时需要在表格中显示图片。为了实现这一功能,开发者需要对DataGrid控件进行相应的配置。首先,开发者需要在DataGrid控件中添加一个列并将其类型设置为“DataGridTemplateColumn”,该列将用于显示图片。其次,开发者需要在该列中添加一个控件(如Image控件)并绑定该控件的源路径(如图片文件路径或是绑定到ViewModel中的属性)。 接下来,开发者可以编写代码来加载图片并将其显示到DataGrid控件中。例如,开发者可以使用C#代码中的BitmapImage类来加载图片。代码如下: BitmapImage bitmapImage = new BitmapImage(); bitmapImage.BeginInit(); bitmapImage.UriSource = new Uri("图片路径"); bitmapImage.EndInit(); 最后,将其赋值给Image控件的Source属性即可实现在DataGrid控件中显示图片。例如: <img src="[image source]" /> 总之,使用WPF中的DataGrid控件可以很方便地在UI中展示数据,而添加图片也不复杂。开发者只需要了解DataGrid控件的基本用法和绑定方式,掌握相关的代码编写技巧,就可轻松在WPF应用程序中呈现各种类型的数据和图片。 ### 回答3: WPF(DataGrid)是一款功能强大的应用程序开发框架,可以用于创建图形用户界面和多媒体内容。其中,DataGrid是WPF中数据网格控件的一种,具有显示和编辑数据的能力,我们可以使用DataGrid来展示数据、绑定数据、编辑数据和排序数据等操作。 在WPF(DataGrid)中,图片的表现形式也可以通过DataGrid中的行模板来展示。我们可以在DataGrid中的其中一列中添加一个Image控件,然后将图片绑定到该Image控件中,实现数据与图片的绑定。 其中,图片可以通过BitmapImage类进行实现,我们可以使用BitmapImage类来读取图片文件,然后将图片绑定到DataGrid的一列中。CodeBehind中的代码如下: ``` // 定义一个BitmapImage,用于读取图片 BitmapImage bm = new BitmapImage(); // 设置图片路径 bm.BeginInit(); bm.UriSource = new Uri(@"路径"); bm.EndInit(); // 将图片绑定到DataGrid上 ImageColumn.SetValue(DataGrid.CellTemplateSelectorProperty, bm); ``` 通过以上代码,我们可以在WPF(DataGrid)中实现图片的展示和绑定,让我们的应用更为美观和实用,提升用户体验和使用效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值