返回介绍

QCanvasSpline Class

发布于 2019-10-04 14:58:42 字数 2863 浏览 911 评论 0 收藏 0

The QCanvasSpline class provides multi-bezier splines on a QCanvas. More...

#include <qcanvas.h>

Inherits QCanvasPolygon.

List of all member functions.

Public Members

  • QCanvasSpline ( QCanvas*canvas )
  • ~QCanvasSpline ()
  • void setControlPoints ( QPointArrayctrl, boolclose = TRUE )
  • QPointArray controlPoints () const
  • bool closed () const
  • virtual int rtti () const

Detailed Description

The QCanvasSpline class provides multi-bezier splines on a QCanvas.

A QCanvasSpline is a sequence of 4-point bezier curves joined together to make a curved shape.

You set the control points of the spline with setControlPoints().

If the bezier is closed(), then the first control point will be re-used as the last control point. Therefore, a closed bezier must have a multiple of 3 control points and an open bezier must have one extra point.

The beziers are not necessarily joined "smoothly". To ensure this, set control points appropriately (general reference texts about beziers will explain this in detail).

Like any other canvas item splines can be moved with QCanvasItem::move() and QCanvasItem::moveBy(), or by setting coordinates with QCanvasItem::setX(), QCanvasItem::setY() and QCanvasItem::setZ().

See also Graphics Classes and Image Processing Classes.


Member Function Documentation

QCanvasSpline::QCanvasSpline ( QCanvas*canvas )

Create a spline with no control points on the canvas canvas.

See also setControlPoints().

QCanvasSpline::~QCanvasSpline ()

Destroy the spline.

bool QCanvasSpline::closed () const

Returns TRUE if the control points are a closed set; otherwise returns FALSE.

QPointArray QCanvasSpline::controlPoints () const

Returns the current set of control points.

See also setControlPoints() and closed().

int QCanvasSpline::rtti () const [virtual]

Returns 8 (QCanvasItem::Rtti_Spline).

See also QCanvasItem::rtti().

Reimplemented from QCanvasPolygon.

void QCanvasSpline::setControlPoints ( QPointArrayctrl, boolclose = TRUE )

Set the spline control points to ctrl.

If close is TRUE, then the first point in ctrl will be re-used as the last point, and the number of control points must be a multiple of 3. If close is FALSE, one additional control point is required, and the number of control points must be one of (4, 7, 11, ...).

If the number of control points doesn't meet the above conditions, the number of points will be truncated to the largest number of points that do meet the requirement.

Example: canvas/canvas.cpp.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文