当前位置: 首页> 财经> 访谈 > 共青城网站建设_广州古柏广告策划有限公司_整站seo免费咨询_跨境电商

共青城网站建设_广州古柏广告策划有限公司_整站seo免费咨询_跨境电商

时间:2025/7/9 10:52:59来源:https://blog.csdn.net/qq_37464701/article/details/144183755 浏览次数:0次
共青城网站建设_广州古柏广告策划有限公司_整站seo免费咨询_跨境电商

参考文章链接:
Qt 2D绘图之三:绘制文字、路径、图像、复合模式

绘制文字

除了绘制图形以外,还可以使用QPainter::darwText()函数来绘制文字,也可以使用QPainter::setFont()设置文字所使用的字体,使用QPainter::fontInfo()函数可以获取字体的信息,它返回QFontInfo类对象。在绘制文字时会默认使用抗锯齿

基本绘制

下面仍然在上一节的程序中进行代码演示,更改paintEvent()的内容如下:

void Widget::paintEvent(QPaintEvent *)
{
QPainter painter(this);
painter.drawText(100, 100, “qter.org-yafeilinux”);
}
这样就在(100, 100)的位置绘制了一个字符串。效果如下图所示。
在这里插入图片描述

控制文字的位置

我们先到QPainter的帮助文档页面,然后查看drawText()函数的重载形式,找到:

QPainter::drawText ( const QRectF & rectangle, int flags, const QString & text, QRectF * boundingRect = 0 )

第一个参数指定了绘制文字所在的矩形;
第二个参数指定了文字在矩形中的对齐方式,它由Qt::AlignmentFlag枚举类型进行定义,不同对齐方式也可以使用“|”操作符同时使用,这里还可以使用Qt::TextFlag定义的其他一些标志,比如自动换行等;
第三个参数就是所要绘制的文字,这里可以使用“\n”来实现换行;
第四个参数一般不用设置。

下面来看一个例子。为了更明显地看到文字在指定矩形中的位置,我们绘制出这个矩形。将paintEvent()函数更改如下:

void Widget::paintEvent(QPaintEvent *)
{QPainter painter(this);//设置一个矩形QRectF rect(50, 50, 300, 200);//为了更直观地看到字体的位置,我们绘制出这个矩形painter.drawRect(rect);painter.setPen(QColor(Qt::red));//这里先让字体水平居中painter.drawText(rect, Qt::AlignHCenter, "yafeilinux");
}

现在运行程序,效果如下图所示。
在这里插入图片描述
可用的对齐方式如下图所示。
在这里插入图片描述

使用字体

为了绘制漂亮的文字,可以使用QFont类来设置文字字体。大家也可以先在帮助文档中查看该类的介绍。下面将最常用的一些设置进行演示。

将paintEvent()函数更改如下:

void Widget::paintEvent(QPaintEvent *)
{QPainter painter(this);//设置一个矩形QRectF rect(50, 50, 300, 200);//为了更直观地看到字体的位置,我们绘制出这个矩形painter.drawRect(rect);painter.setPen(QColor(Qt::red));//这里先让字体水平居中painter.drawText(rect, Qt::AlignHCenter, "yafeilinux");//使用字体QFont font("宋体", 15, QFont::Bold, true);//设置下划线font.setUnderline(true);//设置上划线font.setOverline(true
关键字:共青城网站建设_广州古柏广告策划有限公司_整站seo免费咨询_跨境电商

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: