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/imbuf/intern/cspace.c

182 lines
3.8 KiB
C
Raw Normal View History

2002-10-12 11:37:38 +00:00
/**
*
* $Id$
*
* ***** 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 *****
*/
#include "BLI_blenlib.h"
#include "imbuf.h"
#include "imbuf_patch.h"
#include "IMB_imbuf_types.h"
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
2002-10-12 11:37:38 +00:00
/************************************************************************/
/* COLORSPACE */
/************************************************************************/
static void fillmattab(double val, unsigned short *mattab)
{
int tot,ival;
int i;
val *= (1 << 22);
ival = val;
tot = 32767; /* een half */
for(i = 256; i > 0; i--){
*(mattab) = (tot >> 16);
mattab += 3;
tot += ival;
}
}
static void cspfill(short *buf, short *fill, int x)
{
short r,g,b;
b = fill[0];
g = fill[1];
r = fill[2];
for (;x>0;x--){
buf[0] = b;
buf[1] = g;
buf[2] = r;
buf += 3;
}
}
static void cspadd(short *buf, short cont[][3], unsigned char *rect, int x)
{
short i;
for (;x>0;x--){
i = *(rect);
rect += 4;
buf[0] += cont[i][0];
buf[1] += cont[i][1];
buf[2] += cont[i][2];
buf += 3;
}
}
static void cspret(short *buf, unsigned char *rect, int x)
{
int r,g,b;
for(; x > 0; x--){
b = buf[0];
g = buf[1];
r = buf[2];
if (b & 0x4000){
if (b<0) rect[2]=0;
else rect[2]=255;
} else rect[2] = b >> 6;
if (g & 0x4000){
if (g<0) rect[1]=0;
else rect[1]=255;
} else rect[1] = g >> 6;
if (r & 0x4000){
if (r<0) rect[0]=0;
else rect[0]=255;
} else rect[0] = r >> 6;
buf += 3;
rect += 4;
}
}
static void rotcspace(struct ImBuf *ibuf, short *cont_1, short *cont_2, short *cont_3, short *add)
{
short x,y,*buf;
uchar *rect;
x=ibuf->x;
rect= (uchar *)ibuf->rect;
buf=(short *)malloc(x*3*sizeof(short));
if (buf){
for(y=ibuf->y;y>0;y--){
cspfill(buf,add,x);
cspadd(buf,cont_1,rect+0,x);
cspadd(buf,cont_2,rect+1,x);
cspadd(buf,cont_3,rect+2,x);
cspret(buf,rect,x);
rect += x<<2;
}
free(buf);
}
}
void IMB_cspace(struct ImBuf *ibuf, float mat[][4])
{
short *cont_1,*cont_2,*cont_3,add[3];
cont_1=(short *)malloc(256*3*sizeof(short));
cont_2=(short *)malloc(256*3*sizeof(short));
cont_3=(short *)malloc(256*3*sizeof(short));
if (cont_1 && cont_2 && cont_3){
fillmattab(mat[0][0],cont_1);
fillmattab(mat[0][1],cont_1+1);
fillmattab(mat[0][2],cont_1+2);
fillmattab(mat[1][0],cont_2);
fillmattab(mat[1][1],cont_2+1);
fillmattab(mat[1][2],cont_2+2);
fillmattab(mat[2][0],cont_3);
fillmattab(mat[2][1],cont_3+1);
fillmattab(mat[2][2],cont_3+2);
add[0] = (mat[3][0] * 64.0) + .5;
add[1] = (mat[3][1] * 64.0) + .5;
add[2] = (mat[3][2] * 64.0) + .5;
rotcspace(ibuf, cont_1, cont_2, cont_3, add);
}
if (cont_1) free(cont_1);
if (cont_2) free(cont_2);
if (cont_3) free(cont_3);
}