Qt之描绘轮廓

简述

前面提到过 QPainterPath(绘图路径),除了创建和重用图形形状以外,还可以进行一些高级操作,例如:填充、描绘轮廓、裁剪。

轮廓,是指边缘 - 物体的外周或图形的外框

要为一个指定的绘图路径生成可填充的轮廓,离不开 QPainterPathStroker。

  • 简述
  • QPainterPathStroker
  • 绘制轮廓
  • 深入理解

版权所有:一去丶二三里,转载请注明出处:http://blog.csdn.net/liang19890820

QPainterPathStroker

要生成可填充的轮廓,一般分为两步:

  1. 定义原始绘图路径 QPainterPath path,调用 QPainterPathStroker::createStroke(path),以 path 为样本创建一个新的绘图路径 QPainterPath outlinePath,outlinePath 表示 path 的可填充的轮廓。
  2. 填充 outlinePath,绘制出原始绘图路径 path 的轮廓。

除此之外,还可以使用以下函数来控制轮廓的各种样式:

  • setWidth():宽度
  • setCapStyle():端点风格
  • setJoinStyle():连接样式
  • setDashPattern():虚线图案

注意: 由 createStroke() 生成的新绘图路径(outlinePath)应仅用于指定的绘图路径(path)的轮廓,否则,可能会引发意外行为。

绘制轮廓

以矩形为例,先上轮廓的效果图:

自定义 paintEvent(),生成一个 300 * 200 的矩形路径:

void MainWindow::paintEvent(QPaintEvent *event)
{
    Q_UNUSED(event);

    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing, true);

    // 矩形 300 * 200
    QRectF rect(50, 50, 300, 200);
    QPainterPath path;
    path.addRect(rect);

    // 绘制原始路径
    drawPath(&painter, path);

    // 绘制轮廓
    drawOutline(&painter, path);
}

重点关注 drawOutline(),它是一个自定义函数,主要用于绘制指定路径的轮廓:

// 绘制轮廓
void MainWindow::drawOutline(QPainter *painter, QPainterPath path)
{
    // 生成可填充的轮廓
    QPainterPathStroker stroker;
    stroker.setCapStyle(Qt::RoundCap);  // 端点风格
    stroker.setJoinStyle(Qt::RoundJoin);  // 连接样式
    stroker.setDashPattern(Qt::DashLine);  // 虚线图案
    stroker.setWidth(10);  // 宽度

    // 生成一个新路径(可填充区域),表示原始路径 path 的轮廓
    QPainterPath outlinePath = stroker.createStroke(path);

    // 绘制轮廓时所用的画笔(轮廓外边框灰色部分)
    QPen pen = painter->pen();
    pen.setColor(QColor(0, 160, 230));
    pen.setWidth(10);

    // 用指定的画笔 pen 绘制 outlinePath
    // painter->strokePath(outlinePath, pen);
    painter->setPen(pen);
    painter->drawPath(outlinePath);

    // 用指定的画刷 brush 填充路径 outlinePath
    painter->fillPath(outlinePath, QBrush(Qt::yellow));
}

轮廓有了,来看看原始路径的绘制:

void MainWindow::drawPath(QPainter *painter, QPainterPath path)
{
    QPen pen = painter->pen();
    pen.setWidth(1);

    // 设置画笔、画刷
    painter->setPen(pen);
    painter->setBrush(QColor(35, 175, 75));

    // 绘制路径
    painter->drawPath(path);
}

深入理解

回到 paintEvent(),如果将 drawPath() 和 drawOutline() 的位置颠倒过来,就会产生下面的效果:

很显然,原始路径会将轮廓遮挡住一部分,这是为什么呢?

关于 QPainterPathStroker::setWidth(),助手中有这么一句话:

The generated outlines will extend approximately 50% of width to each side of the given input path’s original outline.

意思是说:生成的轮廓将扩展大约 width 的 50% 到原始路径原来轮廓的每侧。

既然如此,再对照下上图,没有疑问了吧!

时间: 2024-09-30 01:13:44

Qt之描绘轮廓的相关文章

PG基础-01 PG9.6.2源代码安装

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ +++++ 一:环境准备 1.源码下载地址: https://www.postgresql.org/ftp/source/ 可以选择想要编译的版本 2.本次安装介质: postgresql-9.6.2.tar.gz  3.Linux版本:CentOS release 6.6 (Final) Linux vers

红帽、微软和 Codenvy 联合推出开源协议 LSP

