Qt 坐标变换

1.坐标变换常用接口

void translate(qreal dx,qreal dy)平移
void rotate(qreal angle)旋转
void scale(qreal sx,qreal sy)缩放
void save保存painter当前的状态
void restore()恢复上一次状态
void resetTransform()复位所有的坐标变换

2.示例

画五角星

void Widget::paintEvent(QPaintEvent *event)
{
    //创建QPainter对象,指明父对象,否则不能看见
    QPainter painter(this);

    //先画一条线
    QPen pen;

    //设置线宽
    pen.setWidth(2);

    //设置颜色
    pen.setColor(Qt::red);

    //设置线的样式 实线、虚线
    pen.setStyle(Qt::SolidLine);

    //设置线端点样式
    pen.setCapStyle(Qt::FlatCap);

    pen.setJoinStyle(Qt::BevelJoin);

    //设置画笔
    painter.setPen(pen);

    //半径
    qreal R = 100;
    qreal pi = 3.14159;
    qreal deg = pi*72/180;

    QPoint points[5] = {
        QPoint(R,0),
        QPoint(R*std::cos(deg),-R*std::sin(deg)),
        QPoint(R*std::cos(2*deg),-R*std::sin(2*deg)),
        QPoint(R*std::cos(3*deg),-R*std::sin(3*deg)),
        QPoint(R*std::cos(4*deg),-R*std::sin(4*deg))
    };

    //设置字体
    QFont font;
    font.setPixelSize(12);
    font.setBold(true);
    painter.setFont(font);

    //设置画刷
    QBrush brush;

    //画刷设置颜色
    brush.setColor(Qt::yellow);

    //设置填充样式
    brush.setStyle(Qt::SolidPattern);

    //设置画刷
    painter.setBrush(brush);

    QPainterPath painterPath;
    painterPath.moveTo(points[0]);
    painterPath.lineTo(points[2]);
    painterPath.lineTo(points[4]);
    painterPath.lineTo(points[1]);
    painterPath.lineTo(points[3]);

    //闭合路径,最后一个点与第一个点相连
    painterPath.closeSubpath();

    painterPath.addText(points[0],font,"0");
    painterPath.addText(points[1],font,"1");
    painterPath.addText(points[2],font,"2");
    painterPath.addText(points[3],font,"3");
    painterPath.addText(points[4],font,"4");

    //保持坐标状态
    painter.save();

    //平移
    painter.translate(100,120);

    //画星星
    painter.drawPath(painterPath);

    painter.drawText(0,0,"S1");

    //恢复坐标状态
    painter.restore();

    //平移
    painter.translate(300,120);
    //缩放
    painter.scale(0.8,0.8);
    //顺时针旋转90
    painter.rotate(90);
    painter.drawPath(painterPath);
    painter.drawText(0,0,"S2");

    //复位所有坐标变换
    painter.resetTransform();
    //平移
    painter.translate(500,120);
    //逆时针旋转145
    painter.rotate(-145);

    painter.drawPath(painterPath);
    painter.drawText(0,0,"S3");
}

 

本资源为Qt绘图基础,世界坐标换为逻辑坐标系。世界坐标系原点在视图左上角,本例子通过世界坐标换,将坐标原点定位在视图中央,Y轴向上,X轴向右,并绘制坐标轴,基于逻辑坐标系下的绘图,可将换关系函数取消生效,对比世界坐标系下的绘图。 重写PainterEvent函数: void QtPixPainter::paintEvent(QPaintEvent* event) { QPainter painter(this); // 反走样 painter.setRenderHint(QPainter::Antialiasing, true); //物理坐标系与逻辑坐标系的换,如果不换,下面的绘图都是在世界坐标系下 setWorldTransform(painter); // 其他一些绘制矩形,多边形的例子,经过上面换,都是在逻辑坐标系下 drawRectScale(painter); //draw_shearRect(painter); //利用rotate()函数进行比例变换,实现缩放效果 //draw_rotate_act(painter); //draw_by_save_restore(painter); //transform_draw_SinX(painter); transform_draw(painter); local_drawConvexPolygon(painter); } // 将世界坐标(原点左上角)换为逻辑坐标(原点在屏幕中间) QPointF QtPixPainter::mapToScene(const QPointF& point) { QTransform transMatrix = _transform.inverted(); //翻矩阵? return transMatrix.map(point); //将点piont映射到transMatrix定义的坐标系中来 } // 将鼠标的逻辑位置返回并以标签形式展示 void QtPixPainter::mouseMoveEvent(QMouseEvent* event) { QString msg; QPointF mouse_po = mapToScene(event->pos()); //总是返回屏幕物理坐标系 double x = mouse_po.x(); // 总是返回屏幕物理坐标系 double y = mouse_po.y(); QString str = "(" + QString::number(x) + "," + QString::number(y) + ")"; //qDebug()<<"world x = "<pos().x()<<",world y = "<pos().y(); m_mouse_lable->setText(str); }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

灬Sunnnnn

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

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

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

打赏作者

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

抵扣说明:

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

余额充值