Qt图形视图框架自定义图元

版权声明:本文仅代表个人观点,仅供参考! fearlazy和大家一起进步!更多内容看 www.fearlazy.com https://blog.csdn.net/can3981132/article/details/87215281

全文链接:http://www.fearlazy.com/index.php/post/109.html

Qt图形视图框架提供了很多类型的图元给我们使用,但是这些图元仍然不能满足不同行业对图元不同的需求,此时就需要根据自己的需求来定制图元。

定制图元类就是子类化QGraphicsItem,继承QGraphicsItem类必须重写QGraphicsItem的两个纯虚函数boundingRect和paint,前者用来指定图元的外边界,该函数返回值是一个矩形(QRectF),后者是用来绘制图元的,绘制基于图元坐标系进行。

自定义图元类还应该重写type虚函数,该函数返回图元的类型(Int类型),该值应该是一个唯一的值。自定义图元类的type还应该大于等于UserType(65536)。重写以上三个函数就可以实现最简单的图元定制了。

举例:自定义一个标志牌图元,图元由背景和文字组成。

1.从QGraphicsItem派生CustomItem类。

2.重写type函数,返回CustomItem的类型。

blob.png

UserType是QGraphicsItem类的一个枚举值。需要注意小括号后的const别忘了

3.重写boundingRect函数。

blob.png

指定边界为一个固定矩形(左上角-40,-30   宽80  高60)。需要注意小括号后的const别忘了

4.重写paint函数,用于绘制图元的形状。

blob.png

首先绘制了两个矩形作为标志牌的背景,然后绘制了文字,其中m_text为成员变量。当图元为选中时绘制边框为虚线。

创建一个CustomItem对象添加到场景中,显示如下:

blob.png

至此最简单的自定义图元就完成了。

作者:fearlazy 一个入行5年的程序员新人。 文章内容仅代表个人观点,如有雷同请为我点个赞吧!

猜你喜欢

转载自blog.csdn.net/can3981132/article/details/87215281
今日推荐