找回密码
 立即注册
收起左侧

第13篇 2D绘图(三)绘制文字

8
回复
27433
查看
[复制链接]
累计签到:1568 天
连续签到:1 天
来源: 2013-4-25 23:04:46 显示全部楼层 |阅读模式
绘制文字
版权声明

该文章原创于Qter开源社区(www.qter.org),作者yafeilinux,转载请注明出处!



导语

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


环境:Windows Xp + Qt 4.8.4+QtCreator 2.6.2



目录

一、基本绘制
二、控制文字的位置
三、使用字体



正文


一、基本绘制

我们接着在上一节的项目上进行讲解,首先将paintEvent()函数更改如下:
void MainWindow::paintEvent(QPaintEvent *)
{
    QPainter painter(this);
    painter.drawText(100, 100, "qter.org_yafeilinux");
}

这样就在(100, 100)的位置绘制了一个字符串。效果如下图所示。




二、控制文字的位置


1.      我们先到QPainter的帮助文档页面,然后查看drawText()函数的重载形式,找到:
QPainter::drawText ( const QRectF &rectangle, int flags, const QString & text, QRectF * boundingRect = 0 ),如下图所示。


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


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

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

       现在运行程序,效果如下图所示。



       可用的对齐方式如下图所示。



三、使用字体

为了绘制漂亮的文字,可以使用QFont类来设置文字字体。大家也可以先在帮助文档中查看该类的介绍。下面将最常用的一些设置进行演示。
       paintEvent()函数中继续添加如下代码:

QFont font("宋体", 15, QFont::Bold, true);
//设置下划线
font.setUnderline(true);
//设置上划线
font.setOverline(true);
//设置字母大小写
font.setCapitalization(QFont::SmallCaps);
//设置字符间的间距
font.setLetterSpacing(QFont::AbsoluteSpacing, 10);
//使用字体
painter.setFont(font);
painter.setPen(Qt::green);
painter.drawText(120, 80, tr("yafeilinux"));
painter.translate(50, 50);
painter.rotate(90);
painter.drawText(0, 0, tr("helloqt"));

    这里创建了QFont字体对象,使用的构造函数为QFont::QFont ( const QString & family,int pointSize = -1, int weight = -1, bool italic = false ),第一个参数设置字体的family属性,这里使用的字体族为宋体,可以使用QFontDatabase类来获取所支持的所有字体;第二个参数是点大小,默认大小为12;第三个参数为weight属性,这里使用了粗体;最后一个属性设置是否使用斜体。然后我们又使用了其他几个函数来设置字体的格式,最后调用setFont()函数来使用该字体,并使用drawText()函数的另一种重载形式在点(120, 80)绘制了文字。后面又将坐标系统平移并旋转,然后再次绘制了文字。运行程序,效果如下图所示。




结语

       这一节最后的例子中使用了rotate()函数来旋转坐标系统,从而绘制出了纵向的文字。这个将会在后面的篇章中介绍到。




涉及到的源码下载:




上一篇: 第12篇 2D绘图(二)渐变填充

下一篇:第14篇 2D绘图(四)绘制路径

返回:系列教程目录






本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复

使用道具 举报

累计签到:6 天
连续签到:1 天
2015-9-9 16:03:05 显示全部楼层
到现在为止一张图都没有看见。。
回复 支持 反对

使用道具 举报

累计签到:6 天
连续签到:1 天
2015-9-9 16:03:39 显示全部楼层
潇枫残玥 发表于 2015-9-9 16:03
到现在为止一张图都没有看见。。

我勒个去。。原来是要回复的!
回复 支持 反对

使用道具 举报

累计签到:6 天
连续签到:1 天
2015-9-9 16:04:57 显示全部楼层
潇枫残玥 发表于 2015-9-9 16:03
我勒个去。。原来是要回复的!

不对。。还是要登录的?
回复 支持 反对

使用道具 举报

累计签到:1568 天
连续签到:1 天
2015-10-2 09:33:18 显示全部楼层
潇枫残玥 发表于 2015-9-9 16:04
不对。。还是要登录的?

需要注册登录。
回复 支持 反对

使用道具 举报

累计签到:1 天
连续签到:1 天
2015-11-1 11:31:13 显示全部楼层
谢谢分享………………
回复 支持 反对

使用道具 举报

累计签到:27 天
连续签到:1 天
2016-4-15 14:44:49 显示全部楼层
@yafeilinux 所有的教程都是你写的啊,厉害
回复 支持 反对

使用道具 举报

累计签到:1 天
连续签到:1 天
2016-5-18 22:11:39 显示全部楼层
看不到图啊,虽然楼主做的真的很良心
回复 支持 反对

使用道具 举报

累计签到:27 天
连续签到:1 天
2016-7-13 14:55:57 显示全部楼层
PanKen 发表于 2016-5-18 22:11
看不到图啊,虽然楼主做的真的很良心

需要注册,升级到1级才可以看图
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

公告
可以关注我们的微信公众号yafeilinux_friends获取最新动态,或者加入QQ会员群进行交流:190741849、186601429(已满) 我知道了