B样曲线的绘制代码

B样曲线绘制代码。头文件中vector分别储存着控制点和B样曲线的点

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QMouseEvent>
#include <iostream>
#include <cmath>

using namespace std;

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = 0);
    ~Widget();

    void paintEvent(QPaintEvent *event);
    void mousePressEvent(QMouseEvent *event);

private:
    vector<QPointF> ctrlPoint;
    vector<QPointF> curverPoint;
};

#endif // WIDGET_H


//源文件包含对控制点的绘制和B样曲线的绘制
#include "widget.h"
#include <QPainter>
#include <QPen>

Widget::Widget(QWidget *parent)
    : QWidget(parent)
{

}

void Widget::paintEvent(QPaintEvent *event)
{
    int i = 0;
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing,true);
    painter.setBrush(Qt::green);
    for(i=0; i<(int)ctrlPoint.size(); i++)
    {
        QPointF p = ctrlPoint[i];
        painter.drawRect(p.x()-5,p.y()-5,10,10);
    }

    QPen pen;
    pen.setStyle(Qt::DashDotLine);
    pen.setColor(Qt::red);
    painter.setPen(pen);
    for(int i=0; i<(int)ctrlPoint.size()-1; i++)
    {
        painter.drawLine(ctrlPoint[i],ctrlPoint[i+1]);
    }

    painter.setPen(Qt::black);
    for(int j=0; j<(int)curverPoint.size()-1; j++)
    {
        painter.drawLine(curverPoint[j],curverPoint[j+1]);
    }
}

void Widget::mousePressEvent(QMouseEvent *event)
{
    if(event->button() == Qt::LeftButton)
    {
        ctrlPoint.push_back(event->pos());
        update();

        curverPoint.clear();
        for(int i=0; i<(int)ctrlPoint.size()-3; i++)
        {
            for(double j=0; j<=1; j+=0.02)
            {
                //相邻四个点可以绘制一条B样曲线,确定相邻的四个点,那么这四个点的曲线参数方程式也相应确定.
                QPointF p = 1/6.0*(-j*j*j+3*j*j-3*j+1)*ctrlPoint[i]+1/6.0*(3*j*j*j-6*j*j+4)*ctrlPoint[i+1]+1/6.0*(-3*j*j*j+3*j*j+3*j+1)*ctrlPoint[i+2]+1/6.0*(j*j*j)*ctrlPoint[i+3];
                curverPoint.push_back(p);
            }
        }
    }
}

Widget::~Widget()
{

}

 

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值