1
0
mirror of git://projects.qi-hardware.com/ben-blinkenlights.git synced 2024-07-01 00:59:49 +03:00
ben-blinkenlights/ubb-vga/ppmimg.c
Werner Almesberger 6558f56de6 ubb-vga2: replaced threshold-based color mapping with color cube model
- ubb-vga.h (ccube_init, ccube_map), ccube.c: color mapper based on
  proximity in color cube
- grabfb.c (pattern, grabfb), ppmimg.c (pattern, convert): use the color
  cube mapper instead of inferios threshold-based mapping
- ubb-vga2.c (session): initialize the color cube
- ubb-vga.h (thres), grabfb.c (thres), ubb-vga2.c (usage, main): removed
  the threshold along with the option (-l) to set it
- Makefile (OBJS): added ccube.o
2011-04-28 01:18:03 -03:00

57 lines
1.1 KiB
C

/*
* ppmimg.c - Convert a PPM image
*
* Written 2011 by Werner Almesberger
* Copyright 2011 Werner Almesberger
*
* 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.
*/
#include <stdint.h>
#include <stdlib.h>
#include <stdio.h>
#include "ppm.h"
#include "ubb-vga.h"
char *img_name;
static void convert(uint8_t *f, int xres, int yres, uint8_t *ppm)
{
int x, y;
uint8_t v, last = 0;
for (y = 0; y != yres; y++)
for (x = 0; x != xres; x++) {
v = ccube_map(ppm[0], ppm[1], ppm[2]);
if (x & 1) {
*f++ = last | v;
} else {
last = v << 4;
}
ppm += 3;
}
}
void ppmimg(void *f, int xres, int yres)
{
uint8_t *ppm;
int xr = 0, yr = 0;
ppm = load_ppm(img_name, &xr, &yr);
if (xr != xres || yr != yres) {
fprintf(stderr, "image is %dx%d, display is %dx%d\n",
xr, yr, xres, yres);
exit(1);
}
convert(f, xres, yres, ppm);
free(ppm);
}