summaryrefslogtreecommitdiff
path: root/src/content_mapnode.cpp
diff options
context:
space:
mode:
authorPerttu Ahola <celeron55@gmail.com>2011-08-15 02:04:56 +0300
committerPerttu Ahola <celeron55@gmail.com>2011-08-15 02:04:56 +0300
commit8f42a8be0c760322207287e50b624bd3d388a2e1 (patch)
treeebaadb35b922e2b3c0a3ef25a4841baf5c32c743 /src/content_mapnode.cpp
parentc4b707bca265c0c7a76abe01d6c36f354b7010fe (diff)
downloadminetest-8f42a8be0c760322207287e50b624bd3d388a2e1.tar.gz
minetest-8f42a8be0c760322207287e50b624bd3d388a2e1.tar.bz2
minetest-8f42a8be0c760322207287e50b624bd3d388a2e1.zip
lava!
Diffstat (limited to 'src/content_mapnode.cpp')
-rw-r--r--src/content_mapnode.cpp109
1 files changed, 108 insertions, 1 deletions
diff --git a/src/content_mapnode.cpp b/src/content_mapnode.cpp
index b164033db..3c1353467 100644
--- a/src/content_mapnode.cpp
+++ b/src/content_mapnode.cpp
@@ -372,6 +372,21 @@ void content_mapnode_init()
f->liquid_type = LIQUID_FLOWING;
f->liquid_alternative_flowing = CONTENT_WATER;
f->liquid_alternative_source = CONTENT_WATERSOURCE;
+ f->vertex_alpha = 160;
+ if(f->special_material == NULL && g_texturesource)
+ {
+ // Flowing water material
+ f->special_material = new video::SMaterial;
+ f->special_material->setFlag(video::EMF_LIGHTING, false);
+ f->special_material->setFlag(video::EMF_BACK_FACE_CULLING, false);
+ f->special_material->setFlag(video::EMF_BILINEAR_FILTER, false);
+ f->special_material->setFlag(video::EMF_FOG_ENABLE, true);
+ f->special_material->MaterialType = video::EMT_TRANSPARENT_VERTEX_ALPHA;
+ AtlasPointer *pa_water1 = new AtlasPointer(g_texturesource->getTexture(
+ g_texturesource->getTextureId("water.png")));
+ f->special_material->setTexture(0, pa_water1->atlas);
+ f->special_atlas = pa_water1;
+ }
i = CONTENT_WATERSOURCE;
f = &content_features(i);
@@ -389,7 +404,7 @@ void content_mapnode_init()
if(g_texturesource)
t.texture = g_texturesource->getTexture("water.png");
- t.alpha = WATER_ALPHA;
+ t.alpha = 160;
t.material_type = MATERIAL_ALPHA_VERTEX;
t.material_flags &= ~MATERIAL_FLAG_BACKFACE_CULLING;
f->setAllTiles(t);
@@ -404,6 +419,98 @@ void content_mapnode_init()
f->dug_item = std::string("MaterialItem2 ")+itos(i)+" 1";
f->liquid_alternative_flowing = CONTENT_WATER;
f->liquid_alternative_source = CONTENT_WATERSOURCE;
+ f->vertex_alpha = 160;
+ if(f->special_material == NULL && g_texturesource)
+ {
+ // Flowing water material
+ f->special_material = new video::SMaterial;
+ f->special_material->setFlag(video::EMF_LIGHTING, false);
+ f->special_material->setFlag(video::EMF_BACK_FACE_CULLING, false);
+ f->special_material->setFlag(video::EMF_BILINEAR_FILTER, false);
+ f->special_material->setFlag(video::EMF_FOG_ENABLE, true);
+ f->special_material->MaterialType = video::EMT_TRANSPARENT_VERTEX_ALPHA;
+ AtlasPointer *pa_water1 = new AtlasPointer(g_texturesource->getTexture(
+ g_texturesource->getTextureId("water.png")));
+ f->special_material->setTexture(0, pa_water1->atlas);
+ f->special_atlas = pa_water1;
+ }
+
+ i = CONTENT_LAVA;
+ f = &content_features(i);
+ f->setInventoryTextureCube("lava.png", "lava.png", "lava.png");
+ f->param_type = CPT_LIGHT;
+ f->light_propagates = false;
+ f->light_source = LIGHT_MAX-1;
+ f->solidness = 0; // Drawn separately, makes no faces
+ f->walkable = false;
+ f->pointable = false;
+ f->diggable = false;
+ f->buildable_to = true;
+ f->liquid_type = LIQUID_FLOWING;
+ f->liquid_alternative_flowing = CONTENT_LAVA;
+ f->liquid_alternative_source = CONTENT_LAVASOURCE;
+ if(f->special_material == NULL && g_texturesource)
+ {
+ // Flowing lava material
+ f->special_material = new video::SMaterial;
+ f->special_material->setFlag(video::EMF_LIGHTING, false);
+ f->special_material->setFlag(video::EMF_BACK_FACE_CULLING, false);
+ f->special_material->setFlag(video::EMF_BILINEAR_FILTER, false);
+ f->special_material->setFlag(video::EMF_FOG_ENABLE, true);
+ f->special_material->MaterialType = video::EMT_TRANSPARENT_VERTEX_ALPHA;
+ AtlasPointer *pa_lava1 = new AtlasPointer(
+ g_texturesource->getTexture(
+ g_texturesource->getTextureId("lava.png")));
+ f->special_material->setTexture(0, pa_lava1->atlas);
+ f->special_atlas = pa_lava1;
+ }
+
+ i = CONTENT_LAVASOURCE;
+ f = &content_features(i);
+ f->setInventoryTextureCube("lava.png", "lava.png", "lava.png");
+ if(new_style_water)
+ {
+ f->solidness = 0; // drawn separately, makes no faces
+ }
+ else // old style
+ {
+ f->solidness = 2;
+
+ TileSpec t;
+ if(g_texturesource)
+ t.texture = g_texturesource->getTexture("lava.png");
+
+ //t.alpha = 255;
+ //t.material_type = MATERIAL_ALPHA_VERTEX;
+ //t.material_flags &= ~MATERIAL_FLAG_BACKFACE_CULLING;
+ f->setAllTiles(t);
+ }
+ f->param_type = CPT_LIGHT;
+ f->light_propagates = false;
+ f->light_source = LIGHT_MAX-1;
+ f->walkable = false;
+ f->pointable = false;
+ f->diggable = false;
+ f->buildable_to = true;
+ f->liquid_type = LIQUID_SOURCE;
+ f->dug_item = std::string("MaterialItem2 ")+itos(i)+" 1";
+ f->liquid_alternative_flowing = CONTENT_LAVA;
+ f->liquid_alternative_source = CONTENT_LAVASOURCE;
+ if(f->special_material == NULL && g_texturesource)
+ {
+ // Flowing lava material
+ f->special_material = new video::SMaterial;
+ f->special_material->setFlag(video::EMF_LIGHTING, false);
+ f->special_material->setFlag(video::EMF_BACK_FACE_CULLING, false);
+ f->special_material->setFlag(video::EMF_BILINEAR_FILTER, false);
+ f->special_material->setFlag(video::EMF_FOG_ENABLE, true);
+ f->special_material->MaterialType = video::EMT_TRANSPARENT_VERTEX_ALPHA;
+ AtlasPointer *pa_lava1 = new AtlasPointer(
+ g_texturesource->getTexture(
+ g_texturesource->getTextureId("lava.png")));
+ f->special_material->setTexture(0, pa_lava1->atlas);
+ f->special_atlas = pa_lava1;
+ }
i = CONTENT_TORCH;
f = &content_features(i);