1
// Copyright (C) 2002-2011 Nikolaus Gebhardt
2
// This file is part of the "Irrlicht Engine".
3
// For conditions of distribution and use, see copyright notice in irrlicht.h
5
#include "CParticlePointEmitter.h"
7
#include "IAttributes.h"
15
CParticlePointEmitter::CParticlePointEmitter(
16
const core::vector3df& direction, u32 minParticlesPerSecond,
17
u32 maxParticlesPerSecond, video::SColor minStartColor,
18
video::SColor maxStartColor, u32 lifeTimeMin, u32 lifeTimeMax,
20
const core::dimension2df& minStartSize,
21
const core::dimension2df& maxStartSize)
22
: Direction(direction),
23
MinStartSize(minStartSize), MaxStartSize(maxStartSize),
24
MinParticlesPerSecond(minParticlesPerSecond),
25
MaxParticlesPerSecond(maxParticlesPerSecond),
26
MinStartColor(minStartColor), MaxStartColor(maxStartColor),
27
MinLifeTime(lifeTimeMin), MaxLifeTime(lifeTimeMax),
28
MaxAngleDegrees(maxAngleDegrees), Time(0), Emitted(0)
31
setDebugName("CParticlePointEmitter");
36
//! Prepares an array with new particles to emitt into the system
37
//! and returns how much new particles there are.
38
s32 CParticlePointEmitter::emitt(u32 now, u32 timeSinceLastCall, SParticle*& outArray)
40
Time += timeSinceLastCall;
42
const u32 pps = (MaxParticlesPerSecond - MinParticlesPerSecond);
43
const f32 perSecond = pps ? ((f32)MinParticlesPerSecond + os::Randomizer::frand() * pps) : MinParticlesPerSecond;
44
const f32 everyWhatMillisecond = 1000.0f / perSecond;
46
if (Time > everyWhatMillisecond)
49
Particle.startTime = now;
50
Particle.vector = Direction;
54
core::vector3df tgt = Direction;
55
tgt.rotateXYBy(os::Randomizer::frand() * MaxAngleDegrees);
56
tgt.rotateYZBy(os::Randomizer::frand() * MaxAngleDegrees);
57
tgt.rotateXZBy(os::Randomizer::frand() * MaxAngleDegrees);
58
Particle.vector = tgt;
61
Particle.endTime = now + MinLifeTime;
62
if (MaxLifeTime != MinLifeTime)
63
Particle.endTime += os::Randomizer::rand() % (MaxLifeTime - MinLifeTime);
65
if (MinStartColor==MaxStartColor)
66
Particle.color=MinStartColor;
68
Particle.color = MinStartColor.getInterpolated(MaxStartColor, os::Randomizer::frand());
70
Particle.startColor = Particle.color;
71
Particle.startVector = Particle.vector;
73
if (MinStartSize==MaxStartSize)
74
Particle.startSize = MinStartSize;
76
Particle.startSize = MinStartSize.getInterpolated(MaxStartSize, os::Randomizer::frand());
77
Particle.size = Particle.startSize;
87
//! Writes attributes of the object.
88
void CParticlePointEmitter::serializeAttributes(io::IAttributes* out, io::SAttributeReadWriteOptions* options) const
90
out->addVector3d("Direction", Direction);
91
out->addFloat("MinStartSizeWidth", MinStartSize.Width);
92
out->addFloat("MinStartSizeHeight", MinStartSize.Height);
93
out->addFloat("MaxStartSizeWidth", MaxStartSize.Width);
94
out->addFloat("MaxStartSizeHeight", MaxStartSize.Height);
95
out->addInt("MinParticlesPerSecond", MinParticlesPerSecond);
96
out->addInt("MaxParticlesPerSecond", MaxParticlesPerSecond);
97
out->addColor("MinStartColor", MinStartColor);
98
out->addColor("MaxStartColor", MaxStartColor);
99
out->addInt("MinLifeTime", MinLifeTime);
100
out->addInt("MaxLifeTime", MaxLifeTime);
101
out->addInt("MaxAngleDegrees", MaxAngleDegrees);
104
//! Reads attributes of the object.
105
void CParticlePointEmitter::deserializeAttributes(io::IAttributes* in, io::SAttributeReadWriteOptions* options)
107
Direction = in->getAttributeAsVector3d("Direction");
108
if (Direction.getLength() == 0)
109
Direction.set(0,0.01f,0);
112
idx = in->findAttribute("MinStartSizeWidth");
114
MinStartSize.Width = in->getAttributeAsFloat(idx);
115
idx = in->findAttribute("MinStartSizeHeight");
117
MinStartSize.Height = in->getAttributeAsFloat(idx);
118
idx = in->findAttribute("MaxStartSizeWidth");
120
MaxStartSize.Width = in->getAttributeAsFloat(idx);
121
idx = in->findAttribute("MaxStartSizeHeight");
123
MaxStartSize.Height = in->getAttributeAsFloat(idx);
125
MinParticlesPerSecond = in->getAttributeAsInt("MinParticlesPerSecond");
126
MaxParticlesPerSecond = in->getAttributeAsInt("MaxParticlesPerSecond");
128
MinParticlesPerSecond = core::max_(1u, MinParticlesPerSecond);
129
MaxParticlesPerSecond = core::max_(MaxParticlesPerSecond, 1u);
130
MaxParticlesPerSecond = core::min_(MaxParticlesPerSecond, 200u);
131
MinParticlesPerSecond = core::min_(MinParticlesPerSecond, MaxParticlesPerSecond);
133
MinStartColor = in->getAttributeAsColor("MinStartColor");
134
MaxStartColor = in->getAttributeAsColor("MaxStartColor");
135
MinLifeTime = in->getAttributeAsInt("MinLifeTime");
136
MaxLifeTime = in->getAttributeAsInt("MaxLifeTime");
137
MaxAngleDegrees = in->getAttributeAsInt("MaxAngleDegrees");
139
MinLifeTime = core::max_(0u, MinLifeTime);
140
MaxLifeTime = core::max_(MaxLifeTime, MinLifeTime);
141
MinLifeTime = core::min_(MinLifeTime, MaxLifeTime);
145
} // end namespace scene
146
} // end namespace irr