当前位置:主页   - 电脑 - 程序设计 - C/C++
Qt学习之路(27): 渐变填充
来源:网络   作者:FinderCheng   更新时间:2011-07-03
收藏此页】    【字号    】    【打印】    【关闭

  前面说了有关反走样的相关知识,下面来说一下渐变。渐变是绘图中很常见的一种功能,简单来说就是可以把几种颜色混合在一起,让它们能够自然地过渡,而不是一下子变成另一种颜色。渐变的算法比较复杂,写得不好的话效率会很低,好在很多绘图系统都内置了渐变的功能,Qt也不例外。渐变一般是用在填充里面的,所以,渐变的设置就是在QBrush里面。

  Qt提供了三种渐变画刷,分别是线性渐变(QLinearGradient)、辐射渐变(QRadialGradient)、角度渐变(QConicalGradient)。如下图所示(图片出自C++ GUI Programming with Qt4, 2nd Edition):

Qt学习之路(27): 渐变填充

  下面我们来看一下线性渐变QLinearGradient的用法。

void PaintedWidget::paintEvent(QPaintEvent *event)
{
        QPainter painter(this);
        painter.setRenderHint(QPainter::Antialiasing, true);
        QLinearGradient linearGradient(60, 50, 200, 200);
        linearGradient.setColorAt(0.2, Qt::white);
        linearGradient.setColorAt(0.6, Qt::green);
        linearGradient.setColorAt(1.0, Qt::black);
        painter.setBrush(QBrush(linearGradient));
        painter.drawEllipse(50, 50, 200, 150);
}

  同前面一样,这里也仅仅给出了paintEvent()函数里面的代码。

  首先我们打开了反走样,然后创建一个QLinearGradient对象实例。QLinearGradient构造函数有四个参数,分别是x1, y1, x2, y2,即渐变的起始点和终止点。在这里,我们从(60, 50)开始渐变,到(200, 200)止。

  渐变的颜色是在setColorAt()函数中指定的。下面是这个函数的签名:

void QGradient::setColorAt ( qreal position, const QColor & color )

  它的意思是把position位置的颜色设置成color。其中,position是一个0 - 1区间的数字。也就是说,position是相对于我们建立渐变对象时做的那个起始点和终止点区间的。比如这个线性渐变,就是说,在从(60, 50)到(200, 200)的线段上,在0.2,也就五分之一处设置成白色,在0.6也就是五分之三处设置成绿色,在1.0也就是终点处设置成黑色。

  在创建QBrush时,把这个渐变对象传递进去,就是我们的结果啦:

Qt学习之路(27): 渐变填充

  那么,我们怎么让线段也是渐变的呢?要知道,直线是用画笔绘制的啊!这里,如果你仔细查阅了API文档就会发现,QPen是接受QBrush作为参数的。也就是说,你可以利用一个QBrush创建一个QPen,这样,QBrush所有的填充效果都可以用在画笔上了!

void PaintedWidget::paintEvent(QPaintEvent *event)
{
        QPainter painter(this);
        painter.setRenderHint(QPainter::Antialiasing, true);
        QLinearGradient linearGradient(60, 50, 200, 200);
        linearGradient.setColorAt(0.2, Qt::white);
        linearGradient.setColorAt(0.6, Qt::green);
        linearGradient.setColorAt(1.0, Qt::black);
        painter.setPen(QPen(QBrush(linearGradient), 5));
        painter.drawLine(50, 50, 200, 200);
}

  看看我们的渐变线吧!

Qt学习之路(27): 渐变填充

  出处:http://devbean.blog.51cto.com/448512/238168

编缉推荐阅读以下文章

  • Qt学习之路(34): 国际化(下)
  • Qt学习之路(33): 国际化(上)
  • Qt学习之路(32): 一个简易画板的实现(Graphics View)
  • Qt学习之路(31): 一个简易画板的实现(QWidget)
  • Qt学习之路(30): Graphics View Framework
  • Qt学习之路(29): 绘图设备
  • Qt学习之路(28): 坐标变换
  • Qt学习之路(26): 反走样
  • Qt学习之路(25): QPainter(续)
  • Qt学习之路(24): QPainter
其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明