WPF图像处理之像素操作

文章目录

WPF Image控件的初步使用

框架准备

为了演示C#中的图像处理功能,先在xaml中导入一张图片,并且预留出一个WrapPanel,用于存放操作按钮。

xml 复制代码
<TabControl TabStripPlacement="Left">
    <TabItem Header="Bitmap 学习">
        <DockPanel LastChildFill="True" >
            <WrapPanel DockPanel.Dock="Right" Width="150" Background="#EEEEEE">
            </WrapPanel>
            <Image Margin="10"
                x:Name="img" Source="E:\Pictures\test.jpeg"/>
        </DockPanel>
    </TabItem>

</TabControl>

整体框架如下

图像转灰度

转灰度往往是图像处理的第一步,其实质是将图像转换为矩阵,从而便于进行像素操作。wpf提供了非常方便的格式转换类,下面新建一个按钮,绑定下面的函数,即可实现图像转灰度的功能

csharp 复制代码
Bitmap bmp = new BitmapImage(new Uri(@"E:\Pictures\test.jpeg"));
private void btnGray_Click(object sender, RoutedEventArgs e)
{
    img.Source = new FormatConvertedBitmap(bmp, PixelFormats.Gray8, null, 0);
}

其中,FormatConvertedBitmap用于图像格式转换,其输入的4个参数分别是输入图像,图像格式,调色盘以及透明度。由于其继承自BitmapSource,故而可以直接绑定至img.Source中。

点击按钮后,结果如下

像素操作

在转为灰

度之后,图像仍旧以对象的形式存在,而无法直接索引。为此需要新建一个数组,来装载图像的像素,这个数组处理完成后,再把像素值填充进一个新的BitmapSource中。

下面实现一个阈值功能,将灰度值小于128的像素统统置0,实现类似下图的效果

代码如下

cs 复制代码
private void btnPixel_Click(object sender, RoutedEventArgs e)
{
    var src = new FormatConvertedBitmap(bmp, PixelFormats.Gray8, null, 0);
    var h = src.PixelHeight;    // 图像高度
    var w = src.PixelWidth;     // 图像宽度

    var pixels = new byte[h * w];
    src.CopyPixels(pixels, w, 0);
    pixels = pixels.Select(x => x>128 ? x : (byte)0).ToArray();
    img.Source = BitmapSource.Create(w, h, 96, 96,
        PixelFormats.Indexed8, BitmapPalettes.Gray256, pixels, w);
}

其中用到了两个BitmapSource的方法,首先通过CopyPixels将像素赋值给pixels,然后再调用Create来创建。

相关推荐
小陈工2 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
rockey6275 小时前
AScript如何实现中文脚本引擎
c#·.net·script·eval·expression·function·动态脚本
墨染天姬6 小时前
【AI】端侧AIBOX可以部署哪些智能体
人工智能
AI成长日志6 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
2501_948114246 小时前
2026年大模型API聚合平台技术评测:企业级接入层的治理演进与星链4SAPI架构观察
大数据·人工智能·gpt·架构·claude
小小工匠6 小时前
LLM - awesome-design-md 从 DESIGN.md 到“可对话的设计系统”:用纯文本驱动 AI 生成一致 UI 的新范式
人工智能·ui
黎阳之光6 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
小超同学你好7 小时前
面向 LLM 的程序设计 6:Tool Calling 的完整生命周期——从定义、决策、执行到观测回注
人工智能·语言模型
我是唐青枫7 小时前
C#.NET gRPC 深入解析:Proto 定义、流式调用与服务间通信取舍
开发语言·c#·.net
智星云算力7 小时前
本地GPU与租用GPU混合部署:混合算力架构搭建指南
人工智能·架构·gpu算力·智星云·gpu租用