如下所示:
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