- added new rendering module as part of the existing scene module - support for individual scene rendering - support for yafray rendering
1130 lines
34 KiB
C
1130 lines
34 KiB
C
/*
|
|
*
|
|
* ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
|
|
*
|
|
* This program 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 2
|
|
* of the License, or (at your option) any later version. The Blender
|
|
* Foundation also sells licenses for use in proprietary software under
|
|
* the Blender License. See http://www.blender.org/BL/ for information
|
|
* about this.
|
|
*
|
|
* This program 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 this program; if not, write to the Free Software Foundation,
|
|
* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
|
|
* All rights reserved.
|
|
*
|
|
* This is a new part of Blender.
|
|
*
|
|
* Contributor(s): Joseph Gilbert
|
|
*
|
|
* ***** END GPL/BL DUAL LICENSE BLOCK *****
|
|
*/
|
|
|
|
#include "sceneRender.h"
|
|
|
|
RE_Render R;
|
|
|
|
|
|
/*****************************************************************************/
|
|
// Python funciton definitions for Render module
|
|
/*****************************************************************************/
|
|
|
|
PyObject *M_Render_Render(PyObject *self)
|
|
{
|
|
Scene* oldsce;
|
|
|
|
oldsce= G.scene;
|
|
set_scene(((BPy_Scene*)self)->scene);
|
|
BIF_do_render(0);
|
|
set_scene(oldsce);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_RenderAnim(PyObject *self)
|
|
{
|
|
Scene* oldsce;
|
|
|
|
oldsce= G.scene;
|
|
set_scene(((BPy_Scene*)self)->scene);
|
|
BIF_do_render(1);
|
|
set_scene(oldsce);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_CloseRenderWindow(PyObject *self)
|
|
{
|
|
BIF_close_render_display();
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_Play(PyObject *self)
|
|
{
|
|
char file[FILE_MAXDIR+FILE_MAXFILE];
|
|
extern char bprogname[];
|
|
char str[FILE_MAXDIR+FILE_MAXFILE];
|
|
int pos[2], size[2];
|
|
char txt[64];
|
|
|
|
#ifdef WITH_QUICKTIME
|
|
if(((BPy_Scene*)self)->scene->r.imtype == R_QUICKTIME){
|
|
|
|
strcpy(file, ((BPy_Scene*)self)->scene->r.pic);
|
|
BLI_convertstringcode(file, ((BPy_Scene*)self)->scene, ((BPy_Scene*)self)->scene->r.cfra);
|
|
RE_make_existing_file(file);
|
|
if (strcasecmp(file + strlen(file) - 4, ".mov")) {
|
|
sprintf(txt, "%04d_%04d.mov", (((BPy_Scene*)self)->scene->r.sfra) ,
|
|
(((BPy_Scene*)self)->scene->r.efra));
|
|
strcat(file, txt);
|
|
}
|
|
}else
|
|
#endif
|
|
{
|
|
|
|
strcpy(file, ((BPy_Scene*)self)->scene->r.pic);
|
|
BLI_convertstringcode(file, G.sce, ((BPy_Scene*)self)->scene->r.cfra);
|
|
RE_make_existing_file(file);
|
|
if (strcasecmp(file + strlen(file) - 4, ".avi")) {
|
|
sprintf(txt, "%04d_%04d.avi", (((BPy_Scene*)self)->scene->r.sfra) ,
|
|
(((BPy_Scene*)self)->scene->r.efra) );
|
|
strcat(file, txt);
|
|
}
|
|
}
|
|
if(BLI_exist(file)) {
|
|
calc_renderwin_rectangle(R.winpos, pos, size);
|
|
sprintf(str, "%s -a -p %d %d \"%s\"", bprogname, pos[0], pos[1], file);
|
|
system(str);
|
|
}
|
|
else {
|
|
makepicstring(file, ((BPy_Scene*)self)->scene->r.sfra);
|
|
if(BLI_exist(file)) {
|
|
calc_renderwin_rectangle(R.winpos, pos, size);
|
|
sprintf(str, "%s -a -p %d %d \"%s\"", bprogname, pos[0], pos[1], file);
|
|
system(str);
|
|
}
|
|
else sprintf("Can't find image: %s", file);
|
|
}
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
static PyObject *M_Render_BitToggleInt(PyObject *args, int setting, int *structure)
|
|
{
|
|
int flag;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &flag))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected int"));
|
|
|
|
if(flag < 0 || flag > 1)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected 0 or 1"));
|
|
|
|
if(flag)
|
|
*structure |= setting;
|
|
else
|
|
*structure &= ~setting;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
|
|
}
|
|
|
|
static PyObject *M_Render_BitToggleShort(PyObject *args, short setting, short *structure)
|
|
{
|
|
int flag;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &flag))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected int"));
|
|
|
|
if(flag < 0 || flag > 1)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected 0 or 1"));
|
|
|
|
if(flag)
|
|
*structure |= setting;
|
|
else
|
|
*structure &= ~setting;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
|
|
}
|
|
|
|
static PyObject *M_Render_GetSetAttributeFloat(PyObject *args, float *structure, float min, float max)
|
|
{
|
|
float property = -10.0f;
|
|
char error[48];
|
|
|
|
if (!PyArg_ParseTuple(args, "|f", &property))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected float"));
|
|
|
|
if(property != -10.0f){
|
|
if(property < min || property > max){
|
|
sprintf(error, "out of range - expected %f to %f", min, max);
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError, error));
|
|
}
|
|
|
|
*structure = property;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
return EXPP_incr_ret(Py_None);
|
|
}else
|
|
return Py_BuildValue("f", *structure);
|
|
}
|
|
|
|
static PyObject *M_Render_GetSetAttributeShort(PyObject *args, short *structure, int min, int max)
|
|
{
|
|
short property = -10;
|
|
char error[48];
|
|
|
|
if (!PyArg_ParseTuple(args, "|h", &property))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected int"));
|
|
|
|
if(property != -10){
|
|
if(property < min || property > max){
|
|
sprintf(error, "out of range - expected %d to %d", min, max);
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError, error));
|
|
}
|
|
|
|
*structure = property;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
return EXPP_incr_ret(Py_None);
|
|
}else
|
|
return Py_BuildValue("h", *structure);
|
|
}
|
|
|
|
static PyObject *M_Render_GetSetAttributeInt(PyObject *args, int *structure, int min, int max)
|
|
{
|
|
int property = -10;
|
|
char error[48];
|
|
|
|
if (!PyArg_ParseTuple(args, "|i", &property))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected int"));
|
|
|
|
if(property != -10){
|
|
if(property < min || property > max){
|
|
sprintf(error, "out of range - expected %d to %d", min, max);
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError, error));
|
|
}
|
|
|
|
*structure = property;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
return EXPP_incr_ret(Py_None);
|
|
}else
|
|
return Py_BuildValue("i", *structure);
|
|
}
|
|
|
|
PyObject *M_Render_SetRenderPath(PyObject *self, PyObject *args)
|
|
{
|
|
char *name;
|
|
|
|
if (!PyArg_ParseTuple(args, "s", &name))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected a string"));
|
|
|
|
if(strlen(name) > 160)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"path is too long (SetRenderPath)"));
|
|
|
|
strcpy(((BPy_Scene*)self)->scene->r.pic, name);
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_GetRenderPath(PyObject *self)
|
|
{
|
|
return Py_BuildValue("s", ((BPy_Scene*)self)->scene->r.pic);
|
|
}
|
|
|
|
PyObject *M_Render_SetBackbufPath(PyObject *self, PyObject *args)
|
|
{
|
|
char *name;
|
|
Image *ima;
|
|
|
|
if (!PyArg_ParseTuple(args, "s", &name))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected a string"));
|
|
|
|
if(strlen(name) > 160)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"path is too long (SetBackbufPath)"));
|
|
|
|
strcpy(((BPy_Scene*)self)->scene->r.backbuf, name);
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
ima= add_image(name);
|
|
if(ima) {
|
|
free_image_buffers(ima);
|
|
ima->ok= 1;
|
|
}
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_GetBackbufPath(PyObject *self)
|
|
{
|
|
return Py_BuildValue("s", ((BPy_Scene*)self)->scene->r.backbuf);
|
|
}
|
|
|
|
PyObject *M_Render_EnableBackbuf(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleShort(args, 1, &((BPy_Scene*)self)->scene->r.bufflag);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetFtypePath(PyObject *self, PyObject *args)
|
|
{
|
|
char *name;
|
|
|
|
if (!PyArg_ParseTuple(args, "s", &name))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected a string"));
|
|
|
|
if(strlen(name) > 160)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"path is too long (SetFtypePath)"));
|
|
|
|
strcpy(((BPy_Scene*)self)->scene->r.ftype, name);
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_GetFtypePath(PyObject *self)
|
|
{
|
|
return Py_BuildValue("s", ((BPy_Scene*)self)->scene->r.ftype);
|
|
}
|
|
|
|
|
|
PyObject *M_Render_EnableExtensions(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleShort(args, R_EXTENSION, &((BPy_Scene*)self)->scene->r.scemode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableSequencer(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleShort(args, R_DOSEQ, &((BPy_Scene*)self)->scene->r.scemode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableRenderDaemon(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleShort(args, R_BG_RENDER, &((BPy_Scene*)self)->scene->r.scemode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetRenderWinPos(PyObject *self, PyObject *args)
|
|
{
|
|
PyObject *list = NULL;
|
|
char *loc = NULL;
|
|
int x;
|
|
|
|
if (!PyArg_ParseTuple(args, "O!", &PyList_Type, &list))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected a list"));
|
|
|
|
R.winpos = 0;
|
|
for (x = 0; x < PyList_Size(list); x++) {
|
|
if (!PyArg_Parse(PyList_GetItem(list, x), "s", &loc)){
|
|
return EXPP_ReturnPyObjError (PyExc_TypeError,
|
|
"python list not parseable\n");
|
|
}
|
|
if(strcmp(loc,"SW") == 0 || strcmp(loc,"sw") == 0)
|
|
R.winpos |= 1;
|
|
else if (strcmp(loc,"S") == 0 || strcmp(loc,"s") == 0)
|
|
R.winpos |= 2;
|
|
else if (strcmp(loc,"SE") == 0 || strcmp(loc,"se") == 0)
|
|
R.winpos |= 4;
|
|
else if (strcmp(loc,"W") == 0 || strcmp(loc,"w") == 0)
|
|
R.winpos |= 8;
|
|
else if (strcmp(loc,"C") == 0 || strcmp(loc,"c") == 0)
|
|
R.winpos |= 16;
|
|
else if (strcmp(loc,"E") == 0 || strcmp(loc,"e") == 0)
|
|
R.winpos |= 32;
|
|
else if (strcmp(loc,"NW") == 0 || strcmp(loc,"nw") == 0)
|
|
R.winpos |= 64;
|
|
else if (strcmp(loc,"N") == 0 || strcmp(loc,"n") == 0)
|
|
R.winpos |= 128;
|
|
else if (strcmp(loc,"NE") == 0 || strcmp(loc,"ne") == 0)
|
|
R.winpos |= 256;
|
|
else
|
|
return EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"list contains unknown string\n");
|
|
}
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableDispView(PyObject *self)
|
|
{
|
|
R.displaymode = R_DISPLAYVIEW;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableDispWin(PyObject *self)
|
|
{
|
|
R.displaymode = R_DISPLAYWIN;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableToonShading(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_EDGE, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EdgeIntensity(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.edgeint, 0, 255);
|
|
}
|
|
|
|
PyObject *M_Render_EnableEdgeShift(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, 1, &G.compat);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableEdgeAll(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, 1, &G.notonlysolid);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetEdgeColor(PyObject *self, PyObject *args)
|
|
{
|
|
float red = 0.0f;
|
|
float green = 0.0f;
|
|
float blue = 0.0f;
|
|
|
|
if (!PyArg_ParseTuple(args, "fff", &red, &green, &blue))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected three floats"));
|
|
|
|
if(red < 0 || red > 1)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"value out of range 0.000 - 1.000 (red)"));
|
|
if(green < 0 || green > 1)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"value out of range 0.000 - 1.000 (green)"));
|
|
if(blue < 0 || blue > 1)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"value out of range 0.000 - 1.000 (blue)"));
|
|
|
|
((BPy_Scene*)self)->scene->r.edgeR = red;
|
|
((BPy_Scene*)self)->scene->r.edgeG = green;
|
|
((BPy_Scene*)self)->scene->r.edgeB = blue;
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_GetEdgeColor(PyObject *self)
|
|
{
|
|
char rgb[24];
|
|
|
|
sprintf(rgb, "[%.3f,%.3f,%.3f]\n", ((BPy_Scene*)self)->scene->r.edgeR,
|
|
((BPy_Scene*)self)->scene->r.edgeG, ((BPy_Scene*)self)->scene->r.edgeB);
|
|
return PyString_FromString (rgb);
|
|
}
|
|
|
|
PyObject *M_Render_EdgeAntiShift(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.same_mat_redux, 0, 255);
|
|
}
|
|
|
|
PyObject *M_Render_EnableOversampling(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_OSA, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetOversamplingLevel(PyObject *self, PyObject *args)
|
|
{
|
|
int level;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &level))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected int"));
|
|
|
|
if(level != 5 && level != 8 && level != 11 && level != 16)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected 5,8,11, or 16"));
|
|
|
|
((BPy_Scene*)self)->scene->r.osa = level;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableMotionBlur(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_MBLUR, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_MotionBlurLevel(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.blurfac, 0.01f, 5.0f);
|
|
}
|
|
|
|
PyObject *M_Render_PartsX(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.xparts, 1, 64);
|
|
}
|
|
|
|
PyObject *M_Render_PartsY(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.yparts, 1, 64);
|
|
}
|
|
|
|
PyObject *M_Render_EnableSky(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->r.alphamode = R_ADDSKY;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnablePremultiply(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->r.alphamode = R_ALPHAPREMUL;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableKey(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->r.alphamode = R_ALPHAKEY;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableShadow(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_SHADOW, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableEnvironmentMap(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_ENVMAP, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnablePanorama(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_PANORAMA, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableRayTracing(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_RAYTRACE, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableRadiosityRender(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_RADIO, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetRenderWinSize(PyObject *self, PyObject *args)
|
|
{
|
|
int size;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &size))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected int"));
|
|
|
|
if(size != 25 && size != 50 && size != 75 && size != 100)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected 25, 50, 75, or 100"));
|
|
|
|
((BPy_Scene*)self)->scene->r.size = size;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableFieldRendering(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_FIELDS, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableOddFieldFirst(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_ODDFIELD, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableFieldTimeDisable(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_FIELDSTILL, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableGaussFilter(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_GAUSS, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableBorderRender(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_BORDER, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableGammaCorrection(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_GAMMA, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_GaussFilterSize(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.gauss, 0.5f, 1.5f);
|
|
}
|
|
|
|
PyObject *M_Render_StartFrame(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.sfra, 1, 18000);
|
|
}
|
|
|
|
PyObject *M_Render_EndFrame(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.efra, 1, 18000);
|
|
}
|
|
|
|
PyObject *M_Render_ImageSizeX(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.xsch, 4, 10000);
|
|
}
|
|
|
|
PyObject *M_Render_ImageSizeY(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.ysch, 4, 10000);
|
|
}
|
|
|
|
PyObject *M_Render_AspectRatioX(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.xasp, 1, 200);
|
|
}
|
|
|
|
PyObject *M_Render_AspectRatioY(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.yasp, 1, 200);
|
|
}
|
|
|
|
PyObject *M_Render_SetRenderer(PyObject *self, PyObject *args)
|
|
{
|
|
int type;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &type))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected constant INTERN or YAFRAY"));
|
|
|
|
if(type == R_INTERN)
|
|
((BPy_Scene*)self)->scene->r.renderer = R_INTERN;
|
|
else if (type == R_YAFRAY)
|
|
((BPy_Scene*)self)->scene->r.renderer = R_YAFRAY;
|
|
else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected INTERN or YAFRAY"));
|
|
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableCropping(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_MOVIECROP, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetImageType(PyObject *self, PyObject *args)
|
|
{
|
|
int type;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &type))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected constant"));
|
|
|
|
if(type == R_AVIRAW)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_AVIRAW;
|
|
else if (type == R_AVIJPEG)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_AVIJPEG;
|
|
#ifdef _WIN32
|
|
else if (type == R_AVICODEC)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_AVICODEC;
|
|
#endif
|
|
else if (type == R_QUICKTIME && G.have_quicktime)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_QUICKTIME;
|
|
else if (type == R_TARGA)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_TARGA;
|
|
else if (type == R_RAWTGA)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_RAWTGA;
|
|
else if (type == R_PNG)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_PNG;
|
|
else if (type == R_BMP)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_BMP;
|
|
else if (type == R_JPEG90)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_JPEG90;
|
|
else if (type == R_HAMX)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_HAMX;
|
|
else if (type == R_IRIS)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_IRIS;
|
|
else if (type == R_IRIZ)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_IRIZ;
|
|
else if (type == R_FTYPE)
|
|
((BPy_Scene*)self)->scene->r.imtype = R_FTYPE;
|
|
else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"unknown constant - see modules dict for help"));
|
|
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_Quality(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.quality, 10, 100);
|
|
}
|
|
|
|
PyObject *M_Render_FramesPerSec(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.frs_sec, 1, 120);
|
|
}
|
|
|
|
PyObject *M_Render_EnableGrayscale(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->r.planes = R_PLANESBW;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableRGBColor(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->r.planes = R_PLANES24;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableRGBAColor(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->r.planes = R_PLANES32;
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
static void M_Render_DoSizePreset(PyObject *self, short xsch, short ysch, short xasp,
|
|
short yasp, short size, short xparts, short yparts,
|
|
short frames, float a, float b, float c, float d)
|
|
{
|
|
((BPy_Scene*)self)->scene->r.xsch= xsch;
|
|
((BPy_Scene*)self)->scene->r.ysch= ysch;
|
|
((BPy_Scene*)self)->scene->r.xasp= xasp;
|
|
((BPy_Scene*)self)->scene->r.yasp= yasp;
|
|
((BPy_Scene*)self)->scene->r.size= size;
|
|
((BPy_Scene*)self)->scene->r.frs_sec= frames;
|
|
((BPy_Scene*)self)->scene->r.xparts= xparts;
|
|
((BPy_Scene*)self)->scene->r.yparts= yparts;
|
|
|
|
BLI_init_rctf(&((BPy_Scene*)self)->scene->r.safety, a, b, c, d);
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
allqueue(REDRAWVIEWCAM, 0);
|
|
}
|
|
|
|
PyObject *M_Render_SizePreset(PyObject *self, PyObject *args)
|
|
{
|
|
int type;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &type))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected constant"));
|
|
|
|
if(type == R_PAL){
|
|
M_Render_DoSizePreset(self,720,576,54,51,100, ((BPy_Scene*)self)->scene->r.xparts,
|
|
((BPy_Scene*)self)->scene->r.yparts, 25, 0.1, 0.9, 0.1, 0.9);
|
|
((BPy_Scene*)self)->scene->r.mode &= ~R_PANORAMA;
|
|
}else if (type == R_NTSC){
|
|
M_Render_DoSizePreset(self,720,480,10,11,100, 1, 1,
|
|
30, 0.1, 0.9, 0.1, 0.9);
|
|
((BPy_Scene*)self)->scene->r.mode &= ~R_PANORAMA;
|
|
}else if (type == R_DEFAULT){
|
|
M_Render_DoSizePreset(self,720,576,54,51,100, 1, 1,
|
|
((BPy_Scene*)self)->scene->r.frs_sec, 0.1, 0.9, 0.1, 0.9);
|
|
((BPy_Scene*)self)->scene->r.mode= R_OSA+R_SHADOW+R_FIELDS;
|
|
((BPy_Scene*)self)->scene->r.imtype= R_TARGA;
|
|
}else if (type == R_PREVIEW){
|
|
M_Render_DoSizePreset(self,640,512,1,1,50, 1, 1,
|
|
((BPy_Scene*)self)->scene->r.frs_sec, 0.1, 0.9, 0.1, 0.9);
|
|
((BPy_Scene*)self)->scene->r.mode &= ~R_PANORAMA;
|
|
}else if (type == R_PC){
|
|
M_Render_DoSizePreset(self,640,480,100,100,100, 1, 1,
|
|
((BPy_Scene*)self)->scene->r.frs_sec, 0.0, 1.0, 0.0, 1.0);
|
|
((BPy_Scene*)self)->scene->r.mode &= ~R_PANORAMA;
|
|
}else if (type == R_PAL169){
|
|
M_Render_DoSizePreset(self,720,576,64,45,100, 1, 1,
|
|
25, 0.1, 0.9, 0.1, 0.9);
|
|
((BPy_Scene*)self)->scene->r.mode &= ~R_PANORAMA;
|
|
}else if (type == R_PANO){
|
|
M_Render_DoSizePreset(self,36,176,115,100,100, 16, 1,
|
|
((BPy_Scene*)self)->scene->r.frs_sec, 0.1, 0.9, 0.1, 0.9);
|
|
((BPy_Scene*)self)->scene->r.mode |= R_PANORAMA;
|
|
}else if (type == R_FULL){
|
|
M_Render_DoSizePreset(self,1280,1024,1,1,100, 1, 1,
|
|
((BPy_Scene*)self)->scene->r.frs_sec, 0.1, 0.9, 0.1, 0.9);
|
|
((BPy_Scene*)self)->scene->r.mode &= ~R_PANORAMA;
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"unknown constant - see modules dict for help"));
|
|
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableUnifiedRenderer(PyObject *self, PyObject *args)
|
|
{
|
|
M_Render_BitToggleInt(args, R_UNIFIED, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetYafrayGIQuality(PyObject *self, PyObject *args)
|
|
{
|
|
int type;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &type))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected constant"));
|
|
|
|
if( type == PY_NONE || type == PY_LOW ||
|
|
type == PY_MEDIUM || type == PY_HIGH ||
|
|
type == PY_HIGHER || type == PY_BEST){
|
|
((BPy_Scene*)self)->scene->r.GIquality = type;
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"unknown constant - see modules dict for help"));
|
|
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetYafrayGIMethod(PyObject *self, PyObject *args)
|
|
{
|
|
int type;
|
|
|
|
if (!PyArg_ParseTuple(args, "i", &type))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected constant"));
|
|
|
|
if( type == PY_NONE || type == PY_SKYDOME || type == PY_GIFULL){
|
|
((BPy_Scene*)self)->scene->r.GImethod = type;
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"unknown constant - see modules dict for help"));
|
|
|
|
allqueue(REDRAWBUTSSCENE, 0);
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGIPower(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod>0) {
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.GIpower, 0.01f, 100.00f);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'SKYDOME' or 'FULL'"));
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGIDepth(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2) {
|
|
return M_Render_GetSetAttributeInt(args, &((BPy_Scene*)self)->scene->r.GIdepth, 1, 8);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL'"));
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGICDepth(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2) {
|
|
return M_Render_GetSetAttributeInt(args, &((BPy_Scene*)self)->scene->r.GIcausdepth, 1, 8);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL'"));
|
|
}
|
|
|
|
PyObject *M_Render_EnableYafrayGICache(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2) {
|
|
M_Render_BitToggleShort(args, 1, &((BPy_Scene*)self)->scene->r.GIcache);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL'"));
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableYafrayGIPhotons(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2) {
|
|
M_Render_BitToggleShort(args, 1, &((BPy_Scene*)self)->scene->r.GIphotons);;
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL'"));
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGIPhotonCount(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2 && ((BPy_Scene*)self)->scene->r.GIphotons==1) {
|
|
return M_Render_GetSetAttributeInt(args, &((BPy_Scene*)self)->scene->r.GIphotoncount, 0, 10000000);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL' and GIPhotons must be enabled\n"));
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGIPhotonRadius(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2 && ((BPy_Scene*)self)->scene->r.GIphotons==1) {
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.GIphotonradius, 0.00001f, 100.0f);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL' and GIPhotons must be enabled\n"));
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGIPhotonMixCount(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2 && ((BPy_Scene*)self)->scene->r.GIphotons==1) {
|
|
return M_Render_GetSetAttributeInt(args, &((BPy_Scene*)self)->scene->r.GImixphotons, 0, 1000);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL' and GIPhotons must be enabled\n"));
|
|
}
|
|
|
|
PyObject *M_Render_EnableYafrayGITunePhotons(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2 && ((BPy_Scene*)self)->scene->r.GIphotons==1) {
|
|
M_Render_BitToggleShort(args, 1, &((BPy_Scene*)self)->scene->r.GIdirect);;
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL' and GIPhotons must be enabled"));
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGIShadowQuality(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2 && ((BPy_Scene*)self)->scene->r.GIcache==1) {
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.GIshadowquality, 0.01f, 1.0f);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL' and GICache must be enabled\n"));
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGIPixelsPerSample(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2 && ((BPy_Scene*)self)->scene->r.GIcache==1) {
|
|
return M_Render_GetSetAttributeInt(args, &((BPy_Scene*)self)->scene->r.GIpixelspersample, 1, 50);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL' and GICache must be enabled\n"));
|
|
}
|
|
|
|
PyObject *M_Render_EnableYafrayGIGradient(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2 && ((BPy_Scene*)self)->scene->r.GIcache==1) {
|
|
M_Render_BitToggleShort(args, 1, &((BPy_Scene*)self)->scene->r.GIgradient);;
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL' and GICache must be enabled"));
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGIRefinement(PyObject *self, PyObject *args)
|
|
{
|
|
if (((BPy_Scene*)self)->scene->r.GImethod==2 && ((BPy_Scene*)self)->scene->r.GIcache==1) {
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.GIrefinement, 0.001f, 1.0f);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"YafrayGIMethod must be set to 'FULL' and GICache must be enabled\n"));
|
|
}
|
|
|
|
PyObject *M_Render_YafrayRayBias(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.YF_raybias, 0.0f, 10.0f);
|
|
}
|
|
|
|
PyObject *M_Render_YafrayRayDepth(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeInt(args, &((BPy_Scene*)self)->scene->r.YF_raydepth, 1, 80);
|
|
}
|
|
|
|
PyObject *M_Render_YafrayGamma(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.YF_gamma, 0.001f, 5.0f);
|
|
}
|
|
|
|
PyObject *M_Render_YafrayExposure(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.YF_exposure, 0.0f, 10.0f);
|
|
}
|
|
|
|
PyObject *M_Render_YafrayProcessorCount(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeInt(args, &((BPy_Scene*)self)->scene->r.YF_numprocs, 1, 8);
|
|
}
|
|
|
|
PyObject *M_Render_EnableGameFrameStretch(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->framing.type = SCE_GAMEFRAMING_SCALE;
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableGameFrameExpose(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->framing.type = SCE_GAMEFRAMING_EXTEND;
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_EnableGameFrameBars(PyObject *self)
|
|
{
|
|
((BPy_Scene*)self)->scene->framing.type = SCE_GAMEFRAMING_BARS;
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_SetGameFrameColor(PyObject *self, PyObject *args)
|
|
{
|
|
float red = 0.0f;
|
|
float green = 0.0f;
|
|
float blue = 0.0f;
|
|
|
|
if (!PyArg_ParseTuple(args, "fff", &red, &green, &blue))
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"expected three floats"));
|
|
|
|
if(red < 0 || red > 1)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"value out of range 0.000 - 1.000 (red)"));
|
|
if(green < 0 || green > 1)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"value out of range 0.000 - 1.000 (green)"));
|
|
if(blue < 0 || blue > 1)
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"value out of range 0.000 - 1.000 (blue)"));
|
|
|
|
((BPy_Scene*)self)->scene->framing.col[0] = red;
|
|
((BPy_Scene*)self)->scene->framing.col[1] = green;
|
|
((BPy_Scene*)self)->scene->framing.col[2] = blue;
|
|
|
|
return EXPP_incr_ret(Py_None);
|
|
}
|
|
|
|
PyObject *M_Render_GetGameFrameColor(PyObject *self)
|
|
{
|
|
char rgb[24];
|
|
|
|
sprintf(rgb, "[%.3f,%.3f,%.3f]\n", ((BPy_Scene*)self)->scene->framing.col[0],
|
|
((BPy_Scene*)self)->scene->framing.col[1], ((BPy_Scene*)self)->scene->framing.col[2]);
|
|
return PyString_FromString (rgb);
|
|
}
|
|
|
|
|
|
PyObject *M_Render_GammaLevel(PyObject *self, PyObject *args)
|
|
{
|
|
if(((BPy_Scene*)self)->scene->r.mode & R_UNIFIED){
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.gamma, 0.2f, 5.0f);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"Unified Render must be enabled"));
|
|
}
|
|
|
|
PyObject *M_Render_PostProcessAdd(PyObject *self, PyObject *args)
|
|
{
|
|
if(((BPy_Scene*)self)->scene->r.mode & R_UNIFIED){
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.postadd, -1.0f, 1.0f);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"Unified Render must be enabled"));
|
|
}
|
|
|
|
PyObject *M_Render_PostProcessMultiply(PyObject *self, PyObject *args)
|
|
{
|
|
if(((BPy_Scene*)self)->scene->r.mode & R_UNIFIED){
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.postmul, 0.01f, 4.0f);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"Unified Render must be enabled"));
|
|
}
|
|
|
|
PyObject *M_Render_PostProcessGamma(PyObject *self, PyObject *args)
|
|
{
|
|
if(((BPy_Scene*)self)->scene->r.mode & R_UNIFIED){
|
|
return M_Render_GetSetAttributeFloat(args, &((BPy_Scene*)self)->scene->r.postgamma, 0.2f, 2.0f);
|
|
}else
|
|
return (EXPP_ReturnPyObjError (PyExc_AttributeError,
|
|
"Unified Render must be enabled"));
|
|
}
|
|
|
|
PyObject *M_Render_SGIMaxsize(PyObject *self, PyObject *args)
|
|
{
|
|
#ifdef __sgi
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.maximsize, 0, 500);
|
|
#else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"SGI is not defined on this machine"));
|
|
#endif
|
|
}
|
|
|
|
PyObject *M_Render_EnableSGICosmo(PyObject *self, PyObject *args)
|
|
{
|
|
#ifdef __sgi
|
|
M_Render_BitToggleInt(args, R_COSMO, &((BPy_Scene*)self)->scene->r.mode);
|
|
return EXPP_incr_ret(Py_None);
|
|
#else
|
|
return (EXPP_ReturnPyObjError (PyExc_StandardError,
|
|
"SGI is not defined on this machine"));
|
|
#endif
|
|
}
|
|
|
|
PyObject *M_Render_OldMapValue(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.framapto, 1, 900);
|
|
}
|
|
|
|
PyObject *M_Render_NewMapValue(PyObject *self, PyObject *args)
|
|
{
|
|
return M_Render_GetSetAttributeShort(args, &((BPy_Scene*)self)->scene->r.images, 1, 900);
|
|
}
|
|
|
|
|
|
|