可以用来开发GUI界面的主流语言和平台(二)

可以用来开发GUI界面的主流语言和平台(二)


对于代码学习表达感谢:https://blog.csdn.net/yishuicanhong/article/details/80738361

二、C++(Qt creator)

本文承接上文介绍如何快速上手入门Qt开发(用一个自动绘制正弦曲线的的小例程做介绍)
1、创建一个Qt工程项目
在这里插入图片描述
你可以选择点击文件,然后新建工程,也可以直接New project,还可以直接open最近经常打开的工程文件
在这里插入图片描述
选择应用程序,点击choose;
在这里插入图片描述
编辑你的工程文件名称,选择你的保存路径,根据需要可以设置默认路径,然后点击下一步;
在这里插入图片描述
选择不同的编译器,根据你的需要选择MSV2015(这个是和你的VS版本对应的)或者MinGW,需要注意的是一个是64位的,而另一个是32位的,点击下一步;
在这里插入图片描述
选择你的基类并看情况修改类名,一般情况使用widget的较多,点击下一步;
在这里插入图片描述
最后一步,看清添加的文件,点击完成,完成一个Qt工程的创建。
一个建好的工程如下:
在这里插入图片描述
2、在对应的文件下添加你的功能代码
widget.h
#ifndef WIDGET_H
#define WIDGET_H

#include
#include
#include

class Widget : public QWidget

{
Q_OBJECT

protected:
void paintEvent(QPaintEvent *);

public:
int m_count;
float x;
QTimer* m_Timer;
QList xList;
QList yList;

Widget(QWidget *parent = 0);

~Widget();

public slots:
void creatData();

};
#endif // WIDGET_H
widget.cpp

#include "Widget.h"
#include <QPainter>
#include <QPointF>
#include <QPen>
#include <qmath.h>

Widget::Widget(QWidget *parent) : QWidget(parent)
{
    
    
    x = -10;
    m_count = 0;
    m_Timer = new QTimer(this);
    m_Timer->start(10);

    connect(m_Timer,SIGNAL(timeout()),this,SLOT(creatData()));
}

void Widget::creatData()

{
    
    
    x += 0.2;
    m_count += 1;

    if(m_count%2)

    {
    
    
        xList.append(x);
        yList.append(qSin(x));
    }

    else

    {
    
    
        xList.append(x);
        yList.append(qSin(x));
        update();
    }

    if(m_count == 101)
    {
    
    
        xList.clear();
        yList.clear();
        m_count = 0;
        x = -10;
    }
}

void Widget::paintEvent(QPaintEvent *)

{
    
    
    QPainter painter(this);
    QPen pen;
    pen.setColor(Qt::green);
    pen.setStyle(Qt::SolidLine);
    pen.setWidthF(0.05);
    painter.setPen(pen);
    painter.setViewport(50, 50, width()-100, height()-100);
    painter.setWindow(-10, 2, 20, -4); // (-10, 2)    (10, -2)
    painter.fillRect(-10, 2, 20, -4, Qt::white);
    painter.drawLine(QPointF(-10, 0), QPointF(10, 0));   // x
    painter.drawLine(QPointF(0, 2), QPointF(0, -2));     // y
    for(int i = 0; i < yList.count(); i++)
    {
    
    
        if(i == 0)
            painter.drawPoint(QPointF(xList[i], yList[i]));
        else
            painter.drawLine(QPointF(xList[i-1], yList[i-1]), QPointF(xList[i], yList[i]));
    }
}
Widget::~Widget()
{
    
    



}

3、最终实现的效果
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/guo_xyx/article/details/106225609
今日推荐