Added Apple Trees

This commit is contained in:
sfan5 2011-09-11 17:50:44 +02:00
parent d28ea57083
commit c0caedc373
6 changed files with 100 additions and 8 deletions

BIN
data/apple.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 203 B

@ -1,4 +1,4 @@
/* /*
Minetest-c55 Minetest-c55
Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com> Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com>
@ -71,6 +71,8 @@ std::string item_craft_get_image_name(const std::string &subname)
return "scorched_stuff.png"; return "scorched_stuff.png";
else if(subname == "firefly") else if(subname == "firefly")
return "firefly.png"; return "firefly.png";
else if(subname == "apple")
return "apple.png";
else else
return "cloud.png"; // just something return "cloud.png"; // just something
} }
@ -94,7 +96,7 @@ ServerActiveObject* item_craft_create_object(const std::string &subname,
s16 item_craft_get_drop_count(const std::string &subname) s16 item_craft_get_drop_count(const std::string &subname)
{ {
if(subname == "rat" || subname == "firefly") if(subname == "rat" || subname == "firefly" || subname == "apple")
return 1; return 1;
return -1; return -1;
@ -126,6 +128,8 @@ bool item_craft_is_eatable(const std::string &subname)
{ {
if(subname == "cooked_rat") if(subname == "cooked_rat")
return true; return true;
else if(subname == "apple")
return true;
return false; return false;
} }
@ -133,6 +137,8 @@ s16 item_craft_eat_hp_change(const std::string &subname)
{ {
if(subname == "cooked_rat") if(subname == "cooked_rat")
return 6; // 3 hearts return 6; // 3 hearts
else if(subname == "apple")
return 12; // 6 hearts
return 0; return 0;
} }

@ -1,4 +1,4 @@
/* /*
Minetest-c55 Minetest-c55
Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com> Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com>
@ -189,6 +189,16 @@ void mapblock_mesh_generate_special(MeshMakeData *data,
g_texturesource->getTextureId("papyrus.png")); g_texturesource->getTextureId("papyrus.png"));
material_papyrus.setTexture(0, pa_papyrus.atlas); material_papyrus.setTexture(0, pa_papyrus.atlas);
// Apple material
video::SMaterial material_apple;
material_apple.setFlag(video::EMF_LIGHTING, false);
material_apple.setFlag(video::EMF_BILINEAR_FILTER, false);
material_apple.setFlag(video::EMF_FOG_ENABLE, true);
material_apple.MaterialType = video::EMT_TRANSPARENT_ALPHA_CHANNEL_REF;
AtlasPointer pa_apple = g_texturesource->getTexture(
g_texturesource->getTextureId("apple.png"));
material_apple.setTexture(0, pa_apple.atlas);
// junglegrass material // junglegrass material
video::SMaterial material_junglegrass; video::SMaterial material_junglegrass;
material_junglegrass.setFlag(video::EMF_LIGHTING, false); material_junglegrass.setFlag(video::EMF_LIGHTING, false);
@ -1203,6 +1213,56 @@ void mapblock_mesh_generate_special(MeshMakeData *data,
// Add to mesh collector // Add to mesh collector
collector.append(material_ladder, vertices, 4, indices, 6); collector.append(material_ladder, vertices, 4, indices, 6);
} }
else if(n.getContent() == CONTENT_APPLE)
{
u8 l = decode_light(undiminish_light(n.getLightBlend(data->m_daynight_ratio)));
video::SColor c = MapBlock_LightColor(255, l);
for(u32 j=0; j<4; j++)
{
video::S3DVertex vertices[4] =
{
video::S3DVertex(-BS/2,-BS/2,0, 0,0,0, c,
pa_apple.x0(), pa_apple.y1()),
video::S3DVertex(BS/2,-BS/2,0, 0,0,0, c,
pa_apple.x1(), pa_apple.y1()),
video::S3DVertex(BS/2,BS/2,0, 0,0,0, c,
pa_apple.x1(), pa_apple.y0()),
video::S3DVertex(-BS/2,BS/2,0, 0,0,0, c,
pa_apple.x0(), pa_apple.y0()),
};
if(j == 0)
{
for(u16 i=0; i<4; i++)
vertices[i].Pos.rotateXZBy(45);
}
else if(j == 1)
{
for(u16 i=0; i<4; i++)
vertices[i].Pos.rotateXZBy(-45);
}
else if(j == 2)
{
for(u16 i=0; i<4; i++)
vertices[i].Pos.rotateXZBy(135);
}
else if(j == 3)
{
for(u16 i=0; i<4; i++)
vertices[i].Pos.rotateXZBy(-135);
}
for(u16 i=0; i<4; i++)
{
vertices[i].Pos += intToFloat(p + blockpos_nodes, BS);
}
u16 indices[] = {0,1,2,2,3,0};
// Add to mesh collector
collector.append(material_apple, vertices, 4, indices, 6);
}
}
} }
} }
#endif #endif

@ -1,4 +1,4 @@
/* /*
Minetest-c55 Minetest-c55
Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com> Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com>
@ -630,6 +630,18 @@ void content_mapnode_init()
f->dug_item = std::string("MaterialItem2 ")+itos(i)+" 1"; f->dug_item = std::string("MaterialItem2 ")+itos(i)+" 1";
setStoneLikeDiggingProperties(f->digging_properties, 3.0); setStoneLikeDiggingProperties(f->digging_properties, 3.0);
i = CONTENT_APPLE;
f = &content_features(i);
f->setInventoryTexture("apple.png");
f->param_type = CPT_LIGHT;
f->light_propagates = true;
f->sunlight_propagates = true;
f->solidness = 0; // drawn separately, makes no faces
f->walkable = false;
f->air_equivalent = true;
f->dug_item = std::string("CraftItem apple 1");
f->digging_properties.set("", DiggingProperties(true, 0.0, 0));
// NOTE: Remember to add frequently used stuff to the texture atlas in tile.cpp // NOTE: Remember to add frequently used stuff to the texture atlas in tile.cpp

@ -1,4 +1,4 @@
/* /*
Minetest-c55 Minetest-c55
Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com> Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com>
@ -83,6 +83,8 @@ MapNode mapnode_translate_to_internal(MapNode n_from, u8 version);
#define CONTENT_JUNGLEGRASS 0x816 #define CONTENT_JUNGLEGRASS 0x816
#define CONTENT_NC 0x817 #define CONTENT_NC 0x817
#define CONTENT_NC_RB 0x818 #define CONTENT_NC_RB 0x818
#define CONTENT_APPLE 0x819
#endif #endif

@ -1,4 +1,4 @@
/* /*
Minetest-c55 Minetest-c55
Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com> Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com>
@ -84,6 +84,11 @@ static void make_tree(VoxelManipulator &vmanip, v3s16 p0)
{ {
MapNode treenode(CONTENT_TREE); MapNode treenode(CONTENT_TREE);
MapNode leavesnode(CONTENT_LEAVES); MapNode leavesnode(CONTENT_LEAVES);
MapNode applenode(CONTENT_APPLE);
bool is_apple_tree = myrand_range(0,100) < 35?true:false;
s16 apple_count = 0;
s16 trunk_h = myrand_range(4, 5); s16 trunk_h = myrand_range(4, 5);
v3s16 p1 = p0; v3s16 p1 = p0;
@ -138,6 +143,7 @@ static void make_tree(VoxelManipulator &vmanip, v3s16 p0)
for(s16 y=leaves_a.MinEdge.Y; y<=leaves_a.MaxEdge.Y; y++) for(s16 y=leaves_a.MinEdge.Y; y<=leaves_a.MaxEdge.Y; y++)
for(s16 x=leaves_a.MinEdge.X; x<=leaves_a.MaxEdge.X; x++) for(s16 x=leaves_a.MinEdge.X; x<=leaves_a.MaxEdge.X; x++)
{ {
bool is_apple = myrand_range(0,100) < 50?true:false;
v3s16 p(x,y,z); v3s16 p(x,y,z);
p += p1; p += p1;
if(vmanip.m_area.contains(p) == false) if(vmanip.m_area.contains(p) == false)
@ -147,8 +153,14 @@ static void make_tree(VoxelManipulator &vmanip, v3s16 p0)
&& vmanip.m_data[vi].getContent() != CONTENT_IGNORE) && vmanip.m_data[vi].getContent() != CONTENT_IGNORE)
continue; continue;
u32 i = leaves_a.index(x,y,z); u32 i = leaves_a.index(x,y,z);
if(leaves_d[i] == 1) if(leaves_d[i] == 1) {
vmanip.m_data[vi] = leavesnode; if(is_apple_tree && is_apple && apple_count < 4) {
vmanip.m_data[vi] = applenode;
apple_count++;
} else {
vmanip.m_data[vi] = leavesnode;
}
}
} }
} }