qt画旋转的带箭头的线段

43 篇文章 14 订阅

tesb::tesb(QWidget *parent)
	: QWidget(parent)
{
	ui.setupUi(this);
}

void tesb::DrawCustomLine(QPainter& _painter, double _angle, double _len, const QString& _name, const QColor& _color)
{
	// 初始化
	_painter.resetTransform(); // 重设画笔
	_painter.translate(QPoint(300,300));
	_painter.setPen(QPen(Qt::black, 2));

	// 绘制线段
	QLine _line(QPoint(0,0), QPoint(_len,0));
	_painter.rotate(_angle);
	_painter.drawLine(_line);

	// 绘制箭头
	int off_x = 10;
	QPainterPath _path;
	_path.moveTo(_len-off_x, -5);
	_path.lineTo(_len,0);
	_path.lineTo(_len-off_x,5);
	_painter.drawPath(_path);

	// 绘制名称
	_painter.setPen(_color);
	
	QFont _font = _painter.font();
	_font.setPointSize(10);
	_font.setBold(true);
	_painter.setFont(_font);

	_painter.drawText(QPoint(_len-2*off_x,-10), _name);
}

void tesb::paintEvent( QPaintEvent *ev )
{
	QPainter _painter(this);
	_painter.setPen(QPen(Qt::black, 2));
	// 反锯齿
	_painter.setRenderHint(QPainter::Antialiasing);

	// 将画笔中心点移动至(300,300)
	_painter.translate(QPoint(300,300));

	// 绘制中心点
	_painter.drawPoint(QPoint(0,0));
	// 绘制外圆
	_painter.drawEllipse(QRect(-150,-150,300,300));

	DrawCustomLine(_painter, 0, 150, "Da", Qt::red);
	DrawCustomLine(_painter, 123.5, 130, "Db", Qt::green);
	DrawCustomLine(_painter, -45, 30, "Dc", Qt::blue);
	DrawCustomLine(_painter, -145, 60, "Dd", Qt::yellow);

	QWidget::paintEvent(ev);
}


 

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值