|
@@ -1,276 +1,276 @@
|
|
#include "BasicBlocks.h"
|
|
#include "BasicBlocks.h"
|
|
|
|
|
|
|
|
|
|
-BasicBlock::BasicBlock( const BlockType* zType, ItemType* zTool, Framework::Vec3<int> pos )
|
|
|
|
- : Block( zType, zTool, pos, false )
|
|
|
|
|
|
+BasicBlock::BasicBlock(const BlockType* zType, ItemType* zTool, Framework::Vec3<int> pos)
|
|
|
|
+ : Block(zType, zTool, pos, false)
|
|
{}
|
|
{}
|
|
|
|
|
|
-bool BasicBlock::onTick( TickQueue* zQueue, int numTicks, bool& blocked )
|
|
|
|
|
|
+bool BasicBlock::onTick(TickQueue* zQueue, int numTicks, bool& blocked)
|
|
{
|
|
{
|
|
- return 0;
|
|
|
|
|
|
+ return 0;
|
|
}
|
|
}
|
|
|
|
|
|
void BasicBlock::onPostTick()
|
|
void BasicBlock::onPostTick()
|
|
{}
|
|
{}
|
|
|
|
|
|
|
|
|
|
-BasicBlockType::BasicBlockType( int typeId, int itemTypeId )
|
|
|
|
- : BlockType( typeId, 0 ),
|
|
|
|
- itemType( itemTypeId ),
|
|
|
|
- transparent( 0 ),
|
|
|
|
- passable( 0 ),
|
|
|
|
- maxHp( 100.f ),
|
|
|
|
- hardness( 1.f ),
|
|
|
|
- zTool( 0 ),
|
|
|
|
- speedModifier( 1.f ),
|
|
|
|
- interactable( 1 )
|
|
|
|
|
|
+BasicBlockType::BasicBlockType(int typeId, int itemTypeId)
|
|
|
|
+ : BlockType(typeId, 0),
|
|
|
|
+ itemType(itemTypeId),
|
|
|
|
+ transparent(0),
|
|
|
|
+ passable(0),
|
|
|
|
+ maxHp(100.f),
|
|
|
|
+ hardness(1.f),
|
|
|
|
+ zTool(0),
|
|
|
|
+ speedModifier(1.f),
|
|
|
|
+ interactable(1)
|
|
{}
|
|
{}
|
|
|
|
|
|
-void BasicBlockType::createSuperBlock( Block* zBlock, Item* zItem ) const
|
|
|
|
|
|
+void BasicBlockType::createSuperBlock(Block* zBlock, Item* zItem) const
|
|
{
|
|
{
|
|
- if( zItem )
|
|
|
|
- BlockType::createSuperBlock( zBlock, zItem );
|
|
|
|
- else
|
|
|
|
- {
|
|
|
|
- BasicBlock* block = dynamic_cast<BasicBlock*>(zBlock);
|
|
|
|
- if( !block )
|
|
|
|
- throw "DirtBlockType::createSuperBlock was called with a block witch is not an instance of BasicBlock";
|
|
|
|
- block->transparent = transparent;
|
|
|
|
- block->passable = passable;
|
|
|
|
- block->hp = maxHp;
|
|
|
|
- block->maxHP = maxHp;
|
|
|
|
- block->hardness = hardness;
|
|
|
|
- block->zTool = zTool;
|
|
|
|
- block->speedModifier = speedModifier;
|
|
|
|
- block->interactable = interactable;
|
|
|
|
- }
|
|
|
|
|
|
+ if (zItem)
|
|
|
|
+ BlockType::createSuperBlock(zBlock, zItem);
|
|
|
|
+ else
|
|
|
|
+ {
|
|
|
|
+ BasicBlock* block = dynamic_cast<BasicBlock*>(zBlock);
|
|
|
|
+ if (!block)
|
|
|
|
+ throw "DirtBlockType::createSuperBlock was called with a block witch is not an instance of BasicBlock";
|
|
|
|
+ block->transparent = transparent;
|
|
|
|
+ block->passable = passable;
|
|
|
|
+ block->hp = maxHp;
|
|
|
|
+ block->maxHP = maxHp;
|
|
|
|
+ block->hardness = hardness;
|
|
|
|
+ block->zTool = zTool;
|
|
|
|
+ block->speedModifier = speedModifier;
|
|
|
|
+ block->interactable = interactable;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
-Block* BasicBlockType::createBlock( Framework::Vec3<int> position ) const
|
|
|
|
|
|
+Block* BasicBlockType::createBlock(Framework::Vec3<int> position) const
|
|
{
|
|
{
|
|
- return new BasicBlock( this, 0, position );
|
|
|
|
|
|
+ return new BasicBlock(this, 0, position);
|
|
}
|
|
}
|
|
|
|
|
|
Item* BasicBlockType::createItem() const
|
|
Item* BasicBlockType::createItem() const
|
|
{
|
|
{
|
|
- return StaticRegistry<ItemType>::INSTANCE.zElement( itemType )->createItem();
|
|
|
|
|
|
+ return StaticRegistry<ItemType>::INSTANCE.zElement(itemType)->createItem();
|
|
}
|
|
}
|
|
|
|
|
|
// Dirt
|
|
// Dirt
|
|
DirtBlockType::DirtBlockType()
|
|
DirtBlockType::DirtBlockType()
|
|
- : BasicBlockType( ID, DirtBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, DirtBlockItemType::ID)
|
|
{
|
|
{
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
DirtBlockItemType::DirtBlockItemType()
|
|
DirtBlockItemType::DirtBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Dirt", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* DirtBlockItemType::createItem() const
|
|
Item* DirtBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, DirtBlockType::INSTANCE, "Dirt" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 1, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, DirtBlockType::INSTANCE, "Dirt");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 1, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Stone
|
|
// Stone
|
|
StoneBlockType::StoneBlockType()
|
|
StoneBlockType::StoneBlockType()
|
|
- : BasicBlockType( ID, StoneBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, StoneBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 2.f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 2.f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
StoneBlockItemType::StoneBlockItemType()
|
|
StoneBlockItemType::StoneBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Stone", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* StoneBlockItemType::createItem() const
|
|
Item* StoneBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, StoneBlockType::INSTANCE, "Stone" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 2, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, StoneBlockType::INSTANCE, "Stone");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 2, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Sand
|
|
// Sand
|
|
SandBlockType::SandBlockType()
|
|
SandBlockType::SandBlockType()
|
|
- : BasicBlockType( ID, SandBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, SandBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 0.5f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 0.5f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
SandBlockItemType::SandBlockItemType()
|
|
SandBlockItemType::SandBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Sand", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* SandBlockItemType::createItem() const
|
|
Item* SandBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, SandBlockType::INSTANCE, "Sand" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 0.5f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, SandBlockType::INSTANCE, "Sand");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 0.5f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Oak Wood
|
|
// Oak Wood
|
|
OakBlockType::OakBlockType()
|
|
OakBlockType::OakBlockType()
|
|
- : BasicBlockType( ID, OakBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, OakBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 1.5f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 1.5f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
OakBlockItemType::OakBlockItemType()
|
|
OakBlockItemType::OakBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Oak", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* OakBlockItemType::createItem() const
|
|
Item* OakBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, OakBlockType::INSTANCE, "Oak" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 1.5f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, OakBlockType::INSTANCE, "Oak");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 1.5f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Leaves Wood
|
|
// Leaves Wood
|
|
LeavesBlockType::LeavesBlockType()
|
|
LeavesBlockType::LeavesBlockType()
|
|
- : BasicBlockType( ID, LeavesBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, LeavesBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 0.1f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 0.1f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
LeavesBlockItemType::LeavesBlockItemType()
|
|
LeavesBlockItemType::LeavesBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Leaves", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* LeavesBlockItemType::createItem() const
|
|
Item* LeavesBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, LeavesBlockType::INSTANCE, "Leaves" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 0.1f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, LeavesBlockType::INSTANCE, "Leaves");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 0.1f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Gravel
|
|
// Gravel
|
|
GravelBlockType::GravelBlockType()
|
|
GravelBlockType::GravelBlockType()
|
|
- : BasicBlockType( ID, GravelBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, GravelBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 0.75f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 0.75f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
GravelBlockItemType::GravelBlockItemType()
|
|
GravelBlockItemType::GravelBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Gravel", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* GravelBlockItemType::createItem() const
|
|
Item* GravelBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, GravelBlockType::INSTANCE, "Gravel" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 0.75f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, GravelBlockType::INSTANCE, "Gravel");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 0.75f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Granite
|
|
// Granite
|
|
GraniteBlockType::GraniteBlockType()
|
|
GraniteBlockType::GraniteBlockType()
|
|
- : BasicBlockType( ID, GraniteBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, GraniteBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 3.f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 3.f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
GraniteBlockItemType::GraniteBlockItemType()
|
|
GraniteBlockItemType::GraniteBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Granite", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* GraniteBlockItemType::createItem() const
|
|
Item* GraniteBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, GraniteBlockType::INSTANCE, "Granite" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 3.f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, GraniteBlockType::INSTANCE, "Granite");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 3.f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Cobble
|
|
// Cobble
|
|
CobbleBlockType::CobbleBlockType()
|
|
CobbleBlockType::CobbleBlockType()
|
|
- : BasicBlockType( ID, CobbleBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, CobbleBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 1.f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 1.f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
CobbleBlockItemType::CobbleBlockItemType()
|
|
CobbleBlockItemType::CobbleBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Cobble", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* CobbleBlockItemType::createItem() const
|
|
Item* CobbleBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, CobbleBlockType::INSTANCE, "Cobble" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 1.f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, CobbleBlockType::INSTANCE, "Cobble");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 1.f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Birch Wood
|
|
// Birch Wood
|
|
BirchBlockType::BirchBlockType()
|
|
BirchBlockType::BirchBlockType()
|
|
- : BasicBlockType( ID, BirchBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, BirchBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 1.5f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 1.5f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
BirchBlockItemType::BirchBlockItemType()
|
|
BirchBlockItemType::BirchBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Birch", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* BirchBlockItemType::createItem() const
|
|
Item* BirchBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, BirchBlockType::INSTANCE, "Birch" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 1.5f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, BirchBlockType::INSTANCE, "Birch");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 1.5f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Beech Wood
|
|
// Beech Wood
|
|
BeechBlockType::BeechBlockType()
|
|
BeechBlockType::BeechBlockType()
|
|
- : BasicBlockType( ID, BeechBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, BeechBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 1.5f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 1.5f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
BeechBlockItemType::BeechBlockItemType()
|
|
BeechBlockItemType::BeechBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Beech", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* BeechBlockItemType::createItem() const
|
|
Item* BeechBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, BeechBlockType::INSTANCE, "Beech" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 1.5f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, BeechBlockType::INSTANCE, "Beech");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 1.5f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|
|
|
|
|
|
// Basalt
|
|
// Basalt
|
|
BasaltBlockType::BasaltBlockType()
|
|
BasaltBlockType::BasaltBlockType()
|
|
- : BasicBlockType( ID, BasaltBlockItemType::ID )
|
|
|
|
|
|
+ : BasicBlockType(ID, BasaltBlockItemType::ID)
|
|
{
|
|
{
|
|
- hardness = 2.f;
|
|
|
|
- defaultBlock = createBlockAt( { 0, 0, 0 }, 0 );
|
|
|
|
|
|
+ hardness = 2.f;
|
|
|
|
+ defaultBlock = createBlockAt({ 0, 0, 0 }, 0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
BasaltBlockItemType::BasaltBlockItemType()
|
|
BasaltBlockItemType::BasaltBlockItemType()
|
|
- : BasicBlockItemType( ID, 0, 0 )
|
|
|
|
|
|
+ : BasicBlockItemType(ID, "Basalt", 0, 0)
|
|
{}
|
|
{}
|
|
|
|
|
|
Item* BasaltBlockItemType::createItem() const
|
|
Item* BasaltBlockItemType::createItem() const
|
|
{
|
|
{
|
|
- BasicBlockItem* item = new BasicBlockItem( this, BasaltBlockType::INSTANCE, "Basalt" );
|
|
|
|
- initializeItem( item, 0, 0, 100, 100, 2.f, 0, 1 );
|
|
|
|
- return item;
|
|
|
|
|
|
+ BasicBlockItem* item = new BasicBlockItem(this, BasaltBlockType::INSTANCE, "Basalt");
|
|
|
|
+ initializeItem(item, 0, 0, 100, 100, 2.f, 0, 1);
|
|
|
|
+ return item;
|
|
}
|
|
}
|