dos3d
diff src/palman.c @ 1:0b7f840afe4a
palette management
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Mon, 21 Nov 2011 08:35:58 +0200 |
parents | |
children | c3e0bccd673e |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/src/palman.c Mon Nov 21 08:35:58 2011 +0200 1.3 @@ -0,0 +1,110 @@ 1.4 +/* 1.5 +256-color 3D graphics hack for real-mode DOS. 1.6 +Copyright (C) 2011 John Tsiombikas <nuclear@member.fsf.org> 1.7 + 1.8 +This program is free software: you can redistribute it and/or modify 1.9 +it under the terms of the GNU General Public License as published by 1.10 +the Free Software Foundation, either version 3 of the License, or 1.11 +(at your option) any later version. 1.12 + 1.13 +This program is distributed in the hope that it will be useful, 1.14 +but WITHOUT ANY WARRANTY; without even the implied warranty of 1.15 +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1.16 +GNU General Public License for more details. 1.17 + 1.18 +You should have received a copy of the GNU General Public License 1.19 +along with this program. If not, see <http://www.gnu.org/licenses/>. 1.20 +*/ 1.21 + 1.22 +#include <string.h> 1.23 +#include "palman.h" 1.24 + 1.25 +#define MAX_COLORS 256 1.26 +static struct palm_color colors[MAX_COLORS]; 1.27 +static int base_index[MAX_COLORS]; 1.28 + 1.29 +static struct palm_color pal[MAX_COLORS]; 1.30 +static unsigned int ncol, pcol; 1.31 +static int range; 1.32 + 1.33 +void palm_clear(void) 1.34 +{ 1.35 + ncol = 0; 1.36 +} 1.37 + 1.38 +int palm_add_color(unsigned char r, unsigned char g, unsigned char b) 1.39 +{ 1.40 + if(ncol >= MAX_COLORS) { 1.41 + return -1; 1.42 + } 1.43 + colors[ncol].r = r; 1.44 + colors[ncol].g = g; 1.45 + colors[ncol].b = b; 1.46 + ncol++; 1.47 + return 0; 1.48 +} 1.49 + 1.50 +/* TODO: build an octree */ 1.51 +int palm_build(void) 1.52 +{ 1.53 + int i, j; 1.54 + 1.55 + /* gradient range for each color */ 1.56 + range = MAX_COLORS / ncol; 1.57 + 1.58 + if(range == 1) { 1.59 + memcpy(pal, colors, ncol * sizeof *pal); 1.60 + return 0; 1.61 + } 1.62 + pcol = 0; 1.63 + 1.64 + for(i=0; i<ncol; i++) { 1.65 + unsigned int r, g, b, dr, dg, db; 1.66 + 1.67 + base_index[i] = pcol; 1.68 + 1.69 + dr = (colors[i].r << 8) / (range - 1); 1.70 + dg = (colors[i].g << 8) / (range - 1); 1.71 + db = (colors[i].b << 8) / (range - 1); 1.72 + 1.73 + r = g = b = 0; 1.74 + for(j=0; j<range; j++) { 1.75 + pal[pcol].r = (unsigned char)(r >> 8); 1.76 + pal[pcol].g = (unsigned char)(g >> 8); 1.77 + pal[pcol].b = (unsigned char)(b >> 8); 1.78 + pcol++; 1.79 + r += dr; 1.80 + g += dg; 1.81 + b += db; 1.82 + } 1.83 + } 1.84 + return pcol; 1.85 +} 1.86 + 1.87 +struct palm_color *palm_palette(void) 1.88 +{ 1.89 + return pal; 1.90 +} 1.91 + 1.92 +int palm_palette_size(void) 1.93 +{ 1.94 + return pcol; 1.95 +} 1.96 + 1.97 + 1.98 +int palm_color_base(unsigned char r, unsigned char g, unsigned char b) 1.99 +{ 1.100 + int i; 1.101 + 1.102 + for(i=0; i<pcol; i++) { 1.103 + if(colors[i].r == r && colors[i].g == g && colors[i].b == b) { 1.104 + return base_index[i]; 1.105 + } 1.106 + } 1.107 + return -1; 1.108 +} 1.109 + 1.110 +int palm_color_range(void) 1.111 +{ 1.112 + return range; 1.113 +}