/*
图像深度转换
像素级访问
测量时间
剪裁图像
*/
#include<opencv2\opencv.hpp>
#include<cv.h>
using namespace cv;
using namespace std;
int main() {
double t = (double)getTickCount();
Mat img_org = imread("D://图片//5.jpg");
Mat img_tem;
Mat tem = Mat(300, 400, CV_8UC1); //创建一个单通道图片
double elapsed;
if (img_org.empty())
cout << "图片加载失败!" << endl;
img_org.convertTo(img_tem, CV_32F); //图像深度转换
randu( tem, 0, 1000); //产生随机值
double maxvalue, minvalue;
Point p1, p2;
minMaxLoc(tem, &minvalue, &maxvalue, &p1, &p2); //只能从单通道中找到最大最小值以及它们的位置
cout << "min_position = " << p1 << endl;
cout << "max_position = " << p2 << endl;
line(tem, p1, p2, 0, 2); //在最大最小值间画一条连线,单色
circle(tem, p1, 155, 0, 2); //画圆观察
Mat result;
img_org.copyTo(result);
Point center(200, 100);
Mat mask(size(img_org), CV_8UC3, Scalar(0,0,0)); //遮罩
circle(mask, center, 150, Scalar(255,255,255), -1); //白色显示黑色不显示,-1表示全部填充
bitwise_and(img_org, mask, result); //三者要有相同的大小,mask要为8-bit单通道
for (int i = 0; i < result.rows; i++) { //用函数ptr访问图中每个像素的值,当mask是黑色时改变result的像素值,使图片脱离出来
Vec3b* pixrow = result.ptr<Vec3b>(i);
Vec3b* pixrow_tem = mask.ptr<Vec3b>(i);
for (int j = 0; j < result.cols; j++) {
if (pixrow_tem[j][0] == 0 && pixrow_tem[j][1] == 0 && pixrow_tem[j][2] == 0) { //当mask的三个通道全为0时,改变其颜色
pixrow[j][0] = 66;
pixrow[j][1] = 55;
pixrow[j][2] = 0;
}
}
}
imshow("show_org", img_org);
imshow("show_tem", img_tem);
imshow("show_randu", tem);
imshow("show_mask", mask);
imshow("show_result", result);
elapsed = ((double)getTickCount() - t) / getTickFrequency(); //单位为秒
cout << "t2 = " << elapsed << endl;
waitKey(0);
destroyAllWindows;
return 0;
}
运行结果: