Qt 5.9 오각별 그 리 는 법
오늘 그림 부분 을 기록 하 는 절 차 는 비교적 간단 하고 조작 하기 쉬 우 며 다음 에 기 초 를 다 져 줍 니 다.
화면 부터 말씀 해 주세요.
안의 그림 위 치 는 이미지 학 과 관계 가 있 으 니 많이 이해 해 주세요.
대응 하 는 헤더 파일:
#ifndef WIDGET_H
#define WIDGET_H
#include <QWidget>
namespace Ui {
class Widget;
}
class Widget : public QWidget
{
Q_OBJECT
protected:
void paintEvent(QPaintEvent *event);
public:
explicit Widget(QWidget *parent = nullptr);
~Widget();
private:
Ui::Widget *ui;
};
#endif // WIDGET_H
대응 하 는 cpp 파일:
#include "widget.h"
#include "ui_widget.h"
#include <QPainter>
#include <iostream>
#include<math.h>
using namespace std;
void Widget::paintEvent(QPaintEvent *event)
{
Q_UNUSED(event)
QPainter painter(this);// QPainter
painter.setRenderHint(QPainter::Antialiasing);//
painter.setRenderHint(QPainter::TextAntialiasing);//
// 5 ,
qreal R = 100; // // ,qreal windows double float 。
const qreal Pi = 3.1415926;
qreal deg = Pi * 72/180;
QPoint points[5] = {
QPoint(R,0),
QPoint(R*cos(deg),-R*sin(deg)),
QPoint(R*cos(2*deg),-R*sin(2*deg)),
QPoint(R*cos(3*deg),-R*sin(3*deg)),
QPoint(R*cos(4*deg),-R*sin(4*deg)),
};
//
QFont font;
font.setPointSize(12);
font.setBold(true);
painter.setFont(font);
//
QPen penLine;
penLine.setWidth(2);//
penLine.setColor(Qt::blue); //
//Qt::NoPen,Qt::SolidLine, Qt::DashLine, Qt::DotLine,Qt::DashDotLine,Qt::DashDotDotLine,Qt::CustomDashLine
penLine.setStyle(Qt::SolidLine);// , 、
//Qt::FlatCap, Qt::SquareCap,Qt::RoundCap
penLine.setCapStyle(Qt::FlatCap);//
//Qt::MiterJoin,Qt::BevelJoin,Qt::RoundJoin,Qt::SvgMiterJoin
penLine.setJoinStyle(Qt::BevelJoin);//
painter.setPen(penLine);
//
QBrush brush;
brush.setColor(Qt::yellow); //
brush.setStyle(Qt::SolidPattern); //
painter.setBrush(brush); //
// PainterPath,
QPainterPath starPath;
starPath.moveTo(points[0]);
starPath.lineTo(points[2]);
starPath.lineTo(points[4]);
starPath.lineTo(points[1]);
starPath.lineTo(points[3]);
starPath.closeSubpath(); // ,
starPath.addText(points[0],font,"0"); //
starPath.addText(points[1],font,"1");
starPath.addText(points[2],font,"2");
starPath.addText(points[3],font,"3");
starPath.addText(points[4],font,"4");
//
painter.save(); //
painter.translate(100,120);
painter.drawPath(starPath); //
painter.drawText(0,0,"S1");
painter.restore(); //
painter.translate(300,120); //
painter.scale(0.8,0.8); //
painter.rotate(90); //
painter.drawPath(starPath);//
painter.drawText(0,0,"S2");
painter.resetTransform(); //
painter.translate(500,120); //
painter.rotate(-145); //
painter.drawPath(starPath);//
painter.drawText(0,0,"S3");
}
Widget::Widget(QWidget *parent) :
QWidget(parent),
ui(new Ui::Widget)
{
ui->setupUi(this);
setPalette(QPalette(Qt::white)); //
setAutoFillBackground(true); //
resize(600,300); //
}
Widget::~Widget()
{
delete ui;
}
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Qt 5.9 단순 복합 도형 실현본 논문 의 사례 는 Qt 5.9 간단 한 복합 도형 을 실현 하 는 구체 적 인 코드 를 공유 하여 여러분 께 참고 하 시기 바 랍 니 다.구체 적 인 내용 은 다음 과 같 습 니 다. 그림 을 그 리 는 간단 한...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.