Qt畫筆實現折線圖


參考:https://www.cnblogs.com/lsgxeva/p/7821550.html
效果圖:

 



void BrokenLine::paintEvent(QPaintEvent *event)
{
    // 折線上的點
    static QList<QPointF> points = QList<QPointF>() << QPointF(10, 40) << QPointF(100, 100) << QPointF(200, 100)
                                                    << QPointF(300, 100) << QPointF(330, 80) << QPointF(350, 70);
 
        
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing, true);
    painter.setPen(QPen(Qt::black, 2));
 
        
    QPainterPath path(points[0]);
    for (int i = 1; i < points.size(); ++i)
    {
        path.lineTo(points[i]);
 
        
    }
 
         
         
        
    // 繪制 path
    painter.drawPath(path);
 
        
 
        
    // 繪制折線上的標記點
    painter.setBrush(Qt::gray);
    int ellipse_size = 4;
    for (int i = 0; i < points.size(); ++i) {
        painter.drawEllipse(points[i], ellipse_size, ellipse_size);
 
        
 
        
        QString text = QString::number(points[i].y());
        QFontMetrics fm = painter.fontMetrics();
        int height_font = fm.height();
        int width_text = fm.width(text);
 
        
        QPointF textPos(points[i].x()-(width_text/2), points[i].y()-(ellipse_size/2)-(height_font/2));
 
        
        painter.drawText(textPos, text);
    }
 
        
 
        
    return QWidget::paintEvent(event);
 
        
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM