《wpf/XAML--基于wpf修改图片》

博客主要介绍了在WPF中修改服务器上图片的方法。由于没有直接修改图片的函数,需先获取并删除原图片,再新增新图片。展示了显示图片的代码,还说明了将图片转换为字节流传输到服务器进行修改,以及数据回填和服务器端转换字节流等操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

修改图片,没有函数可以直接修改图片的,不像修改字段那样,可以使用一个函数直接修改,
我们的图片存在于服务器上,我们修改图片就是获取原来的图片,删除原来的图片,然后,在新增新的图片,这样我们就需要使用delete函数,而且使用删除之前需要释放图片资源,往往我们在wpf中使用BitmapImage函数显示图片的时候没有释放资源,就是删除不了的哦:
显示图片使用下面的代码:
images = GetImage(myPictureByte);
public static BitmapImage GetImage(string imagePath)
{
BitmapImage bitmap = new BitmapImage();

        if (File.Exists(imagePath))
        {
            bitmap.BeginInit();
            bitmap.CacheOption = BitmapCacheOption.OnLoad;

            using (Stream ms = new MemoryStream(File.ReadAllBytes(imagePath)))
            {
                bitmap.StreamSource = ms;
                bitmap.EndInit();
                bitmap.Freeze();
            }
        }

        return bitmap;
    }

我下面显示图片的代码使用了判断,我提前在服务器中存在了一张图片:
通过服务器那边返回的路径加上图片名,作为没有图片时显示的提示图片;
在这里插入图片描述
下面是去服务器修改图片图片:
我们已经用 List<byte[]> lstBytes = new List<byte[]>();
接收了图片,我们也是获取到图片转换成字节流,然后传输过去服务器
int staff_id = (int)dgv.Row[“staff_id”];
byte[][] picture = new byte[lstBytes.Count][];
var length = 0;
for (int i = 0; i < lstBytes.Count; i++)
{
picture[i] = lstBytes[i];
length = lstBytes[0].Length;
}
下面是去服务器修改图片图片:
我们已经用 List<byte[]> lstBytes = new List<byte[]>();
接收了图片,我们也是获取到图片转换成字节流,然后传输过去服务器
int staff_id = (int)dgv.Row[“staff_id”];
byte[][] picture = new byte[lstBytes.Count][];
var length = 0;
for (int i = 0; i < lstBytes.Count; i++)
{
picture[i] = lstBytes[i];
length = lstBytes[0].Length;
}
在这里插入图片描述
然后我们在数据回填的时候,使用下面代码去接收一个值,然后我们等下吧数值传输过去服务器需要
strOldPath = dgv.Row[“Picture”].ToString();
同时,我们在还有获取到页面的图片的值,这个图片的名称不重要的,只是为了验证图片存在不存在
strNewPath = txt_Load.Text.ToString();
然后我们来到服务器:
在这里插入图片描述
在服务器中通过另一个方法转换一下图片的字节流:
//文件流转换+替换文件
private string IOSwitchPathTwo(byte[][] bytepicture,string strOldPath, string strNewPath) {

        if (strOldPath != "" && strOldPath != strNewPath)
        {
            System.IO.File.Delete(System.AppDomain.CurrentDomain.BaseDirectory + "image\\" + strOldPath);
                //Delete 不删除为正常 I/O 打开的文件或已在内存中映射的文件。
        }
        return IOSwitchPath(bytepicture);

    }
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/20190507181347352.)

这样就可以完成修改图片了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值