Credits go to Gernot Ziegler, who originally coded EXR support, and to Austin Benesh for bringing it further. Kent Mein provided a lot of code for integrating float buffers in Blender imbuf and ImBuf API cleanup, and provided Make and Scons and static linking. At this moment; the EXR libraries are a *dependency*, so you cannot get the Orange branch compiled without having OpenEXR installed. Get the (precompiled or sources) stuff from www.openexr.com. Current default is that the headers and lib resides in /user/local/ Several changes/additions/fixes were added: - EXR code only supported 'half' format (16 bits per channel). I've added float writing, but for reading it I need tomorrow. :) - Quite some clumsy copying of data happened in EXR code. - cleaned up the api calls already a bit, preparing for more advanced support - Zbuffers were saved 16 bits, now 32 bits - automatic adding of .exr extensions went wrong Imbuf: - added proper imbuf->flags and imbuf->mall support for float buffers, it was created for *each* imbuf. :) - found bugs for float buffers in scaling and flipping. Code there will need more checks still - imbuf also needs to be verified to behave properly when no 32 bits rect exists (for saving for example) TODO: - support internal float images for textures, backbuf, AO probes, and display in Image window Hope this commit won't screwup syncing with bf-blender... :/
89 lines
2.2 KiB
C
89 lines
2.2 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.
|
|
*
|
|
* The Original Code is: all of this file.
|
|
*
|
|
* Contributor(s): none yet.
|
|
*
|
|
* ***** END GPL/BL DUAL LICENSE BLOCK *****
|
|
* rotate.c
|
|
*
|
|
* $Id$
|
|
*/
|
|
|
|
#include "BLI_blenlib.h"
|
|
|
|
#include "imbuf.h"
|
|
#include "imbuf_patch.h"
|
|
#include "IMB_imbuf_types.h"
|
|
#include "IMB_imbuf.h"
|
|
|
|
#include "IMB_allocimbuf.h"
|
|
|
|
void IMB_flipy(struct ImBuf * ibuf)
|
|
{
|
|
short x, y;
|
|
unsigned int *top, *bottom, do_float=0, *line;
|
|
float *topf=NULL, *bottomf=NULL, *linef=NULL;
|
|
|
|
if (ibuf == NULL) return;
|
|
if (ibuf->rect == NULL) return;
|
|
|
|
if (ibuf->rect_float) do_float =1;
|
|
|
|
x = ibuf->x;
|
|
y = ibuf->y;
|
|
|
|
top = ibuf->rect;
|
|
bottom = top + ((y-1) * x);
|
|
line= MEM_mallocN(x*sizeof(int), "linebuf");
|
|
|
|
if (do_float) {
|
|
topf= ibuf->rect_float;
|
|
bottomf = topf + 4*((y-1) * x);
|
|
linef= MEM_mallocN(4*x*sizeof(float), "linebuff");
|
|
}
|
|
y >>= 1;
|
|
|
|
for(;y>0;y--) {
|
|
|
|
memcpy(line, top, x*sizeof(int));
|
|
memcpy(top, bottom, x*sizeof(int));
|
|
memcpy(bottom, line, x*sizeof(int));
|
|
bottom -= x;
|
|
top+= x;
|
|
|
|
if(do_float) {
|
|
memcpy(linef, topf, 4*x*sizeof(float));
|
|
memcpy(topf, bottomf, 4*x*sizeof(float));
|
|
memcpy(bottomf, linef, 4*x*sizeof(float));
|
|
bottomf -= 4*x;
|
|
topf+= 4*x;
|
|
}
|
|
}
|
|
|
|
MEM_freeN(line);
|
|
if(linef) MEM_freeN(linef);
|
|
}
|