/*
* This file is part of the DXX-Rebirth project <https://www.dxx-rebirth.com/>.
* It is copyright by its individual contributors, as recorded in the
* project's Git history. See COPYING.txt at the top level for license
* terms and a link to the Git history.
*/
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#include "iff.h"
extern int parse_iff(FILE *ifile,struct bitmap_header *bitmap_header);
int x,y,pl,bc;
int bytes_per_row,color;
int mask,first_bit_value;
FILE *ifile;
struct bitmap_header iff_bitmap_header;
// Parse ilbm style data at my_bh->raw_data.
BITMAP8 * IFF_To_8BPP(char * ifilename)
{
struct bitmap_header * my_bh;
int Process_width,Process_height;
unsigned char *p;
struct pal_entry *palptr;
int newptr = 0;
int i;
BITMAP8 * new;
my_bh = &iff_bitmap_header;
palptr=my_bh->palette;
p=my_bh->raw_data;
Process_width = 32767; // say to process full width of bitmap
Process_height = 32767; // say to process full height of bitmap
if ((ifile
= fopen(ifilename
,"rb")) == NULL
) {
printf("Unable to open bitmap file %s.\n", ifilename
);
}
parse_iff(ifile,&iff_bitmap_header);
if (Process_width > iff_bitmap_header.w)
Process_width = iff_bitmap_header.w;
if (Process_height > iff_bitmap_header.h)
Process_height = iff_bitmap_header.h;
printf( "%d, %d\n", Process_width
, Process_height
);
new
= (BITMAP8
*)malloc( sizeof(BITMAP8
)+ (Process_width
* Process_height
) );
new->Width = Process_width;
new->Height = Process_height;
for (i=0;i<256;i++) {
new->Palette[3*i] = my_bh->palette[i].r;
new->Palette[3*i+1] = my_bh->palette[i].g;
new->Palette[3*i+2] = my_bh->palette[i].b;
}
printf("Process_width = %i, Process_height = %i\n",Process_width
,Process_height
);
first_bit_value = 1 << (my_bh->nplanes-1);
bytes_per_row = 2*((my_bh->w+15)/16);
for (y=0; y<Process_height; y++) {
bc = Process_width;
p = &my_bh->raw_data[y*bytes_per_row*my_bh->nplanes];
switch (my_bh->type) {
case PBM_TYPE:
for (x=0; x<my_bh->w; x++) {
new->Data[newptr++] = my_bh->raw_data[y*my_bh->w+x];
}
break;
case ILBM_TYPE:
for (x=0; x<bytes_per_row; x++) {
for (mask=128; mask; mask /=2) {
color = 0;
for (pl=0; pl<my_bh->nplanes; pl++) {
color /= 2;
if ( p[pl*bytes_per_row+x] & mask)
color += first_bit_value;
}
new->Data[newptr++] = color;
bc--;
if (!bc)
goto line_done;
}
}
line_done: ;
break;
}
}
return new;
}
ΓΏ