43 setLoopCount(Infinite);
45 setCurrentTime(item->elapsed());
47 m_phases[0] = Phase(433, -110, 10, QEasingCurve::BezierSpline);
48 m_phases[1] = Phase(767, 10, 93, QEasingCurve::Linear );
49 m_phases[2] = Phase(417, 93, 205, QEasingCurve::BezierSpline);
50 m_phases[3] = Phase(400, 205, 357, QEasingCurve::BezierSpline);
51 m_phases[4] = Phase(766, 357, 439, QEasingCurve::Linear );
52 m_phases[5] = Phase(434, 439, 585, QEasingCurve::BezierSpline);
54 m_phases[0].curve.addCubicBezierSegment(QPointF(0.02, 0.33), QPointF(0.38, 0.77), QPointF(1.00, 1.00));
55 m_phases[2].curve.addCubicBezierSegment(QPointF(0.57, 0.17), QPointF(0.95, 0.75), QPointF(1.00, 1.00));
56 m_phases[3].curve.addCubicBezierSegment(QPointF(0.00, 0.19), QPointF(0.07, 0.72), QPointF(1.00, 1.00));
57 m_phases[5].curve.addCubicBezierSegment(QPointF(0.00, 0.00), QPointF(0.95, 0.37), QPointF(1.00, 1.00));
63 int count = childCount();
64 QSGTransformNode *transformNode =
static_cast<QSGTransformNode *>(firstChild());
65 while (transformNode) {
66 Q_ASSERT(transformNode->type() == QSGNode::TransformNodeType);
68 QSGOpacityNode *opacityNode =
static_cast<QSGOpacityNode *>(transformNode->firstChild());
69 Q_ASSERT(opacityNode->type() == QSGNode::OpacityNodeType);
74 bool visible = time >= begin && time <= end;
75 opacityNode->setOpacity(visible ? 1.0 : 0.0);
78 int phaseIndex, remain = time, elapsed = 0;
79 for (phaseIndex = 0; phaseIndex <
PhaseCount - 1; ++phaseIndex) {
80 if (remain <= m_phases[phaseIndex].duration + begin)
82 remain -= m_phases[phaseIndex].duration;
83 elapsed += m_phases[phaseIndex].duration;
86 const Phase &phase = m_phases[phaseIndex];
88 qreal from = phase.from - nodeIndex * count;
89 qreal to = phase.to - nodeIndex * count;
90 qreal pos = time - elapsed - begin;
92 qreal value = phase.curve.valueForProgress(pos / phase.duration);
93 qreal rotation = from + (to - from) * value;
96 matrix.rotate(rotation, 0, 0, 1);
97 transformNode->setMatrix(matrix);
100 transformNode =
static_cast<QSGTransformNode *>(transformNode->nextSibling());
107 QQuickUniversalBusyIndicator *indicator =
static_cast<QQuickUniversalBusyIndicator *>(item);
108 QQuickItemPrivate *d = QQuickItemPrivate::get(item);
111 matrix.translate(item->width() / 2, item->height() / 2);
114 qreal size = qMin(item->width(), item->height());
115 qreal diameter = size / 10.0;
116 qreal radius = diameter / 2;
117 qreal offset = (size - diameter * 2) / M_PI;
118 const QRectF rect(offset, offset, diameter, diameter);
120 int count = indicator->count();
121 QSGNode *transformNode = firstChild();
122 for (
int i = 0; i < count; ++i) {
123 if (!transformNode) {
124 transformNode =
new QSGTransformNode;
125 appendChildNode(transformNode);
127 QSGOpacityNode *opacityNode =
new QSGOpacityNode;
128 transformNode->appendChildNode(opacityNode);
130 QSGInternalRectangleNode *rectNode = d->sceneGraphContext()->createInternalRectangleNode();
131 rectNode->setAntialiasing(
true);
132 opacityNode->appendChildNode(rectNode);
135 QSGNode *opacityNode = transformNode->firstChild();
136 Q_ASSERT(opacityNode->type() == QSGNode::OpacityNodeType);
138 QSGInternalRectangleNode *rectNode =
static_cast<QSGInternalRectangleNode *>(opacityNode->firstChild());
139 Q_ASSERT(rectNode->type() == QSGNode::GeometryNodeType);
141 rectNode->setRect(rect);
142 rectNode->setColor(indicator->color());
143 rectNode->setRadius(radius);
146 transformNode = transformNode->nextSibling();
149 while (transformNode) {
150 QSGNode *nextSibling = transformNode->nextSibling();
151 delete transformNode;
152 transformNode = nextSibling;
195void QQuickUniversalBusyIndicator::itemChange(QQuickItem::ItemChange change,
const QQuickItem::ItemChangeData &data)
197 QQuickItem::itemChange(change, data);
198 if (change == ItemVisibleHasChanged)