1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
/*
* The Mana Client
* Copyright (C) 2004-2010 The Mana World Development Team
*
* This file is part of The Mana Client.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "resources/ambientoverlay.h"
#include "graphics.h"
#include "resources/image.h"
#include "resources/resourcemanager.h"
AmbientOverlay::AmbientOverlay(Image *img, float parallax,
float speedX, float speedY, bool keepRatio):
mImage(img), mParallax(parallax),
mPosX(0), mPosY(0),
mSpeedX(speedX), mSpeedY(speedY),
mKeepRatio(keepRatio)
{
if (keepRatio && !mImage->isAnOpenGLOne()
&& defaultScreenWidth != 0
&& defaultScreenHeight != 0
&& graphics->getWidth() != defaultScreenWidth
&& graphics->getHeight() != defaultScreenHeight)
{
// Rescale the overlay to keep the ratio as if we were on
// the default resolution...
Image *rescaledOverlay = mImage->SDLgetScaledImage(
(int) mImage->getWidth() / defaultScreenWidth * graphics->getWidth(),
(int) mImage->getHeight() / defaultScreenHeight * graphics->getHeight());
if (rescaledOverlay)
{
// Replace the resource with the new one...
std::string idPath = mImage->getIdPath() + "_rescaled";
ResourceManager::getInstance()->addResource(idPath, rescaledOverlay);
mImage = rescaledOverlay;
}
else
mImage->incRef();
}
else
mImage->incRef();
}
AmbientOverlay::~AmbientOverlay()
{
mImage->decRef();
}
void AmbientOverlay::update(int timePassed, float dx, float dy)
{
// Self scrolling of the overlay
mPosX -= mSpeedX * timePassed / 10;
mPosY -= mSpeedY * timePassed / 10;
// Parallax scrolling
mPosX += dx * mParallax;
mPosY += dy * mParallax;
int imgW = mImage->getWidth();
int imgH = mImage->getHeight();
// Wrap values
while (mPosX > imgW)
mPosX -= imgW;
while (mPosX < 0)
mPosX += imgW;
while (mPosY > imgH)
mPosY -= imgH;
while (mPosY < 0)
mPosY += imgH;
}
void AmbientOverlay::draw(Graphics *graphics, int x, int y)
{
if (!mImage->isAnOpenGLOne() || !mKeepRatio)
graphics->drawImagePattern(mImage,
(int) -mPosX, (int) -mPosY, x + (int) mPosX, y + (int) mPosY);
else
graphics->drawRescaledImagePattern(mImage,
(int) -mPosX, (int) -mPosY, x + (int) mPosX, y + (int) mPosY,
(int) mImage->getWidth() / defaultScreenWidth * graphics->getWidth(),
(int) mImage->getHeight() / defaultScreenHeight * graphics->getHeight());
}
|