QT开发中文网

qt绘制折线图

在Qt中,你可以使用QPainter和QWidget来绘制折线图。下面是一个简单的示例代码:

#include <QtWidgets>

class LineChartWidget : public QWidget {
public:
    LineChartWidget(QWidget *parent = nullptr) : QWidget(parent) {}

protected:
    void paintEvent(QPaintEvent *) override {
        QPainter painter(this);
        
        // 绘制背景
        painter.fillRect(rect(), Qt::white);
        
        // 数据点坐标
        QVector<QPointF> dataPoints;
        dataPoints.append(QPointF(0, 100));
        dataPoints.append(QPointF(50, 200));
        dataPoints.append(QPointF(100, 150));
        // 添加更多数据点
        
        // 找到最小和最大的x、y值
        qreal minX = std::numeric_limits<qreal>::max();
        qreal maxX = std::numeric_limits<qreal>::min();
        qreal minY = std::numeric_limits<qreal>::max();
        qreal maxY = std::numeric_limits<qreal>::min();
        
        for (const QPointF &point : dataPoints) {
            minX = qMin(minX, point.x());
            maxX = qMax(maxX, point.x());
            minY = qMin(minY, point.y());
            maxY = qMax(maxY, point.y());
       }
       
       // 将坐标映射到绘图区域
       const int margin = 20; // 边距
       QRectF plotArea(margin, margin,
                       width() - margin * 2,
                       height() - margin * 2);
                       
       QTransform transform;
       transform.scale(plotArea.width() / (maxX - minX),
                       -plotArea.height() / (maxY - minY));
       transform.translate(-minX, -maxY);
       
       // 绘制坐标轴
       painter.setPen(Qt::black);
       painter.drawLine(plotArea.left(), 0,
                        plotArea.right(), 0); // x轴
       painter.drawLine(0, plotArea.top(),
                        0, plotArea.bottom()); // y轴
                       
        // 绘制折线图
        QPolygonF polyline;
        for (const QPointF &point : dataPoints) {
            polyline.append(transform.map(point));
        }
        
        painter.setPen(Qt::blue);
        painter.drawPolyline(polyline);
    }
};

int main(int argc, char *argv[]) {
    QApplication app(argc, argv);
    
    LineChartWidget widget;
    widget.show();
    
    return app.exec();
}

这是一个简单的绘制折线图的示例,你可以根据自己的需求修改和扩展它。在dataPoints中添加更多数据点,根据实际情况调整绘图区域、颜色等。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://qt.0voice.com/?id=9224

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?