微软.红帽及容器开发环境供应商Codenvy本周在Red Hat DevNation开放源码大会上宣布将共同发展语言服务器协定(Language Server Protocol,LSP)项目,让不同的程序编辑器与集成开发环境(IDE)方便嵌入各种程序语言,允许开发人员在最喜爱的工具中使用各种语言来撰写程序. LSP是个开放源码项目,唯一基于JSON的语言服务器数据交换协定,目前由GitHub代管,并采用CC及MIT授权.该协定主要用来促进编辑器及语言服务器之间的互动,允许开发人员在各种编辑器或整

Illustrator创建折纸风格的矢量天鹅图绘制教程

给各位Illustrator软件的使用者们来详细的解析分享一下创建折纸风格的矢量天鹅图的绘制教程. 技巧分享:   第1步:描绘轮廓 你需要对你的设计有个总体的概念.利用照片和钢笔工具(P)描出轮廓.把填充颜色设为无,描边颜色设为黑色,1pt 粗细.这将作为你完成剩下设计的指导.编组 (Ctrl+G)你的线条并在图层面板中锁定这个组. 提示: 把一张图片作为背景来创建你设计的基本形状是个好主意(比如,动物或者物体). 使用矩形工具 (M)在画板上画一个大大的矩形作为背景(颜色随意).   第2步

Illustrator鼠绘卡通绿叶子大树效果教程

给各位Illustrator软件的使用者们来详细的解析分享一下鼠绘卡通绿叶子大树效果的教程. 教程分享: 步骤1 首先,我们将创建自定义的笔刷. 选择钢笔工具(P),并画出叶子的形状.填充形状和路径,并调整到深绿色.   步骤2 用钢笔工具(P)创建一个弯曲的线条,用同一种着色描出,穿过整个树叶.   步骤3 制作两片树叶,并改变填充颜色为暗绿和亮绿色,crtl+G进行群组,现在对群组后的树叶进行复制.   步骤4 把树叶向下旋转倾斜,并将他们重叠在一起,并使其在同一方向.   步骤5 双击比例

【Qt编程】3D迷宫游戏

       说起迷宫想必大家都很熟悉,个人感觉迷宫对人的方向感是很大的考验,至少我的方向感是不好的,尤其是在三维空间中.由于这段时间帮导师做项目用到了三维作图,便心血来潮想做个三维迷宫玩玩.要想画出三维的迷宫游戏,我们需要先从二维开始. 二维迷宫: 迷宫的程序描述:         现实生活中,我们经常将问题用数学的方法来描述并解决(数学建模).同样的,我们想用程序来解决问题,就得把问题程序化.废话不多说,进入正题:         我们可以用一个矩阵matrix来描绘整个迷宫:元素为1,代表

Qt Mode/View 学习笔记 —— 概述和Model

介绍 Qt 4推出了一组新的item view类,它们使用model/view结构来管理数据与表示层的关系.这种结构带来的功能上的分离给了开发人员更大的弹性来定制数据项的表示,它也提供一个标准的model接口,使得更多的数据源可以被这些item view使用.这里对model/view的结构进行了描述,结构中的每个组件都进行了解释,给出了一些例子说明了提供的这些类如何使用. Model/View 结构 Model-View-Controller(MVC), 是从Smalltalk发展而来的一种设

Qt之图形(QPainterPath)

简述 QPainterPath类提供了一个容器,用于绘图操作,可以创建和重用图形形状. QPainterPath是一个图形构建块的对象,如矩形.椭圆.直线和曲线.构建块可以加入在封闭的子路径中,例如:矩形或椭圆形.一个封闭的路径同时存在开始点和结束点.或者作为未封闭的子路径独立存在,如:直线和曲线. QPainterPath可以进行填充.显示轮廓和裁剪.要生成可填充的轮廓的绘图路径,可以使用QPainterPathStroker类.QPainterPath比正常绘制的主要优点在于:复杂的图形只需

【Qt编程】设计ColorBar颜色栏

画过图的都知道,我们常常用颜色的深浅来表示值的大小,在Matlab作图中,我们使用的是colorbar这个函数来给出颜色的直观参考.下面给出Matlab的示例:在Matlab命令窗口输入: figure surf(peaks) colorbar 可以得到的图像如下: 通过右击该颜色栏,可以选择不同的颜色,当选择jet后,可以得到如下的图像: 那上面的示例来说,使用颜色栏的好处是可以显示四维信息,例如(x,y,z)表示了一个三维空间的坐标,坐标点温度的大小则可以通过颜色栏的温度来表明.当然,要说明

QT中的QInputDialog的小例子

其实这断代码没什么优秀之处,贴出来主要为为了方便自己和他人,因为以后如果用到这一块的话,这些代码可能能够直接拿过来用. InpugDialog.h头文件: #ifndef INPUGDIALOG_H #define INPUGDIALOG_H #include <QtGui> #include "ui_inpugdialog.h" class InpugDialog : public QDialog { Q_OBJECT public: InpugDialog(QWidge