使用WPF调用Python进行图像灰度处理

1. 前言

在本文中,我们将通过WPF应用程序调用Python脚本进行图像灰度处理。我们将使用Python的OpenCV库来处理图像,并将其转换为灰度图像,然后通过WPF界面来启动Python进程并展示结果。

2. 准备工作

在开始之前,请确保系统已经安装了Python和.NET SDK,并且已经安装了Python的OpenCV库。

可以通过以下命令安装OpenCV库:

bash 复制代码
pip install opencv-python

3. 编写Python脚本

在项目目录下创建一个新的Python脚本文件image_processing.py,并编写以下代码:

python 复制代码
import cv2
import sys

def convert_to_grayscale(image_path, output_path):
    # 读取图像
    image = cv2.imread(image_path)
    # 将图像转换为灰度
    gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
    # 保存灰度图像
    cv2.imwrite(output_path, gray_image)

if __name__ == "__main__":
    if len(sys.argv) != 3:
        print("Usage: python image_processing.py <input_image_path> <output_image_path>")
    else:
        input_image_path = sys.argv[1]
        output_image_path = sys.argv[2]
        convert_to_grayscale(input_image_path, output_path)

这个脚本将读取输入图像,将其转换为灰度图像,并将结果保存到指定的输出路径。

测试输入指令

csharp 复制代码
python image_processing.py "C:\Users\Lenovo\Desktop\Snipaste_2024-06-21_23-20-30.png" "C:\Users\Lenovo\Desktop\output.jpg"

可以正常运行。

4. 创建WPF项目

首先,创建一个新的WPF应用程序:使用dotnet cli命令

bash 复制代码
dotnet new wpf -n WpfImageProcessingApp
cd WpfImageProcessingApp

4.1 设计WPF界面

打开MainWindow.xaml文件,设计一个简单的界面,包括两个按钮和一个图像展示控件:

xml 复制代码
<Window x:Class="WpfImageProcessingApp.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:WpfImageProcessingApp"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid>
<Button x:Name="SelectImageButton" Content="Select Image" HorizontalAlignment="Left" VerticalAlignment="Top" Width="100" Margin="10" Click="SelectImageButton_Click"/>
        <Button x:Name="ProcessImageButton" Content="Process Image" HorizontalAlignment="Left" VerticalAlignment="Top" Width="100" Margin="120,10,0,0" Click="ProcessImageButton_Click"/>
        <Image x:Name="ImageDisplay" HorizontalAlignment="Left" VerticalAlignment="Top" Width="500" Height="250" Margin="10,50,0,0"/>
    </Grid>
</Window>

4.2 编写WPF代码

MainWindow.xaml.cs文件中,编写以下代码:

csharp 复制代码
using System;
using System.Diagnostics;
using System.Windows;
using Microsoft.Win32;
using System.IO;
using System.Windows.Media.Imaging;

namespace WpfImageProcessingApp
{
    public partial class MainWindow : Window
    {
        private string selectedImagePath;
        private string outputImagePath;

        public MainWindow()
        {
            InitializeComponent();
        }

        private void SelectImageButton_Click(object sender, RoutedEventArgs e)
        {
            OpenFileDialog openFileDialog = new OpenFileDialog();
            openFileDialog.Filter = "Image files (*.jpg, *.jpeg, *.png) | *.jpg; *.jpeg; *.png";

            if (openFileDialog.ShowDialog() == true)
            {
                selectedImagePath = openFileDialog.FileName;
                ImageDisplay.Source = new BitmapImage(new Uri(selectedImagePath));
            }
        }

        private void ProcessImageButton_Click(object sender, RoutedEventArgs e)
        {
            if (string.IsNullOrEmpty(selectedImagePath))
            {
                MessageBox.Show("Please select an image first.");
                return;
            }

            outputImagePath = Path.Combine(Path.GetDirectoryName(selectedImagePath), "output.jpg");

            var startInfo = new ProcessStartInfo
            {
                FileName = "python",
                Arguments = $"image_processing.py \"{selectedImagePath}\" \"{outputImagePath}\"",
                RedirectStandardOutput = true,
                UseShellExecute = false,
                CreateNoWindow = true
            };

            try
            {
                using (var process = Process.Start(startInfo))
                {
                    process.WaitForExit();

                    if (process.ExitCode == 0)
                    {
                        ImageDisplay.Source = new BitmapImage(new Uri(outputImagePath));
                    }
                    else
                    {
                        MessageBox.Show("An error occurred during image processing.");
                    }
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show($"An error occurred: {ex.Message}");
            }
        }
    }
}

4.3 运行应用程序

运行WPF应用程序。点击"Select Image"按钮选择一张图像,

然后点击"Process Image"按钮进行灰度处理,处理后的图像将显示在界面上。

5. 总结

在本文中,我们展示了如何通过WPF应用程序调用Python脚本进行图像灰度处理。通过使用Python的OpenCV库进行图像处理,并通过启动Python进程来执行Python脚本和展示结果,我们实现了一个跨语言的图像处理应用。这一技术可以应用于各种需要结合C#和Python优势的图像处理项目中。

相关推荐
半盏茶香2 分钟前
C语言勘破之路-最终篇 —— 预处理(下)
c语言·开发语言·c++·算法
时雨h2 分钟前
30天面试打卡计划 2024-12-25 26 27 面试题
java·开发语言·数据库
别致的影分身1 小时前
Linux 线程池
java·开发语言·jvm
CM莫问1 小时前
tokenizer、tokenizer.encode、tokenizer.encode_plus比较
人工智能·python·深度学习·语言模型·大模型·tokenizer·文本表示
web135085886352 小时前
Python毕业设计选题:基于python的白酒数据推荐系统_django+hive
python·django·课程设计
山山而川粤3 小时前
母婴用品系统|Java|SSM|JSP|
java·开发语言·后端·学习·mysql
云空4 小时前
《解锁 Python 数据分析的强大力量》
python·数据挖掘·数据分析
迷失蒲公英4 小时前
XML与Go结构互转实现(序列化及反序列化)
xml·开发语言·golang
测试盐4 小时前
c++编译过程初识
开发语言·c++
MUTA️5 小时前
专业版pycharm与服务器连接
人工智能·python·深度学习·计算机视觉·pycharm