第7章图形与图画1.pptVIP

  • 2
  • 0
  • 约8.75千字
  • 约 33页
  • 2017-05-29 发布于四川
  • 举报
下面通过利用QsvgWidget类和QsvgRender类实现一个SVG图片浏览器,显示以.svg结尾的文件来介绍SVG格式图片显示的方法,如图7.20所示。 此实例由3个层次的窗体构成,如图7.21所示。 在完成此功能的程序中使用与SVG相关的类,必须在程序中包含SVG相关的头文件: #include QtSvg 由于Qt默认生成的Makefile中只会加入QtGui、QtCore模块的库,因此,必须在工程文件.pro中加入一行: QT += svg 这样会在编译时加入QtSvg的库。 7.1 各类位置相关函数的区别 7.2 各种与位置相关函数的使用场合 7.3 各种基础图形的绘制 7.4 双缓冲机制 7.5 SVG格式图片的显示 Qt提供了很多关于获取窗体位置以及显示区域大小的函数,如x( )、y( )和pos( )、rect( )、size( )、geometry( )等,如图7.1所示。 本节通过一个简单的例子介绍QWidget提供的x()、y()、frameGeometry、pos()、rect()、size()、geometry()等函数的使用场合。在此例中,当改变对话框的大小,或移动对话框时调用各个函数所获得的信息也相应地发生变化,从变化中可得知各函数之间的区别,如图7.2所示。 首先介绍各种形状的区分,其次介绍画笔颜色、线宽、风格、顶帽风格、连接点风格以及画刷的颜色设置、填充模式和画刷的风格设置,使用的实例如图7.3所示。 此实例的具体实现包含了两个部分的内容,一个是用于画图的区域PaintArea类,一个是主窗口MainWidget类,如图7.4所示。 打开“paintarea.h”头文件,添加如下代码: #include QPen #include QBrush ? class PaintArea : public QWidget { Q_OBJECT public: enum Shape{Line,Rectangle,RoundRect,Ellipse,Polygon,Polyline,Points, Arc,Path,Text,Pixmap}; PaintArea(QWidget *parent=0); ? void setShape(Shape); void setPen(QPen); void setBrush(QBrush); void setFillRule(Qt::FillRule); void paintEvent(QPaintEvent *); private: Shape shape; QPen pen; QBrush brush; Qt::FillRule fillRule; }; PaintArea类的构造函数完成初始化工作,设置了图形显示区域的背景色以及最小显示尺寸,具体代码如下: #include paintarea.h #include QPainter PaintArea::PaintArea(QWidget *parent) :QWidget(parent) { setPalette(QPalette(Qt::white)); setAutoFillBackground(true); setMinimumSize(400,400); } setShape()函数可以设置形状、setPen()函数可以设置画笔、setBrush()函数可以设置画刷、setFillRule()函数可以设置填充模式,具体代码实现。 (1) 利用QPainter绘制图形(Shape) Qt为开发者提供了丰富的绘制基本图形的draw函数,如图7.6所示。 (2) 利用QPainterPath绘制简单图形 利用QPainterPath绘制简单图形,QPainterPath类为QPainter类提供了一个存储容器,里面包含了所要画的内容的集合以及画的顺序,如长方形、多边形、曲线等各种任意图形。 cubicTo()函数绘制的是贝赛尔曲线,如图7.7所示。 利用QPainterPath类可以实现QPainter类的所有draw()函数能实现的图形。如对于QPainter::drawRect()函数,除了可用上面介绍的QPainterPath::addRect()的方式实现,还可以用如下方式实现: QPainterPath path; path.moveTo(0,0); path.lineTo(200,0); path.lineTo(200,100); path.lineTo(0,100); path.lineTo(0,0); 主窗口类MainWig

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档