当QCustomplot上有两条以上的曲线,怎么实现点击某一条曲线就查看这条曲线上的点呢?
效果如图:
可以分成两步解决
首先是要能查看一条曲线的点,这个qcustomplot有专门的一个QCPItemTracer类来实现。
鼠标移动实现只需重写mouseMoveEvent事件即可,
然后是要实现多条曲线选中某一条,QCustomplot也给出了实现方法:
setInteractions(QCP::iSelectPlottables);//设置曲线可选
在鼠标移动事件中加入曲线选择判断条件,并通过setGraph函数将锚点和曲线连接起来即可。
头文件:
protected:
virtual void mouseMoveEvent(QMouseEvent *event);
private:
QCPItemTracer *tracer;
构造函数中:
tracer = new QCPItemTracer(this);
tracer->setInterpolating(false);
tracer->setStyle(QCPItemTracer::tsCircle);
tracer->setPen(QPen(Qt::red));
tracer->setBrush(Qt::red);
tracer->setSize(6);
setInteractions(QCP::iSelectPlottables);
mouseMoveEvent事件中:
QCPGraph *mGraph = graph(0);
//得到锚点的像素坐标
QPointF temp = tracer->position->coords();
//将像素点转换成qcustomplot中的坐标值,并通过setGraphKey将锚点值设为真实数据值。
tracer->setGraphKey(xAxis->pixelToCoord(event->pos().x()));
//遍历曲线
for (int i = 0; i < graphCount(); ++i)
{
//判断哪一条曲线被选中
if(graph(i)->selected())
{
//显示锚点
tracer->setVisible(true);
mGraph = graph(i);
//显示tip框
QToolTip::showText(event->globalPos(), tr(
"<h4>%L1</h4>"
"<table>"
"<tr>"
"<td><h5>X: %L2</h5></td>" "<td> , </td>" "<td><h5>Y: %L3</h5></td>"
"</tr>"
"</table>").arg(mGraph->name()).
arg( QString::number( temp.x(), 'g' ) )
.arg( QString::number( temp.y(), 'g' ) ),
this, this->rect());
break;
}
else
{
//没有曲线被选中,不显示锚点
tracer->setVisible(false);
}
}
//将锚点设置到被选中的曲线上
tracer->setGraph(mGraph);
//重绘
replot();