OpenCvSharp从入门到实践-(06)创建图像

目录

1、创建图像

1.1实例1-创建黑色图像

1.2实例2-创建白色图像

1.3实例3-创建随机像素的雪花点图像

2、图像拼接

2.1水平拼接图像

2.2垂直拼接图像

2.3实例4-垂直和水平两种方式拼接两张图像


在OpenCV中,黑白图像其实就是一个二维数组,彩色图像就是一个三位数组。数组中的每个元素就是图像中对应位置的像素值。

1、创建图像

在黑白图像中,像素值为0表示纯黑色,像素值为255表示纯白色

1.1实例1-创建黑色图像

创建一个100行、200列(即宽200、高100)的黑色图像,代码如下:

int width = 200;

int height = 100;

Mat img = Mat.Zeros(height, width, MatType.CV_8UC1);

Cv2.ImShow("img", img);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

效果

方式二,效果同上,代码如下:

int width = 200;

int height = 100;

int[] array = new int[200 * 100];

Mat img = new Mat(height, width, MatType.CV_8UC1, array);

Cv2.ImShow("img", img);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

1.2实例2-创建白色图像

创建白色图像有多种方式:

第一种:利用Mat构造函数直接创建;

第二种:利用Mat.Ones方法创建一个像素值为1的图像,然后将图像中所有像素值乘以255;

第三种:创建一个所有值都为255的数组,利用数组创建图像;

第四种:利用SetTo方法;

第一种代码如下:

int width = 200;

int height = 100;

Mat img = new Mat(new Size(width, height), MatType.CV_8UC1, Scalar.White);

Cv2.ImShow("img", img);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

第二种代码如下:

int width = 200;

int height = 100;

Mat img = Mat.Ones(height, width, MatType.CV_8UC1) * 255;

Cv2.ImShow("img", img);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

第三种代码如下:

int width = 200;

int height = 100;

byte[] array = new byte[width* height]; // 定义了长度为width* height的数组

for (int i = 0; i < array.Length; i++)

{

array[i] = 255; // 将每个元素赋值为255

}

Mat img = new Mat(height, width, MatType.CV_8UC1, array);

Cv2.ImShow("img", img);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

第四种代码如下:

int width = 200;

int height = 100;

Mat img = new Mat(new Size(width, height), MatType.CV_8UC1);

img.SetTo(new Scalar(255, 255, 255)); // 将背景设置为白色

Cv2.ImShow("img", img);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

效果:

1.3实例3-创建随机像素的雪花点图像

代码如下:

int width = 200;

int height = 100;

Mat img = new Mat(height, width, MatType.CV_8UC1);

Random random = new Random();

for (int i = 0; i < height; i++)

{

for (int j = 0; j < width; j++)

{

byte blue = (byte)(random.NextDouble() * 256);

byte green = (byte)(random.NextDouble() * 256);

byte red = (byte)(random.NextDouble() * 256);

Vec3b color = new Vec3b((byte)blue, (byte)green, (byte)red);

img.At<Vec3b>(i, j) = color;

}

}

Cv2.ImShow("img", img);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

效果:

改变一行代码,创建彩色的随机图像,代码如下:

int width = 200;

int height = 100;

Mat img = new Mat(height, width, MatType.CV_8UC3);

Random random = new Random();

for (int i = 0; i < height; i++)

{

for (int j = 0; j < width; j++)

{

byte blue = (byte)(random.NextDouble() * 256);

byte green = (byte)(random.NextDouble() * 256);

byte red = (byte)(random.NextDouble() * 256);

Vec3b color = new Vec3b((byte)blue, (byte)green, (byte)red);

img.At<Vec3b>(i, j) = color;

}

}

Cv2.ImShow("img", img);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

效果:

2、图像拼接

OpenCvSharp中提供Cv2.HConcat、Cv2.VConcat方法实现图像拼接。

2.1水平拼接图像

Cv2.HConcat方法可以对图像进行水平拼接(或者叫横向拼接),其函数如下:

public static void HConcat(IEnumerable<Mat> src, OutputArray dst)

说明:

摘要:

Applies horizontal concatenation to given matrices.

参数:

src:

input array or vector of matrices. all of the matrices must have the same number

of rows and the same depth.

dst:

output array. It has the same number of rows and depth as the src, and the sum

of cols of the src.

2.2垂直拼接图像

Cv2.VConcat可以对图像进行垂直拼接(或者叫纵向拼接),其函数如下:

public static void VConcat(IEnumerable<Mat> src, OutputArray dst)

说明:

摘要:

Applies vertical concatenation to given matrices.

参数:

src:

input array or vector of matrices. all of the matrices must have the same number

of cols and the same depth.

dst:

output array. It has the same number of cols and depth as the src, and the sum

of rows of the src.

2.3实例4-垂直和水平两种方式拼接两张图像

代码如下:

Mat mat = Cv2.ImRead("test01.jpg");

Cv2.ImShow("src", mat);

Mat dst = new Mat();

Cv2.VConcat(new Mat[] { mat, mat }, dst);

Cv2.ImShow("img_v", dst);

Cv2.HConcat(new Mat[] { mat, mat }, dst);

Cv2.ImShow("img_h", dst);

Cv2.WaitKey();

Cv2.DestroyAllWindows();

效果:

相关推荐
xrgs_shz23 分钟前
基于MATLAB的证件照片背景变换实例
图像处理·计算机视觉·matlab
razelan23 分钟前
第一例:石头剪刀布的机器学习(xedu,示例15)
人工智能·机器学习
一条星星鱼41 分钟前
从0到1:如何用统计学“看透”不同睡眠PSG数据集的差异(域偏差分析实战)
人工智能·深度学习·算法·概率论·归一化·睡眠psg
TMT星球1 小时前
TCL华星t8项目正式开工,总投资额约295亿元
大数据·人工智能
猫头虎1 小时前
DeepSeek刚刚开源了一个3B的 OCR模型:什么是DeepSeek-OCR?单张A100-40G每天可以处理20万+页文档
人工智能·开源·whisper·prompt·aigc·ocr·gpu算力
lky不吃香菜1 小时前
上下文工程的艺术与科学:来自 LangChain 和 Manus 的前沿洞察
人工智能
香菜烤面包1 小时前
Attention:MHA->MQA->GQA->MLA
人工智能·深度学习
阿里云大数据AI技术1 小时前
云栖实录 | 驶入智驾深水区:广汽的“数据突围“之路
大数据·人工智能
肥晨1 小时前
OCR 模型受全球关注,实测到底谁更出色?
人工智能·ai编程
景天科技苑1 小时前
【AI智能体开发】什么是LLM?如何在本地搭建属于自己的Ai智能体?
人工智能·llm·agent·智能体·ai智能体·ollama·智能体搭建