From 9c4d134ab304794b755139e90ca6da9de73a1e9a Mon Sep 17 00:00:00 2001 From: Stijn Buys Date: Sun, 24 Aug 2008 18:52:10 +0000 Subject: JPEG screenshots --- src/render/Makefile.am | 5 +-- src/render/jpgfile.cc | 89 ++++++++++++++++++++++++++++++++++++++++++++++++++ src/render/jpgfile.h | 34 +++++++++++++++++++ src/render/pngfile.cc | 5 +-- src/render/pngfile.h | 2 +- 5 files changed, 130 insertions(+), 5 deletions(-) create mode 100644 src/render/jpgfile.cc create mode 100644 src/render/jpgfile.h (limited to 'src/render') diff --git a/src/render/Makefile.am b/src/render/Makefile.am index 99b1847..3e3c0c8 100644 --- a/src/render/Makefile.am +++ b/src/render/Makefile.am @@ -9,8 +9,9 @@ endif librender_la_LDFLAGS = -avoid-version -no-undefined @GL_LIBS@ librender_la_LIBADD = $(top_builddir)/src/math/libmath.la -librender_la_SOURCES = camera.cc draw.cc dust.cc gl.cc image.cc pngfile.cc \ - render.cc text.cc textures.cc tga.cc +librender_la_SOURCES = camera.cc draw.cc dust.cc gl.cc image.cc jpgfile.cc \ + pngfile.cc render.cc text.cc textures.cc tga.cc noinst_HEADERS = camera.h draw.h dust.h gl.h image.h render.h text.h textures.h \ tga.h _SOURCES = pngfile.h +_SOURCES = jpgfile.h diff --git a/src/render/jpgfile.cc b/src/render/jpgfile.cc new file mode 100644 index 0000000..74cdea9 --- /dev/null +++ b/src/render/jpgfile.cc @@ -0,0 +1,89 @@ +/* + render/jpgfile.cc + This file is part of the Osirion project and is distributed under + the terms of the GNU General Public License version 2 +*/ + +/* +Notes: + +http://www.zarb.org/~gc/html/libpng.html + +*/ + +#include +#include + +#include "filesystem/filesystem.h" +#include "render/jpgfile.h" +#include "sys/sys.h" + +extern "C" { + #include "jpeglib.h" +} + +namespace render { + +Image *JPG::load(const char *filename) +{ + Image *image = 0; + + if (!filename) + return 0; + + filesystem::File *jpg_file = filesystem::open(filename); + if (!jpg_file) { + //con_warn << "Could not open " << filename << std::endl; + return 0; + } + + + filesystem::close(jpg_file); + +// con_debug << " " << filename << " " << png_width << "x" << png_height << "x" << channels * png_depth << "bpp" << std::endl; + + return image; +} + +void JPG::save(const char *filename, Image & image, int jpeg_quality) +{ + struct jpeg_compress_struct jpeg_compression_info; + struct jpeg_error_mgr jerr; + + JSAMPROW row_pointer[1]; + int row_stride; + + FILE *jpg_file = fopen(filename, "wb"); + if (!jpg_file) { + con_warn << "Could not write " << filename << std::endl; + return; + } + + jpeg_compression_info.err = jpeg_std_error(&jerr); + jpeg_create_compress(&jpeg_compression_info); + jpeg_stdio_dest(&jpeg_compression_info, jpg_file); + + jpeg_compression_info.image_width = image.width(); + jpeg_compression_info.image_height = image.height(); + jpeg_compression_info.input_components = image.channels(); + jpeg_compression_info.in_color_space = JCS_RGB; + + jpeg_set_defaults(&jpeg_compression_info); + jpeg_set_quality(&jpeg_compression_info, jpeg_quality, TRUE); + jpeg_start_compress(&jpeg_compression_info, TRUE); + row_stride = image.width() * image.channels(); + + while (jpeg_compression_info.next_scanline < jpeg_compression_info.image_height) { + row_pointer[0] = image[jpeg_compression_info.next_scanline * row_stride]; + jpeg_write_scanlines(&jpeg_compression_info, row_pointer, 1); + } + + jpeg_finish_compress(&jpeg_compression_info); + fclose(jpg_file); + + jpeg_destroy_compress(&jpeg_compression_info); + + con_print << "Wrote " << filename << std::endl; +} + +} diff --git a/src/render/jpgfile.h b/src/render/jpgfile.h new file mode 100644 index 0000000..858a8a3 --- /dev/null +++ b/src/render/jpgfile.h @@ -0,0 +1,34 @@ +/* + render/jpgfile.h + This file is part of the Osirion project and is distributed under + the terms of the GNU General Public License version 2 +*/ + + +#ifndef _INCLUDED_RENDER_JPGFILE_H_ +#define _INCLUDED_RENDER_JPGFILE_H_ + +#include "render/image.h" + +namespace render +{ + +/// a class for loading and saving .jpg files +class JPG { + +public: + /// load a JPG image file from disk + /** @param filename short path to the filename to be loaded + */ + static Image *load(const char * filename); + + /// write an image to a JPG file + /** @param filename short path to the file to write the image data to + */ + static void save(const char *filename, Image & image, int jpeg_quality); +}; + +} + +#endif //_INCLUDED_RENDER_JPGFILE_H_ + diff --git a/src/render/pngfile.cc b/src/render/pngfile.cc index 8038d22..bff6a54 100644 --- a/src/render/pngfile.cc +++ b/src/render/pngfile.cc @@ -1,5 +1,5 @@ /* - render/png.cc + render/pngfile.cc This file is part of the Osirion project and is distributed under the terms of the GNU General Public License version 2 */ @@ -11,8 +11,9 @@ http://www.zarb.org/~gc/html/libpng.html */ +#include "png.h" + #include -#include #include diff --git a/src/render/pngfile.h b/src/render/pngfile.h index a7beb7c..4559f70 100644 --- a/src/render/pngfile.h +++ b/src/render/pngfile.h @@ -1,5 +1,5 @@ /* - render/png.h + render/pngfile.h This file is part of the Osirion project and is distributed under the terms of the GNU General Public License version 2 */ -- cgit v1.2.3