效果
灰度图
黑白色反转
彩色反转
项目
代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using OpenCvSharp;
using OpenCvSharp.Extensions;
namespace OpenCvSharp_颜色反转
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private string fileFilter = "*.*|*.bmp;*.jpg;*.jpeg;*.tiff;*.tiff;*.png";
Bitmap bmp;
String imgPath = "";
private void button2_Click(object sender, EventArgs e)
{
OpenFileDialog ofd = new OpenFileDialog();
ofd.Filter = fileFilter;
if (ofd.ShowDialog() != DialogResult.OK) return;
imgPath = ofd.FileName;
bmp = new Bitmap(imgPath);
pictureBox1.Image = bmp;
}
private void button1_Click(object sender, EventArgs e)
{
if (imgPath == "")
{
return;
}
Mat mat = new Mat(imgPath);
Cv2.CvtColor(mat, mat, ColorConversionCodes.BGR2GRAY);
Mat dst = new Mat(mat.Height, mat.Width, mat.Type(), Scalar.White);
byte grayPixel = 0;
for (int r = 0; r < dst.Rows; r++)
{
for (int c = 0; c < dst.Cols; c++)
{
grayPixel = mat.At<byte>(r, c);
dst.Set<byte>(r, c, (byte)(255 - grayPixel));
}
}
if (pictureBox2.Image != null)
{
pictureBox2.Image.Dispose();
}
pictureBox2.Image = BitmapConverter.ToBitmap(dst);
}
private void button4_Click(object sender, EventArgs e)
{
if (imgPath == "")
{
return;
}
Mat mat = new Mat(imgPath);
Cv2.CvtColor(mat, mat, ColorConversionCodes.BGR2GRAY);
if (pictureBox2.Image != null)
{
pictureBox2.Image.Dispose();
}
pictureBox2.Image = BitmapConverter.ToBitmap(mat);
}
private void button3_Click(object sender, EventArgs e)
{
if (imgPath == "")
{
return;
}
Mat mat = new Mat(imgPath);
Mat dst = new Mat(mat.Height, mat.Width, mat.Type(), Scalar.White);
Vec3b vec3B;
for (int r = 0; r < dst.Rows; r++)
{
for (int c = 0; c < dst.Cols; c++)
{
vec3B = mat.At<Vec3b>(r, c);
vec3B.Item0 = (byte)(255 - vec3B.Item0);
vec3B.Item1 = (byte)(255 - vec3B.Item1);
vec3B.Item2 = (byte)(255 - vec3B.Item2);
dst.Set<Vec3b>(r, c, vec3B);
}
}
if (pictureBox2.Image != null)
{
pictureBox2.Image.Dispose();
}
pictureBox2.Image = BitmapConverter.ToBitmap(dst);
}
}
}
Demo下载