OpenCoverage

qquickellipseextruder.cpp

Absolute File Name:/home/opencoverage/opencoverage/guest-scripts/qtdeclarative/src/qtdeclarative/src/particles/qquickellipseextruder.cpp
Source codeSwitch to Preprocessed file
LineSourceCount
1/****************************************************************************-
2**-
3** Copyright (C) 2016 The Qt Company Ltd.-
4** Contact: https://www.qt.io/licensing/-
5**-
6** This file is part of the QtQuick module of the Qt Toolkit.-
7**-
8** $QT_BEGIN_LICENSE:LGPL$-
9** Commercial License Usage-
10** Licensees holding valid commercial Qt licenses may use this file in-
11** accordance with the commercial license agreement provided with the-
12** Software or, alternatively, in accordance with the terms contained in-
13** a written agreement between you and The Qt Company. For licensing terms-
14** and conditions see https://www.qt.io/terms-conditions. For further-
15** information use the contact form at https://www.qt.io/contact-us.-
16**-
17** GNU Lesser General Public License Usage-
18** Alternatively, this file may be used under the terms of the GNU Lesser-
19** General Public License version 3 as published by the Free Software-
20** Foundation and appearing in the file LICENSE.LGPL3 included in the-
21** packaging of this file. Please review the following information to-
22** ensure the GNU Lesser General Public License version 3 requirements-
23** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.-
24**-
25** GNU General Public License Usage-
26** Alternatively, this file may be used under the terms of the GNU-
27** General Public License version 2.0 or (at your option) the GNU General-
28** Public license version 3 or any later version approved by the KDE Free-
29** Qt Foundation. The licenses are as published by the Free Software-
30** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3-
31** included in the packaging of this file. Please review the following-
32** information to ensure the GNU General Public License requirements will-
33** be met: https://www.gnu.org/licenses/gpl-2.0.html and-
34** https://www.gnu.org/licenses/gpl-3.0.html.-
35**-
36** $QT_END_LICENSE$-
37**-
38****************************************************************************/-
39-
40#include "qquickellipseextruder_p.h"-
41#include <qmath.h>-
42#include <qrandom.h>-
43-
44QT_BEGIN_NAMESPACE-
45/*!-
46 \qmltype EllipseShape-
47 \instantiates QQuickEllipseExtruder-
48 \inqmlmodule QtQuick.Particles-
49 \ingroup qtquick-particles-
50 \inherits Shape-
51 \brief Represents an ellipse to other particle system elements.-
52-
53 This shape can be used by Emitter subclasses and Affector subclasses to have-
54 them act upon an ellipse shaped area.-
55*/-
56QQuickEllipseExtruder::QQuickEllipseExtruder(QObject *parent) :-
57 QQuickParticleExtruder(parent)-
58 , m_fill(true)-
59{-
60}
executed 16 times by 2 tests: end of block
Executed by:
  • tst_examples
  • tst_qquickellipseextruder
16
61-
62/*!-
63 \qmlproperty bool QtQuick.Particles::EllipseShape::fill-
64 If fill is true the ellipse is filled; otherwise it is just a border.-
65-
66 Default is true.-
67*/-
68-
69QPointF QQuickEllipseExtruder::extrude(const QRectF & r)-
70{-
71 qreal theta = QRandomGenerator::global()->bounded(2 * M_PI);-
72 qreal mag = m_fill ? QRandomGenerator::global()->generateDouble() : 1;
m_fillDescription
TRUEevaluated 1216 times by 1 test
Evaluated by:
  • tst_qquickellipseextruder
FALSEevaluated 1216 times by 1 test
Evaluated by:
  • tst_qquickellipseextruder
1216
73 return QPointF(r.x() + r.width()/2 + mag * (r.width()/2) * qCos(theta),
executed 2432 times by 1 test: return QPointF(r.x() + r.width()/2 + mag * (r.width()/2) * qCos(theta), r.y() + r.height()/2 + mag * (r.height()/2) * qSin(theta));
Executed by:
  • tst_qquickellipseextruder
2432
74 r.y() + r.height()/2 + mag * (r.height()/2) * qSin(theta));
executed 2432 times by 1 test: return QPointF(r.x() + r.width()/2 + mag * (r.width()/2) * qCos(theta), r.y() + r.height()/2 + mag * (r.height()/2) * qSin(theta));
Executed by:
  • tst_qquickellipseextruder
2432
75}-
76-
77bool QQuickEllipseExtruder::contains(const QRectF &bounds, const QPointF &point)-
78{-
79 if (!bounds.contains(point))
!bounds.contains(point)Description
TRUEnever evaluated
FALSEnever evaluated
0
80 return false;
never executed: return false;
0
81-
82 QPointF relPoint(bounds.center() - point);-
83 qreal xa = relPoint.x()/bounds.width();-
84 qreal yb = relPoint.y()/bounds.height();-
85 return (xa * xa + yb * yb) < 0.25;
never executed: return (xa * xa + yb * yb) < 0.25;
0
86}-
87-
88QT_END_NAMESPACE-
89-
90#include "moc_qquickellipseextruder_p.cpp"-
Source codeSwitch to Preprocessed file

Generated by Squish Coco 4.2.0