diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/Makefile.am | 2 | ||||
-rw-r--r-- | src/Makefile.in | 21 | ||||
-rw-r--r-- | src/cubeit.c | 1 | ||||
-rw-r--r-- | src/render.c | 163 | ||||
-rw-r--r-- | src/render.h | 9 |
5 files changed, 107 insertions, 89 deletions
diff --git a/src/Makefile.am b/src/Makefile.am index 98508dd0..75ef8063 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -67,9 +67,11 @@ facetron_SOURCES = facetron.c cell.c hdf5-file.c utils.c detector.c peaks.c \ beam-parameters.c symmetry.c post-refinement.c hrs-scaling.c facetron_LDADD = @LIBS@ +if HAVE_CAIRO cubeit_SOURCES = cubeit.c cell.c hdf5-file.c utils.c detector.c render.c \ filters.c image.c symmetry.c stream.c thread-pool.c cubeit_LDADD = @LIBS@ +endif reintegrate_SOURCES = reintegrate.c cell.c hdf5-file.c utils.c detector.c \ peaks.c image.c stream.c \ diff --git a/src/Makefile.in b/src/Makefile.in index d7833b13..11b0eabf 100644 --- a/src/Makefile.in +++ b/src/Makefile.in @@ -70,10 +70,15 @@ am_compare_hkl_OBJECTS = compare_hkl.$(OBJEXT) sfac.$(OBJEXT) \ statistics.$(OBJEXT) symmetry.$(OBJEXT) compare_hkl_OBJECTS = $(am_compare_hkl_OBJECTS) compare_hkl_DEPENDENCIES = -am_cubeit_OBJECTS = cubeit.$(OBJEXT) cell.$(OBJEXT) \ - hdf5-file.$(OBJEXT) utils.$(OBJEXT) detector.$(OBJEXT) \ - render.$(OBJEXT) filters.$(OBJEXT) image.$(OBJEXT) \ - symmetry.$(OBJEXT) stream.$(OBJEXT) thread-pool.$(OBJEXT) +am__cubeit_SOURCES_DIST = cubeit.c cell.c hdf5-file.c utils.c \ + detector.c render.c filters.c image.c symmetry.c stream.c \ + thread-pool.c +@HAVE_CAIRO_TRUE@am_cubeit_OBJECTS = cubeit.$(OBJEXT) cell.$(OBJEXT) \ +@HAVE_CAIRO_TRUE@ hdf5-file.$(OBJEXT) utils.$(OBJEXT) \ +@HAVE_CAIRO_TRUE@ detector.$(OBJEXT) render.$(OBJEXT) \ +@HAVE_CAIRO_TRUE@ filters.$(OBJEXT) image.$(OBJEXT) \ +@HAVE_CAIRO_TRUE@ symmetry.$(OBJEXT) stream.$(OBJEXT) \ +@HAVE_CAIRO_TRUE@ thread-pool.$(OBJEXT) cubeit_OBJECTS = $(am_cubeit_OBJECTS) cubeit_DEPENDENCIES = am_estimate_background_OBJECTS = estimate_background.$(OBJEXT) \ @@ -180,7 +185,7 @@ SOURCES = $(calibrate_detector_SOURCES) $(check_hkl_SOURCES) \ $(process_hkl_SOURCES) $(reintegrate_SOURCES) \ $(render_hkl_SOURCES) DIST_SOURCES = $(calibrate_detector_SOURCES) $(check_hkl_SOURCES) \ - $(compare_hkl_SOURCES) $(cubeit_SOURCES) \ + $(compare_hkl_SOURCES) $(am__cubeit_SOURCES_DIST) \ $(estimate_background_SOURCES) $(facetron_SOURCES) \ $(get_hkl_SOURCES) $(am__hdfsee_SOURCES_DIST) \ $(am__indexamajig_SOURCES_DIST) \ @@ -333,10 +338,10 @@ facetron_SOURCES = facetron.c cell.c hdf5-file.c utils.c detector.c peaks.c \ beam-parameters.c symmetry.c post-refinement.c hrs-scaling.c facetron_LDADD = @LIBS@ -cubeit_SOURCES = cubeit.c cell.c hdf5-file.c utils.c detector.c render.c \ - filters.c image.c symmetry.c stream.c thread-pool.c +@HAVE_CAIRO_TRUE@cubeit_SOURCES = cubeit.c cell.c hdf5-file.c utils.c detector.c render.c \ +@HAVE_CAIRO_TRUE@ filters.c image.c symmetry.c stream.c thread-pool.c -cubeit_LDADD = @LIBS@ +@HAVE_CAIRO_TRUE@cubeit_LDADD = @LIBS@ reintegrate_SOURCES = reintegrate.c cell.c hdf5-file.c utils.c detector.c \ peaks.c image.c stream.c \ index.c dirax.c templates.c geometry.c symmetry.c \ diff --git a/src/cubeit.c b/src/cubeit.c index 4b32e11b..c5766d6f 100644 --- a/src/cubeit.c +++ b/src/cubeit.c @@ -25,6 +25,7 @@ #include <fenv.h> #include <pthread.h> #include <libgen.h> +#include <cairo.h> #include "utils.h" #include "hdf5-file.h" diff --git a/src/render.c b/src/render.c index 2cc6a63b..98fb693d 100644 --- a/src/render.c +++ b/src/render.c @@ -13,8 +13,12 @@ #include <config.h> #endif -#include <stdlib.h> + +#ifdef HAVE_GTK #include <gdk-pixbuf/gdk-pixbuf.h> +#endif + +#include <stdlib.h> #include <math.h> #include <stdint.h> #include <png.h> @@ -27,81 +31,6 @@ #include "utils.h" -static void *render_bin(float *in, int inw, int inh, int binning, float *maxp) -{ - float *data; - int x, y; - int w, h; - float max; - - w = inw / binning; - h = inh / binning; /* Some pixels might get discarded */ - - data = malloc(w*h*sizeof(float)); - max = 0.0; - - for ( x=0; x<w; x++ ) { - for ( y=0; y<h; y++ ) { - - double total; - size_t xb, yb; - - total = 0; - for ( xb=0; xb<binning; xb++ ) { - for ( yb=0; yb<binning; yb++ ) { - - total += in[binning*x+xb + (binning*y+yb)*inw]; - - } - } - - data[x+w*y] = total / ((double)binning * (double)binning); - if ( data[x+w*y] > max ) max = data[x+w*y]; - - } - } - - *maxp = max; - return data; -} - - -float *render_get_image_binned(DisplayWindow *dw, int binning, float *max) -{ - struct image *image; - float *data; - - if ( (dw->image == NULL) || (dw->image_dirty) ) { - - image = malloc(sizeof(struct image)); - if ( image == NULL ) return NULL; - image->features = NULL; - image->data = NULL; - - /* We don't care about the photon energy here */ - hdf5_read(dw->hdfile, image, 1, 0.0); - dw->image_dirty = 0; - if ( dw->cmfilter ) filter_cm(image); - if ( dw->noisefilter ) filter_noise(image, NULL); - - /* Deal with the old image, if existing */ - if ( dw->image != NULL ) { - image->features = dw->image->features; - if ( dw->image->data != NULL ) free(dw->image->data); - free(dw->image); - } - - dw->image = image; - - } - - data = render_bin(dw->image->data, hdfile_get_width(dw->hdfile), - hdfile_get_height(dw->hdfile), binning, max); - - return data; -} - - static void render_rgb(float val, float max, float *rp, float *gp, float *bp) { int s; @@ -201,6 +130,84 @@ void render_scale(float val, float max, int scale, } +#ifdef HAVE_GTK + + +static void *render_bin(float *in, int inw, int inh, int binning, float *maxp) +{ + float *data; + int x, y; + int w, h; + float max; + + w = inw / binning; + h = inh / binning; /* Some pixels might get discarded */ + + data = malloc(w*h*sizeof(float)); + max = 0.0; + + for ( x=0; x<w; x++ ) { + for ( y=0; y<h; y++ ) { + + double total; + size_t xb, yb; + + total = 0; + for ( xb=0; xb<binning; xb++ ) { + for ( yb=0; yb<binning; yb++ ) { + + total += in[binning*x+xb + (binning*y+yb)*inw]; + + } + } + + data[x+w*y] = total / ((double)binning * (double)binning); + if ( data[x+w*y] > max ) max = data[x+w*y]; + + } + } + + *maxp = max; + return data; +} + + +float *render_get_image_binned(DisplayWindow *dw, int binning, float *max) +{ + struct image *image; + float *data; + + if ( (dw->image == NULL) || (dw->image_dirty) ) { + + image = malloc(sizeof(struct image)); + if ( image == NULL ) return NULL; + image->features = NULL; + image->data = NULL; + + /* We don't care about the photon energy here */ + hdf5_read(dw->hdfile, image, 1, 0.0); + dw->image_dirty = 0; + if ( dw->cmfilter ) filter_cm(image); + if ( dw->noisefilter ) filter_noise(image, NULL); + + /* Deal with the old image, if existing */ + if ( dw->image != NULL ) { + image->features = dw->image->features; + if ( dw->image->data != NULL ) free(dw->image->data); + free(dw->image); + } + + dw->image = image; + + } + + data = render_bin(dw->image->data, hdfile_get_width(dw->hdfile), + hdfile_get_height(dw->hdfile), binning, max); + + return data; +} + + /* NB This function is shared between render_get_image() and * render_get_colour_scale() */ static void render_free_data(guchar *data, gpointer p) @@ -250,7 +257,6 @@ static void show_marked_features(struct image *image, guchar *data, } -#ifdef HAVE_GTK /* Return a pixbuf containing a rendered version of the image after binning. * This pixbuf might be scaled later - hopefully mostly in a downward * direction. */ @@ -345,7 +351,6 @@ GdkPixbuf *render_get_colour_scale(size_t w, size_t h, int scale) return gdk_pixbuf_new_from_data(data, GDK_COLORSPACE_RGB, FALSE, 8, w, h, w*3, render_free_data, NULL); } -#endif /* HAVE_GTK */ int render_png(DisplayWindow *dw, const char *filename) @@ -566,3 +571,5 @@ int render_tiff_int16(DisplayWindow *dw, const char *filename) #endif return 0; } + +#endif /* HAVE_GTK */ diff --git a/src/render.h b/src/render.h index 902ec278..ae9fb637 100644 --- a/src/render.h +++ b/src/render.h @@ -20,7 +20,7 @@ #include <stddef.h> -#include "displaywindow.h" + #include "image.h" enum { @@ -32,18 +32,21 @@ enum { extern void render_scale(float val, float max, int scale, float *rp, float *gp, float *bp); + #ifdef HAVE_GTK #include <gdk-pixbuf/gdk-pixbuf.h> +#include "displaywindow.h" extern GdkPixbuf *render_get_image(DisplayWindow *dw); extern GdkPixbuf *render_get_colour_scale(size_t w, size_t h, int scale); -#endif /* HAVE_GTK */ - extern int render_png(DisplayWindow *dw, const char *filename); extern int render_tiff_fp(DisplayWindow *dw, const char *filename); extern int render_tiff_int16(DisplayWindow *dw, const char *filename); +#endif /* HAVE_GTK */ + + #endif /* RENDER_H */ |