summaryrefslogtreecommitdiff
path: root/dmagick/c/resample.d
blob: 7a0cb0b22cb68e7c981892fc0e9ceaa35f719ff8 (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
56
57
58
59
60
61
62
63
64
65
module dmagick.c.resample;

import dmagick.c.exception;
import dmagick.c.image;
import dmagick.c.magickType;
import dmagick.c.pixel;
import dmagick.c.cacheView;

extern(C)
{
	enum FilterTypes
	{
		UndefinedFilter,
		PointFilter,
		BoxFilter,
		TriangleFilter,
		HermiteFilter,
		HanningFilter,
		HammingFilter,
		BlackmanFilter,
		GaussianFilter,
		QuadraticFilter,
		CubicFilter,
		CatromFilter,
		MitchellFilter,
		LanczosFilter,
		JincFilter,
		SincFilter,
		KaiserFilter,
		WelshFilter,
		ParzenFilter,
		LagrangeFilter,
		BohmanFilter,
		BartlettFilter,
		SincFastFilter,
		Lanczos2DFilter,
		RobidouxFilter,
		SentinelFilter
	}

	enum InterpolatePixelMethod
	{
		UndefinedInterpolatePixel,
		AverageInterpolatePixel,
		BicubicInterpolatePixel,
		BilinearInterpolatePixel,
		FilterInterpolatePixel,
		IntegerInterpolatePixel,
		MeshInterpolatePixel,
		NearestNeighborInterpolatePixel,
		SplineInterpolatePixel
	}

	struct ResampleFilter {}

	MagickBooleanType ResamplePixelColor(ResampleFilter*, const double, const double, MagickPixelPacket*);
	MagickBooleanType SetResampleFilterInterpolateMethod(ResampleFilter*, const InterpolatePixelMethod);
	MagickBooleanType SetResampleFilterVirtualPixelMethod(ResampleFilter*, const VirtualPixelMethod);

	ResampleFilter* AcquireResampleFilter(const(Image)*, ExceptionInfo*);
	ResampleFilter* DestroyResampleFilter(ResampleFilter*);

	void ScaleResampleFilter(ResampleFilter*, const double, const double, const double, const double);
	void SetResampleFilter(ResampleFilter*, const FilterTypes, const double);
}