当前位置: 技术问答>linux和unix
利用QT画实时曲线,大家有什么好办法!
来源: 互联网 发布时间:2017-04-05
本文导语: 最近正在搞一个项目,在嵌入式设备上接收串口发来的数据,并将数据用QT显示为动态的实时曲线。 收发数据没什么问题,画曲线也能画,可是这个实时曲线是怎么个画法,有点不知道怎么入手 实时曲线一般是y轴表...
最近正在搞一个项目,在嵌入式设备上接收串口发来的数据,并将数据用QT显示为动态的实时曲线。
收发数据没什么问题,画曲线也能画,可是这个实时曲线是怎么个画法,有点不知道怎么入手
实时曲线一般是y轴表示时间,x轴表示数据,曲线应该从右到左画出来,坐标轴也要随时间变化而变化
求助了qwt插件结果相关资料太少,而且qwt的例子都没有注释很难看懂。正在看assistant英文文档,但是也没有类似的例子,看看大家有没有兴趣帮忙提供个思路。
我自己的思路是将从串口得到的数据放入一个环形队列中,每隔一秒钟刷新下绘图窗口从又向左划线,环形队列的大小和绘图窗口的宽度一致,这样绘图不会超出边界,可是坐标怎么变没有想好。
各位老师有兴趣帮忙看看,谢谢了。
收发数据没什么问题,画曲线也能画,可是这个实时曲线是怎么个画法,有点不知道怎么入手
实时曲线一般是y轴表示时间,x轴表示数据,曲线应该从右到左画出来,坐标轴也要随时间变化而变化
求助了qwt插件结果相关资料太少,而且qwt的例子都没有注释很难看懂。正在看assistant英文文档,但是也没有类似的例子,看看大家有没有兴趣帮忙提供个思路。
我自己的思路是将从串口得到的数据放入一个环形队列中,每隔一秒钟刷新下绘图窗口从又向左划线,环形队列的大小和绘图窗口的宽度一致,这样绘图不会超出边界,可是坐标怎么变没有想好。
各位老师有兴趣帮忙看看,谢谢了。
|
以下是伪代码,未经过测试,性能也不一定好,仅供参考,欢迎大家批评指正;
//屏幕像素1024*800
//每秒之间为3个像素宽度
//时间坐标的像素范围:(293,0)到(293,300) ;在该行画直线,
//画尺子上的那种刻度,为10秒的整数时从纵向画4个像素,否则画2个像
//即整10秒从294行画到297,否则从294行画到295,其中Y轴保持不变
//文字所在的行:(300,0)到(300,300);在该行打印时间HH:MM:SS
//每个时间HH:MM:SS从其对应的整点刻度向左偏移15个像素位置
//上面的偏移值需要程序运行之后调整,以便看起来时间正好位于整点刻度的下方
#define RING_BUFFER_SIZE = 101; //环形缓冲队列的大小,记录最近的101个采样记录
#define PRINT_INTERVAL = 10 //每10秒打印一个时间
#define OFF_SET = 15; //时间文字的偏移值
long start_time; //第一个采样点对应的系统时间,格式为HHMMSS
long sampling_count //记录已经采样的点的个数
long compute_time(long start_time, int i)
{
long second = 0,
min = 0,
hour = 0;
if (sample_count == 1) return start_time;
hour = start_time / 10000;
min = start_time % 10000 / 100;
second = start_time % 100;
second += i;
hour += second / 3600;
min += second % 3600 / 60;
second = second % 60;
return hour*10000+min*100+second;
}
void print_at(int y, int x,long time)
{
//OFF_SET需要调节,使得文字位于刻度正下方
draw_txt(y, x-OFF_SET, "%d:%d:%d", time/10000, (time%10000)/100, time%100);
return;
}
void print_time_axis()
{
if (sampling_count
//屏幕像素1024*800
//每秒之间为3个像素宽度
//时间坐标的像素范围:(293,0)到(293,300) ;在该行画直线,
//画尺子上的那种刻度,为10秒的整数时从纵向画4个像素,否则画2个像
//即整10秒从294行画到297,否则从294行画到295,其中Y轴保持不变
//文字所在的行:(300,0)到(300,300);在该行打印时间HH:MM:SS
//每个时间HH:MM:SS从其对应的整点刻度向左偏移15个像素位置
//上面的偏移值需要程序运行之后调整,以便看起来时间正好位于整点刻度的下方
#define RING_BUFFER_SIZE = 101; //环形缓冲队列的大小,记录最近的101个采样记录
#define PRINT_INTERVAL = 10 //每10秒打印一个时间
#define OFF_SET = 15; //时间文字的偏移值
long start_time; //第一个采样点对应的系统时间,格式为HHMMSS
long sampling_count //记录已经采样的点的个数
long compute_time(long start_time, int i)
{
long second = 0,
min = 0,
hour = 0;
if (sample_count == 1) return start_time;
hour = start_time / 10000;
min = start_time % 10000 / 100;
second = start_time % 100;
second += i;
hour += second / 3600;
min += second % 3600 / 60;
second = second % 60;
return hour*10000+min*100+second;
}
void print_at(int y, int x,long time)
{
//OFF_SET需要调节,使得文字位于刻度正下方
draw_txt(y, x-OFF_SET, "%d:%d:%d", time/10000, (time%10000)/100, time%100);
return;
}
void print_time_axis()
{
if (sampling_count
您可能感兴趣的文章:
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。