blob: 3013bde4ed7d39786659a76e1931c3b8e71db226 (
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package org.apache.tools.ant.types.optional.image;
import java.awt.image.BufferedImage;
import java.awt.image.renderable.ParameterBlock;
import javax.media.jai.InterpolationNearest;
import javax.media.jai.JAI;
import javax.media.jai.PlanarImage;
/**
* ImageOperation to rotate an image by a certain degree
*
* @see org.apache.tools.ant.taskdefs.optional.image.Image
*/
public class Rotate extends TransformOperation implements DrawOperation {
private static final float HALF_CIRCLE = 180.0F;
// CheckStyle:VisibilityModifier OFF - bc
protected float angle = 0.0F;
// CheckStyle:VisibilityModifier ON
/**
* Sets the angle of rotation in degrees.
* @param ang The angle at which to rotate the image
*/
public void setAngle(String ang) {
angle = Float.parseFloat(ang);
}
/**
* Rotate an image.
* @param image the image to rotate.
* @return the rotated image.
*/
public PlanarImage performRotate(PlanarImage image) {
float tAngle = (float) (angle * (Math.PI / HALF_CIRCLE));
ParameterBlock pb = new ParameterBlock();
pb.addSource(image);
pb.add(0.0F);
pb.add(0.0F);
pb.add(tAngle);
pb.add(new InterpolationNearest());
return JAI.create("Rotate", pb, null);
}
/**
* Performs the image rotation when being handled as a TransformOperation.
* @param image The image to perform the transformation on.
* @return the transformed image.
*/
public PlanarImage executeTransformOperation(PlanarImage image) {
BufferedImage bi = null;
final int size = instructions.size();
for (int i = 0; i < size; i++) {
ImageOperation instr = ((ImageOperation) instructions.elementAt(i));
if (instr instanceof DrawOperation) {
// If this TransformOperation has DrawOperation children
// then Rotate the first child and return.
System.out.println("Execing Draws");
PlanarImage op = ((DrawOperation) instr).executeDrawOperation();
image = performRotate(op);
return image;
} else if (instr instanceof TransformOperation) {
bi = image.getAsBufferedImage();
System.out.println("Execing Transforms");
image = ((TransformOperation) instr)
.executeTransformOperation(PlanarImage.wrapRenderedImage(bi));
bi = image.getAsBufferedImage();
}
}
System.out.println("Execing as TransformOperation");
image = performRotate(image);
System.out.println(image);
return image;
}
/**
* Performs the image rotation when being handled as a DrawOperation.
* It absolutely requires that there be a DrawOperation nested beneath it,
* but only the FIRST DrawOperation will be handled since it can only return
* ONE image.
* @return the image.
*/
public PlanarImage executeDrawOperation() {
final int size = instructions.size();
for (int i = 0; i < size; i++) {
ImageOperation instr = ((ImageOperation) instructions.elementAt(i));
if (instr instanceof DrawOperation) {
// If this TransformOperation has DrawOperation children
// then Rotate the first child and return.
PlanarImage op = ((DrawOperation) instr).executeDrawOperation();
op = performRotate(op);
return op;
}
}
return null;
}
}
|