1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
/*-----------------------------------------------------------------
LOG
GEM - Graphics Environment for Multimedia
Clamp pixel values to a threshold_bernsen
Copyright (c) 1997-1998 Mark Danks. mark@danks.org
Copyright (c) Günther Geiger. geiger@epy.co.at
Copyright (c) 2001-2011 IOhannes m zmölnig. forum::für::umläute. IEM. zmoelnig@iem.at
Copyright (c) 2002 James Tittle & Chris Clepper
For information on usage and redistribution, and for a DISCLAIMER OF ALL
WARRANTIES, see the file, "GEM.LICENSE.TERMS" in this distribution.
-----------------------------------------------------------------*/
#ifndef _INCLUDE__GEM_PIXES_PIX_THRESHOLD_BERNSEN_H_
#define _INCLUDE__GEM_PIXES_PIX_THRESHOLD_BERNSEN_H_
#include "Base/GemPixObj.h"
/*-----------------------------------------------------------------
-------------------------------------------------------------------
CLASS
pix_threshold_bernsen
Clamp pixel values to a threshold_bernsen
KEYWORDS
pix
DESCRIPTION
Inlet for a list - "vec_thresh"
Inlet for a float - "ft1"
"vec_thresh" - The threshold_bernsen vector
"ft1" - Set all threshold_bernsens to one value
-----------------------------------------------------------------*/
class GEM_EXTERN pix_threshold_bernsen : public GemPixObj
{
CPPEXTERN_HEADER(pix_threshold_bernsen, GemPixObj);
public:
//////////
// Constructor
pix_threshold_bernsen();
protected:
//////////
// Destructor
virtual ~pix_threshold_bernsen();
//////////
// Do the processing
static void processGraySub_getMinMax(imageStruct&image,
int fromX, int toX,
int fromY, int toY,
unsigned char*resultMin,
unsigned char*resultMax);
virtual void processGrayImage(imageStruct &image);
//////////
// set the number of tiles
void tilesMess(int w, int h);
void contrastMess(int c);
int m_xtiles, m_ytiles;
int m_contrast;
unsigned char*m_minVals;
unsigned char*m_maxVals;
private:
//////////
// Static member functions
static void tilesMessCallback(void *data, t_float w, t_float h);
static void contrastMessCallback(void *data, t_float c);
};
#endif // for header file
|