接上一篇文章中,利用opencl-buffer灰度化图像以外,还可以使用image2D进行操作。
本文利用opencv读取一张jpg图像,将数据传入opencl-image2D中,使用kernel快速灰度化图像,并且保存输出图像到本地。
首先读取和保存图像接口:
1.data_io.h
#include <opencv2/opencv.hpp>
#include <opencv2/highgui.hpp>
#ifdef APPLE //平台相关代码
#include <OpenCL/cl.h>
#else
#include <CL/cl.h>
#endif
cl_int Load_image2D_by_opencv(const char * filename,cl_mem *imageObjects,cl_context context,int &h,int &w);
void Show_pic_by_opencv(unsigned char *rd);
2.data_io.cpp
#include "data_io.h"
cv::Mat srcImage,dst_Image;
cl_int Load_image2D_by_opencv(const char * filename,cl_mem *imageObjects,cl_context context,int &img_h,int &img_w)
{
//3.加载图像
cl_int errNum;
srcImage = cv::imread(filename);
img_h = srcImage.rows;
img_w = srcImage.cols;
dst_Image= cv::Mat(srcImage.size(), srcImage.type());
u_char *rd = new u_char[img_h* img_w *4];
memcpy(rd, static_cast<u_char*>(srcImage.data), img_h* img_w *3);//转化函数,注意Mat的data成员
// 创建OpenCL图像对象
cl_image_format clImageFormat;//图像格式属性
clImageFormat.image_channel_order = CL_RGBA;
clImageFormat.image_channel_data_type = CL_UNORM_INT8;
imageObjects[0] = clCreateImage2D(context,
CL_MEM_READ_ONLY | CL_MEM_COPY_HOST_PTR,
&clImageFormat,
img_w,
img_h,
0,
rd,
&errNum);
std::cerr << "L4.2" <<std::endl;
return errNum;
}
void Show_pic_by_opencv(u_char *rd)
{
dst_Image = cv::Mat(dst_Image.rows, dst_Image.cols, dst_Image.type(), (void *)rd); //h_,w_是图像长宽
cv::imwrite("../data/des_img/00grayImage.jpg", dst_Image);
}
其次,主函数:
3.main.cpp
#include <iostream>
#include <fstream>
#include <sstream>
#ifdef APPLE //平台相关代码
#include <OpenCL/cl.h>
#else
#include <CL/cl.h>
#endif
#include "data_io.h"
//在第一个平台中创建只包括GPU的上下文
cl_context CreateContext()
{
cl_int errNum;
cl_uint numPlatforms;
cl_platform_id firstPlatformId;
cl_context context = NULL;
// 选择第一个平台
errNum = clGetPlatformIDs(1, &firstPlatformId, &numPlatforms);
if (errNum != CL_SUCCESS || numPlatforms <= 0)
{
std::cerr << "Failed to find any OpenCL platforms." << std::endl;
return NULL;
}
// 接下来尝试通过GPU


1万+

被折叠的 条评论
为什么被折叠?



