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

Last change on this file since 1001 was 846, checked in by Dmitry A. Kuminov, 14 years ago

trunk: Merged in qt 4.7.2 sources from branches/vendor/nokia/qt.

File size: 4.0 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation (qt-info@nokia.com)
6**
7** This file is part of the examples of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:BSD$
10** You may use this file under the terms of the BSD license as follows:
11**
12** "Redistribution and use in source and binary forms, with or without
13** modification, are permitted provided that the following conditions are
14** met:
15** * Redistributions of source code must retain the above copyright
16** notice, this list of conditions and the following disclaimer.
17** * Redistributions in binary form must reproduce the above copyright
18** notice, this list of conditions and the following disclaimer in
19** the documentation and/or other materials provided with the
20** distribution.
21** * Neither the name of Nokia Corporation and its Subsidiary(-ies) nor
22** the names of its contributors may be used to endorse or promote
23** products derived from this software without specific prior written
24** permission.
25**
26** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
27** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
28** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
29** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
30** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
31** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
32** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
33** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
34** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
35** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
36** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
37** $QT_END_LICENSE$
38**
39****************************************************************************/
40
41#include <QtGui>
42
43#include "bubble.h"
44
45Bubble::Bubble(const QPointF &position, qreal radius, const QPointF &velocity)
46 : position(position), vel(velocity), radius(radius)
47{
48 innerColor = randomColor();
49 outerColor = randomColor();
50 updateBrush();
51}
52
53void Bubble::updateBrush()
54{
55 QRadialGradient gradient(QPointF(radius, radius), radius,
56 QPointF(radius*0.5, radius*0.5));
57
58 gradient.setColorAt(0, QColor(255, 255, 255, 255));
59 gradient.setColorAt(0.25, innerColor);
60 gradient.setColorAt(1, outerColor);
61 brush = QBrush(gradient);
62}
63
64void Bubble::drawBubble(QPainter *painter)
65{
66 painter->save();
67 painter->translate(position.x() - radius, position.y() - radius);
68 painter->setBrush(brush);
69 painter->drawEllipse(0, 0, int(2*radius), int(2*radius));
70 painter->restore();
71}
72
73QColor Bubble::randomColor()
74{
75 int red = int(205 + 50.0*qrand()/(RAND_MAX+1.0));
76 int green = int(205 + 50.0*qrand()/(RAND_MAX+1.0));
77 int blue = int(205 + 50.0*qrand()/(RAND_MAX+1.0));
78 int alpha = int(91 + 100.0*qrand()/(RAND_MAX+1.0));
79
80 return QColor(red, green, blue, alpha);
81}
82
83void Bubble::move(const QRect &bbox)
84{
85 position += vel;
86 qreal leftOverflow = position.x() - radius - bbox.left();
87 qreal rightOverflow = position.x() + radius - bbox.right();
88 qreal topOverflow = position.y() - radius - bbox.top();
89 qreal bottomOverflow = position.y() + radius - bbox.bottom();
90
91 if (leftOverflow < 0.0) {
92 position.setX(position.x() - 2 * leftOverflow);
93 vel.setX(-vel.x());
94 } else if (rightOverflow > 0.0) {
95 position.setX(position.x() - 2 * rightOverflow);
96 vel.setX(-vel.x());
97 }
98
99 if (topOverflow < 0.0) {
100 position.setY(position.y() - 2 * topOverflow);
101 vel.setY(-vel.y());
102 } else if (bottomOverflow > 0.0) {
103 position.setY(position.y() - 2 * bottomOverflow);
104 vel.setY(-vel.y());
105 }
106}
107
108QRectF Bubble::rect()
109{
110 return QRectF(position.x() - radius, position.y() - radius,
111 2 * radius, 2 * radius);
112}
Note: See TracBrowser for help on using the repository browser.