diff --git a/setup.py b/setup.py index e8f0503..2b306ad 100644 --- a/setup.py +++ b/setup.py @@ -45,7 +45,7 @@ except AttributeError: c_overviewer_files = ['src/main.c', 'src/composite.c', 'src/iterate.c'] -c_overviewer_files += ['src/rendermodes.c', 'src/rendermode-normal.c', 'src/rendermode-lighting.c'] +c_overviewer_files += ['src/rendermodes.c', 'src/rendermode-normal.c', 'src/rendermode-lighting.c', 'src/rendermode-night.c'] setup_kwargs['ext_modules'].append(Extension('c_overviewer', c_overviewer_files, include_dirs=['.', numpy_include], extra_link_args=["/MANIFEST"] if platform.system() == "Windows" else [])) # tell build_ext to build the extension in-place # (NOT in build/) diff --git a/src/rendermode-night.c b/src/rendermode-night.c new file mode 100644 index 0000000..5943b6a --- /dev/null +++ b/src/rendermode-night.c @@ -0,0 +1,66 @@ +/* + * This file is part of the Minecraft Overviewer. + * + * Minecraft Overviewer is free software: you can redistribute it and/or + * modify it under the terms of the GNU General Public License as published + * by the Free Software Foundation, either version 3 of the License, or (at + * your option) any later version. + * + * Minecraft Overviewer is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General + * Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with the Overviewer. If not, see . + */ + +#include "overviewer.h" +#include + +/* figures out the black_coeff from a given skylight and blocklight, used in + lighting calculations -- note this is *different* from the one in + rendermode-lighting.c (the "skylight - 11" part) */ +static float calculate_darkness(unsigned char skylight, unsigned char blocklight) { + return 1.0f - powf(0.8f, 15.0 - MAX(blocklight, skylight - 11)); +} + +static int +rendermode_night_start(void *data, RenderState *state) { + /* first, chain up */ + int ret = rendermode_lighting.start(data, state); + if (ret != 0) + return ret; + + /* override the darkness function with our night version! */ + RenderModeNight* self = (RenderModeNight *)data; + self->parent.calculate_darkness = calculate_darkness; + + return 0; +} + +static void +rendermode_night_finish(void *data, RenderState *state) { + /* nothing special to do */ + rendermode_lighting.finish(data, state); +} + +static int +rendermode_night_occluded(void *data, RenderState *state) { + /* no special occlusion here */ + return rendermode_lighting.occluded(data, state); +} + +static void +rendermode_night_draw(void *data, RenderState *state, PyObject *src, PyObject *mask) { + /* nothing special to do */ + rendermode_lighting.draw(data, state, src, mask); +} + +RenderModeInterface rendermode_night = { + sizeof(RenderModeNight), + rendermode_night_start, + rendermode_night_finish, + rendermode_night_occluded, + rendermode_night_draw, +}; diff --git a/src/rendermodes.c b/src/rendermodes.c index 0642d9d..a5b57cb 100644 --- a/src/rendermodes.c +++ b/src/rendermodes.c @@ -27,6 +27,8 @@ RenderModeInterface *get_render_mode(RenderState *state) { if (strcmp(rendermode, "lighting") == 0) { iface = &rendermode_lighting; + } else if (strcmp(rendermode, "night") == 0) { + iface = &rendermode_night; } Py_DECREF(rendermode_py); diff --git a/src/rendermodes.h b/src/rendermodes.h index 1a693da..5cf185b 100644 --- a/src/rendermodes.h +++ b/src/rendermodes.h @@ -21,12 +21,13 @@ * * add a data struct and extern'd interface declaration below * * * fill in this interface struct in rendermode-(yourmode).c - * (see rendermodes.c for an example: the "normal" mode) + * (see rendermodes-normal.c for an example: the "normal" mode) * * * if you want to derive from (say) the "normal" mode, put * a RenderModeNormal entry at the top of your data struct, and * be sure to call your parent's functions in your own! - * (see rendermode-lighting.c for an example) + * (see rendermode-night.c for a simple example derived from + * the "lighting" mode) * * * add a condition to get_render_mode() in rendermodes.c */ @@ -82,4 +83,11 @@ typedef struct { } RenderModeLighting; extern RenderModeInterface rendermode_lighting; +/* NIGHT */ +typedef struct { + /* inherits from lighting */ + RenderModeLighting parent; +} RenderModeNight; +extern RenderModeInterface rendermode_night; + #endif /* __RENDERMODES_H_INCLUDED__ */