summaryrefslogtreecommitdiff
path: root/src/DataImage.H
blob: 18468577f301fdf5b85801de0e80e6d3c713f9e4 (plain)
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
// 
// Copyright 2006 by Johannes Hofmann
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Library General Public
// License as published by the Free Software Foundation; either
// version 2 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
// Library General Public License for more details.
//
// You should have received a copy of the GNU Library General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
// USA.
//

#ifndef DATAIMAGE_H
#define DATAIMAGE_H

#include <FL/Fl_Widget.H>
#include <FL/Fl_Image.H>

class DataImage : public Fl_Widget {
	private:
		int d;
		uchar *data;
		

	public:
		DataImage(int X, int Y, int W, int H, int channels=3);

		~DataImage();
		
		int set_pixel(int x, int y, char r, char g, char b);

		void draw();

		int write_jpeg(const char *file, int quality);

		int write_tiff(const char *file);

		static int get_pixel(Fl_Image *img, int x, int y,
			char *r, char *g, char *b);

		static int get_pixel_bilinear(Fl_Image *img, double x, double y,
			char *r, char *g, char *b);

		static int get_pixel_nearest(Fl_Image *img, double x, double y,
			char *r, char *g, char *b);
};

#endif