服务器之家

服务器之家 > 正文

c++ 调用python传输图片实例

时间:2021-08-08 17:11     来源/作者:ShellCollector

如下所示:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#include <Python.h>
 
#include <arrayobject.h>
 
 
 
#include "opencv2/imgcodecs.hpp"
 
#include "opencv2/imgproc.hpp"
 
#include "opencv2/videoio.hpp"
 
#include <opencv2/highgui.hpp>
 
#include <opencv2/video.hpp>
 
#include "opencv2/video/background_segm.hpp"
 
//using namespace std;
 
int init_numpy() {
 
 import_array();
 
}

初始化:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Py_SetPythonHome(L"D:\\Users\\Lenovo\\Anaconda3\\envs\\python35");
 
Py_Initialize();
 
init_numpy();
 
PyRun_SimpleString("import sys");
 
PyRun_SimpleString("sys.path.append('./')");
 
pModule = NULL;
 
pFunc = NULL;
 
pModule =PyImport_ImportModule("demo");
 
pFunc =PyObject_GetAttrString(pModule, "load_model");
 
PyEval_CallObject(pFunc,NULL);

传输代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
cv::Mat img =cv::imread("d:\\1.jpg", CV_LOAD_IMAGE_COLOR);
 
int m, n;
 
n = img.cols *3;
 
m = img.rows;
 
unsigned char *data = (unsigned char*)malloc(sizeof(unsignedchar) * m * n);
 
int p = 0;
 
for (int i = 0; i < m;i++)
 
{
 
 for (int j = 0; j < n; j++)
 
 {
 
  data[p]= img.at<unsignedchar>(i, j);
 
  p++;
 
 }
 
}
 
npy_intp Dims[2]= { m, n }; //给定维度信息
 
PyObject*PyArray = PyArray_SimpleNewFromData(2, Dims, NPY_UBYTE, data);
 
PyObject*ArgArray = PyTuple_New(1);
 
PyTuple_SetItem(ArgArray,0, PyArray);
 
PyObject *pDict= nullptr;
 
pDict =PyModule_GetDict(pModule);
 
PyObject*pFuncFive = PyDict_GetItemString(pDict, "load_image");
 
//PyObject_CallObject(pFuncFive, ArgArray);
 
 
 
PyObject*pReturn = PyObject_CallObject(pFuncFive, ArgArray);
 
int result;
 
PyArg_Parse(pReturn,"i", &result);
 
CString strtemp;
 
strtemp.Format(_T("%d"), result);
 
MessageBox(strtemp);

Python部分:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
importcv2
import numpyas np
 
w=227
h=227
c=3
sess = None
def arrayreset(array):
 # for i inrange(array.shape[1]/3):
 #  pass
 a = array[:,0:len( array[0] -2 ):3]
 b = array[:, 1:len( array[0] - 2 ):3]
 c = array[:, 2:len( array[0] - 2 ):3]
 a = a[:, :, None]
 b = b[:, :, None]
 c = c[:, :, None]
 m = np.concatenate((a,b,c),axis=2)
 return m
def load_model():
 global sess
 sess = tf.Session()
 saver = tf.train.import_meta_graph( './model/model.ckpt.meta')
 saver.restore( sess, tf.train.latest_checkpoint('./model/') )
 
def load_image(image):
 img = arrayreset(image)

其实还可以用imencode来解决:本文尚未完善

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Mat image = imread("d:\\11.jpeg", CV_LOAD_IMAGE_COLOR);
 
 
IplImage iplimage = image;
 
 
vector<uchar> buff;//buffer for coding
 
 
vector<int> param = vector<int>(2);
 
 
param[0] = CV_IMWRITE_JPEG_QUALITY;
 
 
param[1] = 95;//default(95) 0-100
 
imencode(".jpg", image, buff, param);
std::string str_encode(buff.begin(), buff.end());

以上这篇c++ 调用python传输图片实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/jacke121/article/details/78574476

标签:

相关文章

热门资讯

yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部