source: trunk/examples/opengl/overpainting/bubble.cpp@ 349

Last change on this file since 349 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 3.9 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information (qt-info@nokia.com)
5**
6** This file is part of the examples of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at qt-sales@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#include <QtGui>
43
44#include "bubble.h"
45
46Bubble::Bubble(const QPointF &position, qreal radius, const QPointF &velocity)
47 : position(position), vel(velocity), radius(radius)
48{
49 innerColor = randomColor();
50 outerColor = randomColor();
51 updateBrush();
52}
53
54void Bubble::updateBrush()
55{
56 QRadialGradient gradient(QPointF(radius, radius), radius,
57 QPointF(radius*0.5, radius*0.5));
58
59 gradient.setColorAt(0, QColor(255, 255, 255, 255));
60 gradient.setColorAt(0.25, innerColor);
61 gradient.setColorAt(1, outerColor);
62 brush = QBrush(gradient);
63}
64
65void Bubble::drawBubble(QPainter *painter)
66{
67 painter->save();
68 painter->translate(position.x() - radius, position.y() - radius);
69 painter->setBrush(brush);
70 painter->drawEllipse(0, 0, int(2*radius), int(2*radius));
71 painter->restore();
72}
73
74QColor Bubble::randomColor()
75{
76 int red = int(205 + 50.0*qrand()/(RAND_MAX+1.0));
77 int green = int(205 + 50.0*qrand()/(RAND_MAX+1.0));
78 int blue = int(205 + 50.0*qrand()/(RAND_MAX+1.0));
79 int alpha = int(91 + 100.0*qrand()/(RAND_MAX+1.0));
80
81 return QColor(red, green, blue, alpha);
82}
83
84void Bubble::move(const QRect &bbox)
85{
86 position += vel;
87 qreal leftOverflow = position.x() - radius - bbox.left();
88 qreal rightOverflow = position.x() + radius - bbox.right();
89 qreal topOverflow = position.y() - radius - bbox.top();
90 qreal bottomOverflow = position.y() + radius - bbox.bottom();
91
92 if (leftOverflow < 0.0) {
93 position.setX(position.x() - 2 * leftOverflow);
94 vel.setX(-vel.x());
95 } else if (rightOverflow > 0.0) {
96 position.setX(position.x() - 2 * rightOverflow);
97 vel.setX(-vel.x());
98 }
99
100 if (topOverflow < 0.0) {
101 position.setY(position.y() - 2 * topOverflow);
102 vel.setY(-vel.y());
103 } else if (bottomOverflow > 0.0) {
104 position.setY(position.y() - 2 * bottomOverflow);
105 vel.setY(-vel.y());
106 }
107}
108
109QRectF Bubble::rect()
110{
111 return QRectF(position.x() - radius, position.y() - radius,
112 2 * radius, 2 * radius);
113}
Note: See TracBrowser for help on using the repository browser.