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来创建。

相关推荐
武子康9 小时前
调查研究-198 Agent 到底该记住什么?读懂《What Must Generalist Agents Remember?》
人工智能·openai·agent
aqi0010 小时前
15天学会AI应用开发(九)利用Chroma持久化向量数据
人工智能·python·大模型·ai编程·ai应用
武子康11 小时前
调查研究-197 FAISS vs Elasticsearch 全面对比:从向量检索、全文搜索到 RAG 选型指南
人工智能·elasticsearch·agent
青禾网络12 小时前
Web 前端如何接入 AI 音效生成:从零到可用的完整方案
人工智能·设计模式
用户2527362781412 小时前
【技术实战】用 Spring Boot + Vue3 + LM Studio 在本地跑通 RAG 知识库
人工智能
用户51914958484512 小时前
VBScript随机数生成器内部机制:从时间种子到密码令牌破解
人工智能·aigc
米小虾12 小时前
Context Engineering —— 知识与记忆的窗口
人工智能·agent
IT_陈寒12 小时前
Python里这个赋值坑,连老司机都能翻车
前端·人工智能·后端
Shockang1 天前
AI 设计工作流全景拆解:Figma MCP / Claude Design / Codex / Google Stitch
人工智能