使用QSlider

1、当绘制的线性图等需要水平拖动的时候(不用qwt里面的函数),可以用QSlider,代码如下

ui.horizontalSlider->setMaximum(1000);  //需要拖动的越缓慢,平滑它的值就设置得越大
ui.horizontalSlider->setSingleStep(1);  //拖动的最小单位

QObject::connect(ui.horizontalSlider, SIGNAL(valueChanged(int)), this, SLOT(sliderMovedSlot(int))); //在槽函数中改变qwt的横坐标显示范围
QObject::connect(ui.horizontalSlider, SIGNAL(sliderPressed()), this, SLOT(sliderPressSlot()));
QObject::connect(ui.horizontalSlider, SIGNAL(sliderReleased()), this, SLOT(sliderReleaseSlot()));
/*滑条按下*/
void RoadAllData::sliderPressSlot()
{
  SLIDER_RUNNING = true;  //滑条正在拖动,这个时候在添加曲线的点的地方,将不会改变曲线显示的范围(setRange)
  realLeft = ui.customPlot->xAxis->range().lower;    //获取当前显示曲线的窗口的最小横坐标
  realRight = ui.customPlot->xAxis->range().upper;    //最大横坐标
}
/*滑条释放*/
void RoadAllData::sliderReleaseSlot()
{
  SLIDER_RUNNING = false;  //滑条停止滑动
  if (!FILEOPENING)//不是打开数据库,而是实时更新的状态
 {
    ui.horizontalSlider->setValue(ui.horizontalSlider->maximum());
  }    
}
/*滑条滑动响应的槽函数*/
void RoadAllData::sliderMovedSlot(int value)
{
  if (FILEOPENING)
  {
    double min = graphData[0][0];
    
double max = graphData[0][graphData[0].size() - 1];
    
double left = 0, right = 0;//需要显示在界面的范围
    double tmp = 0;
    
//获取left、right
    if (UP_LINE_WAY)
    {
      tmp
= value / (ui.horizontalSlider->maximum()*1.0) * (abs(max - min)) + min;
      left
= tmp;
      right
= tmp+0.3;
    }
    
else
    {
      tmp
= min - value / (ui.horizontalSlider->maximum()*1.0) * (abs(max - min));
      left
= tmp;
      right
= tmp - 0.3;
    }
    
//qDebug() << left << right <<" "<< min << max;
    
//设置显示范围
    ui.qwtPlot->xAxis->setRange(left, right);
    ui.qwtPlot
->replot();
  }
}

 

 2、实现qwt动态加载图片的时候,可以拖动水平滚动条查看历史数据(不受数据实时更新的影响)

else//实时
    {
        //获取left、right
        if (UP_LINE_WAY)  //上行,横坐标递增
        {
            tmp = realRight - (ui.horizontalSlider->maximum() - value) / (ui.horizontalSlider->maximum()*1.0) * (realRight-realFirst);//realRight是指qwt曲线当前屏幕range的最大值,realFirst是指曲线的起点
            right = tmp;
            left = tmp - 0.3;    
        }
        else   //下行,横坐标递减
        {
            tmp = realLeft + (ui.horizontalSlider->maximum() - value) / (ui.horizontalSlider->maximum()*1.0) * (realFirst - realLeft);//realLeft指的是当前屏幕range的最大值。
            right = tmp;
            left = tmp + 0.3;
        }
        qDebug() << "left:" << left << "right:" << right<<"value:"<<value;
        //设置显示范围
        ui.customPlot->xAxis->setRange(left, right);
        ui.customPlot->replot();
    }

/*x轴设置反向或者正向*/
ui.customPlot->xAxis->setRangeReversed(true);//x轴反向
ui.customPlot->xAxis->setRangeReversed(false);//x轴正向

 

转载于:https://www.cnblogs.com/xian-yongchao/p/9634685.html

使用 `installEventFilter` 来为 `QSlider` 安装事件过滤器,可以捕获和处理滑块控件的事件。通过事件过滤器,你可以拦截并处理滑块控件的各种事件,例如鼠标点击、滑动等。 下面是一个示例代码,展示如何使用事件过滤器来监听 `QSlider` 的鼠标点击事件: ```cpp #include <QSlider> #include <QEvent> #include <QDebug> class SliderEventFilter : public QObject { Q_OBJECT public: explicit SliderEventFilter(QObject *parent = nullptr) : QObject(parent) {} protected: bool eventFilter(QObject *obj, QEvent *event) override { if (event->type() == QEvent::MouseButtonPress) { QSlider *slider = qobject_cast<QSlider*>(obj); if (slider) { qDebug() << "Slider clicked!"; // 在这里处理滑块点击事件的逻辑 return true; } } return QObject::eventFilter(obj, event); } }; ``` 在上面的示例中,我们创建了一个继承自 `QObject` 的事件过滤器类 `SliderEventFilter`。在 `eventFilter` 方法中,我们首先判断接收到的事件类型是否为鼠标按下事件(`QEvent::MouseButtonPress`),然后使用 `qobject_cast` 将对象转换为 `QSlider` 类型。如果转换成功,说明事件发生在 `QSlider` 上,我们在这里可以处理滑块点击事件的逻辑。 为了使用事件过滤器,你需要在你的代码中安装它: ```cpp QSlider *slider = new QSlider(parent); SliderEventFilter *eventFilter = new SliderEventFilter(slider); slider->installEventFilter(eventFilter); ``` 通过以上步骤,你可以成功使用事件过滤器来监听和处理 `QSlider` 的鼠标点击事件。你可以根据需要在 `eventFilter` 方法中处理其他类型的事件,以实现自定义的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值