2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2012-09-23 18:09:57 -04:00
|
|
|
#include "Simulator.h"
|
2020-04-03 02:57:01 -04:00
|
|
|
#include "../IniFile.h"
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2013-03-01 14:35:29 -05:00
|
|
|
/** The fire simulator takes care of the fire blocks.
|
|
|
|
It periodically increases their meta ("steps") until they "burn out"; it also supports the forever burning netherrack.
|
|
|
|
Each individual fire block gets stored in per-chunk data; that list is then used for fast retrieval.
|
|
|
|
The data value associated with each coord is used as the number of msec that the fire takes until
|
|
|
|
it progresses to the next step (blockmeta++). This value is updated if a neighbor is changed.
|
|
|
|
The simulator reads its parameters from the ini file given to the constructor.
|
|
|
|
*/
|
|
|
|
class cFireSimulator :
|
2014-10-25 16:54:00 -04:00
|
|
|
public cSimulator
|
2012-06-14 09:06:06 -04:00
|
|
|
{
|
|
|
|
public:
|
2020-07-28 20:18:59 -04:00
|
|
|
|
2013-03-01 14:35:29 -05:00
|
|
|
cFireSimulator(cWorld & a_World, cIniFile & a_IniFile);
|
2020-07-28 20:18:59 -04:00
|
|
|
|
|
|
|
static bool IsFuel (BLOCKTYPE a_BlockType);
|
|
|
|
static bool DoesBurnForever(BLOCKTYPE a_BlockType);
|
|
|
|
|
|
|
|
private:
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2013-12-22 08:46:55 -05:00
|
|
|
virtual void Simulate(float a_Dt) override { UNUSED(a_Dt);} // not used
|
2015-01-11 16:12:26 -05:00
|
|
|
virtual void SimulateChunk(std::chrono::milliseconds a_Dt, int a_ChunkX, int a_ChunkZ, cChunk * a_Chunk) override;
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2020-07-28 20:18:59 -04:00
|
|
|
static bool IsAllowedBlock(BLOCKTYPE a_BlockType);
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2015-07-31 10:49:10 -04:00
|
|
|
/** Time (in msec) that a fire block takes to burn with a fuel block into the next step */
|
2013-03-01 14:35:29 -05:00
|
|
|
unsigned m_BurnStepTimeFuel;
|
|
|
|
|
2015-07-31 10:49:10 -04:00
|
|
|
/** Time (in msec) that a fire block takes to burn without a fuel block into the next step */
|
2013-03-01 14:35:29 -05:00
|
|
|
unsigned m_BurnStepTimeNonfuel;
|
|
|
|
|
2015-07-31 10:49:10 -04:00
|
|
|
/** Chance [0..100000] of an adjacent fuel to catch fire on each tick */
|
2013-04-13 17:02:10 -04:00
|
|
|
int m_Flammability;
|
2016-02-05 16:45:45 -05:00
|
|
|
|
2015-07-31 10:49:10 -04:00
|
|
|
/** Chance [0..100000] of a fuel burning out being replaced by a new fire block instead of an air block */
|
2013-04-13 17:02:10 -04:00
|
|
|
int m_ReplaceFuelChance;
|
2016-02-05 16:45:45 -05:00
|
|
|
|
2020-07-28 19:12:45 -04:00
|
|
|
virtual void AddBlock(cChunk & a_Chunk, Vector3i a_Position, BLOCKTYPE a_Block) override;
|
2016-02-05 16:45:45 -05:00
|
|
|
|
2015-07-31 10:49:10 -04:00
|
|
|
/** Returns the time [msec] after which the specified fire block is stepped again; based on surrounding fuels */
|
2019-10-11 05:02:53 -04:00
|
|
|
int GetBurnStepTime(cChunk * a_Chunk, Vector3i a_RelPos);
|
2016-02-05 16:45:45 -05:00
|
|
|
|
2015-07-31 10:49:10 -04:00
|
|
|
/** Tries to spread fire to a neighborhood of the specified block */
|
2019-10-11 05:02:53 -04:00
|
|
|
void TrySpreadFire(cChunk * a_Chunk, Vector3i a_RelPos);
|
2016-02-05 16:45:45 -05:00
|
|
|
|
2015-07-31 10:49:10 -04:00
|
|
|
/** Removes all burnable blocks neighboring the specified block */
|
2019-10-11 05:02:53 -04:00
|
|
|
void RemoveFuelNeighbors(cChunk * a_Chunk, Vector3i a_RelPos);
|
2016-02-05 16:45:45 -05:00
|
|
|
|
2013-03-01 14:35:29 -05:00
|
|
|
/** Returns true if a fire can be started in the specified block,
|
|
|
|
that is, it is an air block and has fuel next to it.
|
|
|
|
Note that a_NearChunk may be a chunk neighbor to the block specified!
|
2015-07-31 10:49:10 -04:00
|
|
|
The coords are relative to a_NearChunk but not necessarily in it. */
|
2019-10-11 05:02:53 -04:00
|
|
|
bool CanStartFireInBlock(cChunk * a_NearChunk, Vector3i a_RelPos);
|
2013-03-01 14:35:29 -05:00
|
|
|
} ;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2015-07-31 10:49:10 -04:00
|
|
|
/** Stores individual fire blocks in the chunk; the int data is used as the time [msec] the fire takes to step to another stage (blockmeta++) */
|
2013-03-01 14:35:29 -05:00
|
|
|
typedef cCoordWithIntList cFireSimulatorChunkData;
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|