-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsourceimage.h
78 lines (68 loc) · 2.25 KB
/
sourceimage.h
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
/**
* @file sourceimage.h
*
* Definition of SourceImage class.
*
* @author Jack Toole
* @author Matt Sachtler
* @author Scott Wegner
*
* Developed for CS225 PhotoMosaic MP, Fall 2008
* Rewritten Fall 2011 by Jack Toole
*/
#ifndef _SOURCEIMAGE_H
#define _SOURCEIMAGE_H
#include <stdint.h>
#include "png.h"
using namespace std;
/**
* SourceImage extends the Image class and provides some additional data and
* functions suitable for the source image for the photomosaic. The default
* constructor will take a number of rows and columns to divide the image
* into. The image will then be processes to find the average color of each
* region.
*/
class SourceImage
{
public:
/**
* Default constructor
*
* @param image The image data from GraphicsMagick
* @param resolution The resolution of the sub-regions. This will be the number
* of tiles in the larger of the two dimensions of the SourceImage. If the
* given resolution is greater than the largest dimension of the image, it will
* be automatically set to the pixel dimensions
*/
SourceImage(const PNG & image, int resolution);
/**
* Get the average color of a particular region. Note, the
* row and column should be specified with a 0-based index.
* i.e., The top-left corner is (row, column) (0,0).
*
* @param row The row of the particular region in the image
* @param col The column of the particular region in the image
*
* @return The average color of the image
*/
RGBAPixel getRegionColor(int row, int col) const;
/**
* Retreive the number of row sub-regions the source image
* is broken into.
*
* @return The number of rows, or -1 if in an invalid state
*/
int getRows() const;
/**
* Retreive the number of column sub-regions the source
* image is broken into.
*
* @return The number of columns, or -1 if in an invalid state
*/
int getColumns() const;
private:
PNG backingImage;
int resolution;
static uint64_t divide(uint64_t a, uint64_t b);
};
#endif /* _SOURCEIMAGE_H */