Add higher logic to load bitmap texture files
This commit is contained in:
parent
957a9a18ef
commit
7d86b9ce7a
@ -50,7 +50,7 @@ CSRCS = trv_bitmapfile.c trv_bitmaps.c trv_color.c trv_createworld.c
|
||||
CSRCS += trv_doors.c trv_fsutils.c trv_graphics.c trv_input.c trv_mem.c
|
||||
CSRCS += trv_planefiles.c trv_planelists.c trv_pov.c trv_rayavoid.c
|
||||
CSRCS += trv_raycast.c trv_raycntl.c trv_rayprune.c trv_rayrend.c
|
||||
CSRCS += trv_trigtbl.c
|
||||
CSRCS += trv_texturefile.c trv_trigtbl.c
|
||||
MAINSRC = trv_main.c
|
||||
|
||||
ifeq ($(CONFIG_NX),y)
|
||||
|
100
graphics/traveler/include/trv_graphicfile.h
Normal file
100
graphics/traveler/include/trv_graphicfile.h
Normal file
@ -0,0 +1,100 @@
|
||||
/****************************************************************************
|
||||
* apps/graphics/traveler/include/trv_graphicfile.h
|
||||
*
|
||||
* Copyright (C) 2014 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef __APPS_GRAPHICS_TRAVELER_INCLUDE_TRV_GRAPHICFILE_H
|
||||
#define __APPS_GRAPHICS_TRAVELER_INCLUDE_TRV_GRAPHICFILE_H
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include "trv_types.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/* MAGIC_LENGTH must be the length of the longest MAGIC string. */
|
||||
|
||||
#define MAGIC_LENGTH 5
|
||||
#define GIF_MAGIC "GIF87"
|
||||
#define GIF89_MAGIC "GIF89"
|
||||
#define PPM_MAGIC "P6"
|
||||
|
||||
/****************************************************************************
|
||||
* Public Type Definitions
|
||||
****************************************************************************/
|
||||
|
||||
enum trv_graphicfile_format_e
|
||||
{
|
||||
GRAPHICFILE_UNKNOWN = 0,
|
||||
GRAPHICFILE_GIF87,
|
||||
GRAPHICFILE_GIF89,
|
||||
GRAPHICFILE_PPM,
|
||||
GRAPHICFILE_PCX
|
||||
};
|
||||
|
||||
enum trv_graphicfile_type_e
|
||||
{
|
||||
GRAPHICFILE_TRUECOLOR = 0,
|
||||
GRAPHICFILE_PALETTED
|
||||
};
|
||||
|
||||
struct trv_graphicfile_s
|
||||
{
|
||||
uint8_t type; /* See enum trv_graphicfile_type_e */
|
||||
uint16_t height;
|
||||
uint16_t width;
|
||||
int palette_entries;
|
||||
long transparent_entry;
|
||||
FAR struct trv_color_rgb_s *palette;
|
||||
FAR uint8_t *bitmap;
|
||||
};
|
||||
|
||||
/****************************************************************************
|
||||
* Public Data
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Function Prototypes
|
||||
****************************************************************************/
|
||||
|
||||
FAR struct trv_graphicfile_s *trv_graphicfile_new(void);
|
||||
void trv_graphicfile_free(struct trv_graphicfile_s *gfile);
|
||||
struct trv_color_rgb_s
|
||||
trv_graphicfile_pixel(FAR struct trv_graphicfile_s *gfile, int x, int y);
|
||||
struct trv_graphicfile_s *tvr_graphicfile_read(FAR char *filename);
|
||||
|
||||
#endif /* __APPS_GRAPHICS_TRAVELER_INCLUDE_TRV_GRAPHICFILE_H */
|
201
graphics/traveler/src/trv_texturefile.c
Normal file
201
graphics/traveler/src/trv_texturefile.c
Normal file
@ -0,0 +1,201 @@
|
||||
/*******************************************************************************
|
||||
* apps/graphics/traveler/src/trv_texturefile.c
|
||||
*
|
||||
* Copyright (C) 2014 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included files
|
||||
****************************************************************************/
|
||||
|
||||
#include "trv_types.h"
|
||||
#include "trv_bitmaps.h"
|
||||
#include "trv_mem.h"
|
||||
#include "trv_color.h"
|
||||
#include "trv_graphicfile.h"
|
||||
#include "trv_fsutils.h"
|
||||
|
||||
#include <stdio.h>
|
||||
#include <errno.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
#define COLOR_LEVELS 6
|
||||
|
||||
#undef MIN
|
||||
#undef MAX
|
||||
#define MIN(a,b) ((a) < (b) ? (a) : (b))
|
||||
#define MAX(a,b) ((a) > (b) ? (a) : (b))
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: trv_log2
|
||||
*
|
||||
* Description:
|
||||
* Return the log base 2 of the argument, or -1 if the argument is not
|
||||
* an integer power of 2.
|
||||
*
|
||||
***************************************************************************/
|
||||
|
||||
static int trv_log2(uint16_t x)
|
||||
{
|
||||
int i;
|
||||
|
||||
if (x != 0)
|
||||
{
|
||||
for (i = 0; i < 16 && (x & 1) == 0; i++, x >>= 1);
|
||||
}
|
||||
|
||||
return (x == 1) ? i : -EINVAL;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: trv_new_texture
|
||||
*
|
||||
* Description:
|
||||
***************************************************************************/
|
||||
|
||||
static FAR struct trv_bitmap_s *
|
||||
trv_new_texture(uint16_t width, uint16_t height)
|
||||
{
|
||||
struct trv_bitmap_s *bitmap;
|
||||
int log2h;
|
||||
int log2w;
|
||||
|
||||
/* The height and width should be powers of two for efficient texture
|
||||
* mapping. Here, we enforce this.
|
||||
*/
|
||||
|
||||
log2w = trv_log2(width);
|
||||
if (log2w < 0)
|
||||
{
|
||||
fprintf(stderr, "ERROR: Width is not a power of 2: %u\n", width);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
log2h = trv_log2(height);
|
||||
if (log2h < 0)
|
||||
{
|
||||
fprintf(stderr, "ERROR: Height is not a power of 2: %u\n", height);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Allocate the bitmap container */
|
||||
|
||||
bitmap = (FAR struct trv_bitmap_s*)trv_malloc(sizeof(struct trv_bitmap_s));
|
||||
if (!bitmap)
|
||||
{
|
||||
fprintf(stderr, "ERROR: Failed to allocate bitmap structure\n",
|
||||
height, width);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Allocate the bitmap texture memory */
|
||||
|
||||
bitmap->bm = (trv_pixel_t*)trv_malloc(height * width * sizeof(trv_pixel_t));
|
||||
if (!bitmap->bm)
|
||||
{
|
||||
fprintf(stderr, "ERROR: Failed to allocate bitmap: %u x %u x %u\n",
|
||||
height, width, sizeof(trv_pixel_t));
|
||||
trv_free(bitmap);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Initialize the bitmap container */
|
||||
|
||||
bitmap->w = width;
|
||||
bitmap->h = height;
|
||||
bitmap->log2h = log2h;
|
||||
|
||||
return bitmap;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: trv_quantize_texture
|
||||
* Description:
|
||||
***************************************************************************/
|
||||
|
||||
static void trv_quantize_texture(FAR struct trv_graphicfile_s *gfile,
|
||||
FAR struct trv_bitmap_s *bitmap)
|
||||
{
|
||||
FAR trv_pixel_t *destpixel = bitmap->bm;
|
||||
struct trv_color_rgb_s pixel;
|
||||
int x;
|
||||
int y;
|
||||
|
||||
for (x = gfile->width - 1; x >= 0; x--)
|
||||
{
|
||||
for (y = gfile->height - 1; y >= 0; y--)
|
||||
{
|
||||
pixel = trv_graphicfile_pixel(gfile, x, y);
|
||||
*destpixel++ = trv_color_rgb2pixel(&pixel);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: trv_read_texture
|
||||
*
|
||||
* Description:
|
||||
*
|
||||
***************************************************************************/
|
||||
|
||||
FAR struct trv_bitmap_s *trv_read_texture(char *filename)
|
||||
{
|
||||
FAR struct trv_graphicfile_s *gfile;
|
||||
FAR struct trv_bitmap_s *bitmap;
|
||||
|
||||
gfile = tvr_graphicfile_read(filename);
|
||||
if (gfile == NULL)
|
||||
{
|
||||
fprintf(stderr, "Error reading texture %s.", filename);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
bitmap = trv_new_texture(gfile->width, gfile->height);
|
||||
if (bitmap)
|
||||
{
|
||||
trv_quantize_texture(gfile, bitmap);
|
||||
}
|
||||
|
||||
trv_graphicfile_free(gfile);
|
||||
return bitmap;
|
||||
}
|
Loading…
Reference in New Issue
Block a user