/* * libpipi Proper image processing implementation library * Copyright (c) 2004-2008 Sam Hocevar * All Rights Reserved * * $Id$ * * This library is free software. It comes without any warranty, to * the extent permitted by applicable law. You can redistribute it * and/or modify it under the terms of the Do What The Fuck You Want * To Public License, Version 2, as published by Sam Hocevar. See * http://sam.zoy.org/wtfpl/COPYING for more details. */ /* * image.c: image I/O functions */ #include "config.h" #include "common.h" #include #include #include #include #include #include "pipi.h" #include "pipi_internals.h" /* FIXME: this whole file is broken until we support BGR24 images */ pipi_image_t *pipi_load_opencv(const char *name) { pipi_image_t *img; IplImage *priv = cvLoadImage(name, 1); if(!priv) return NULL; img = pipi_new(priv->width, priv->height); img->p[PIPI_PIXELS_BGR24].pixels = priv->imageData; img->p[PIPI_PIXELS_BGR24].w = priv->width; img->p[PIPI_PIXELS_BGR24].h = priv->height; img->p[PIPI_PIXELS_BGR24].pitch = priv->widthStep; img->last_modified = PIPI_PIXELS_BGR24; img->codec_priv = (void *)priv; img->codec_format = PIPI_PIXELS_BGR24; return img; } void pipi_free_opencv(pipi_image_t *img) { IplImage *iplimg; iplimg = (IplImage *)img->codec_priv; cvReleaseImage(&iplimg); } void pipi_save_opencv(pipi_image_t *img, const char *name) { if(!img->codec_priv) { IplImage *priv = cvCreateImage(cvSize(img->w, img->h), IPL_DEPTH_8U, 3); /* FIXME: check pitch differences here */ if(img->last_modified == PIPI_PIXELS_BGR24) { memcpy(priv->imageData, img->p[PIPI_PIXELS_BGR24].pixels, 3 * img->w * img->h); free(img->p[PIPI_PIXELS_BGR24].pixels); } img->p[PIPI_PIXELS_BGR24].pixels = priv->imageData; img->p[PIPI_PIXELS_BGR24].w = priv->width; img->p[PIPI_PIXELS_BGR24].h = priv->height; img->p[PIPI_PIXELS_BGR24].pitch = priv->widthStep; img->codec_priv = (void *)priv; img->codec_format = PIPI_PIXELS_BGR24; } pipi_getpixels(img, img->codec_format); cvSaveImage(name, img->codec_priv); }