Qt绘制五角星

该代码示例展示了如何在Qt环境中重写paintEvent函数,用以绘制一个五角星。首先定义了QPoint数组m_starData来存储五角星的顶点坐标,然后在paintEvent中使用QPainter进行绘制,包括设置抗锯齿效果、画笔颜色、填充刷子颜色,并将五角星的顶点连接成路径,最后在五角星各顶点添加编号。
摘要由CSDN通过智能技术生成

在这里插入图片描述

利用Qt中的paintEvent事件绘制五角星
class DrawStar : public  QWidget
{
	Q_OBJECT
public:
	explicit DrawStar(QWidget* parent = nullptr);

protected:
	void paintEvent(QPaintEvent* pEvent);

private:
	void initData();

private:
	QPoint m_starData[5];
};

DrawStar::DrawStar(QWidget* parent)
	: QWidget(parent)
{
	this->initData();
	update();
}

void DrawStar::initData()
{
	qreal deg = ((360 / 5) * 3.1415926) / 180;
	qreal r = 100;
	
	m_starData[0] = QPoint(r, 0);
	m_starData[1] = QPoint(r * qCos(deg), -r * qSin(deg));
	m_starData[2] = QPoint(r * qCos(2 * deg), -r * qSin(2 * deg));
	m_starData[3] = QPoint(r * qCos(3 * deg), -r * qSin(3 * deg));
	m_starData[4] = QPoint(r * qCos(4 * deg), -r * qSin(4 * deg));
}

void DrawStar::paintEvent(QPaintEvent* pEvent)
{
	QPainter painter(this);
	painter.setRenderHint(QPainter::Antialiasing, true);
	painter.setPen(Qt::black);
	painter.setBrush(QBrush(Qt::yellow));

	QPainterPath paintPath;
	paintPath.moveTo(m_starData[3]);
	paintPath.lineTo(m_starData[1]);
	paintPath.lineTo(m_starData[4]);
	paintPath.lineTo(m_starData[2]);
	paintPath.lineTo(m_starData[0]);
	paintPath.closeSubpath();
	painter.translate(100, 100);
	

	QFont font;
	font.setPointSizeF(12);
	paintPath.addText(m_starData[0], font, "0");
	paintPath.addText(m_starData[1], font, "1");
	paintPath.addText(m_starData[2], font, "2");
	paintPath.addText(m_starData[3], font, "3");
	paintPath.addText(m_starData[4], font, "4");
	painter.setFont(font);	
	painter.drawPath(paintPath);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Pailugou

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值