This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/python/api2_2x/sceneRender.c
Joseph Gilbert c0966e309b - new files sceneRender.c/.h
- added new rendering module as part of the existing scene module
- support for individual scene rendering
- support for yafray rendering
2004-03-14 02:06:57 +00:00

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);
}