用Qt获取到的数据写如文本文件中,然后再用python读取绘制折线图。
最近写一个人眼识别的东西,想实时的查看眼睛坐标的折线图,识别程序是用C++写的,用到了Qt,python的matplotlib看着很强大,就试着用它绘制了图片。
1.Qt写文件操作
首先我把识别的数据写入到文本文件中,用到 Qt写文件操作
,Qt写文件操作还是很方便的,比原生态的C++好用一点。首先需要 include
两个头文件:
#include
#include
然后就直接可以在代码中使用了
QFile f("/home/tairy/Documents/result/9.txt");
if(!f.open(QIODevice::WriteOnly | QIODevice::Text|QIODevice::Append |QIODevice::Truncate)){
cerr << "Open failed." << endl;
}
QTextStream txtOutput(&f);
txtOutput<e_lx<<","<e_ly<
txtOutput<e_rx<<","<e_ry<
txtOutput<np_x<<","<np_y<
txtOutput<ml_x<<","<ml_y<
i++;
f.close();
上面的代码简单的实现了写如的操作,要注意的是linux系统下要对写入的文件给相应的权限,否则写如会失败。
2.python绘制图像
python绘制图像需要 import
一个库
import matplotlib.pyplot as plt
然后就可以使用下面的代码绘制折线图了
plt.plot(nose_times, nose_x, 'o-')#这里的第一个参数是所有点的x轴的一个list,第二个是对应的y轴,第三的参数是绘制的点的属性,像这里的o就表示圆点,后面一条短线表示每个点用线连接。
plt.xlabel('times')
plt.ylabel('nose_x')
plt.title('nose_x-time filgue')
# plt.ylim(390,420)
plt.xlim(i,i+200)
plt.show()
#其他的都意思很明确,就不多解释了。
3.实现实时绘制图片
我的思路就是用一个 while 1:
死循环不停的读取文本文件,这样绘图窗口关闭一次就可以实现图像更新一次,觉得方法还是有点笨,真在努力寻找跟简单的方法,第一次用python绘图,很多东西都的一点点的找!!