/*
* Copyright (C) 2012 CyberAgent
*
* Licensed 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 jp.co.cyberagent.android.gpuimage;
import java.util.ArrayList;
import java.util.List;
/**
* Applies sobel edge detection on the image.
*/
public class GPUImageSobelEdgeDetection extends GPUImageFilterGroup {
public static final String SOBEL_EDGE_DETECTION = "" +
"precision mediump float;\n" +
"\n" +
"varying vec2 textureCoordinate;\n" +
"varying vec2 leftTextureCoordinate;\n" +
"varying vec2 rightTextureCoordinate;\n" +
"\n" +
"varying vec2 topTextureCoordinate;\n" +
"varying vec2 topLeftTextureCoordinate;\n" +
"varying vec2 topRightTextureCoordinate;\n" +
"\n" +
"varying vec2 bottomTextureCoordinate;\n" +
"varying vec2 bottomLeftTextureCoordinate;\n" +
"varying vec2 bottomRightTextureCoordinate;\n" +
"\n" +
"uniform sampler2D inputImageTexture;\n" +
"\n" +
"void main()\n" +
"{\n" +
" float bottomLeftIntensity = texture2D(inputImageTexture, bottomLeftTextureCoordinate).r;\n" +
" float topRightIntensity = texture2D(inputImageTexture, topRightTextureCoordinate).r;\n" +
" float topLeftIntensity = texture2D(inputImageTexture, topLeftTextureCoordinate).r;\n" +
" float bottomRightIntensity = texture2D(inputImageTexture, bottomRightTextureCoordinate).r;\n" +
" float leftIntensity = texture2D(inputImageTexture, leftTextureCoordinate).r;\n" +
" float rightIntensity = texture2D(inputImageTexture, rightTextureCoordinate).r;\n" +
" float bottomIntensity = texture2D(inputImageTexture, bottomTextureCoordinate).r;\n" +
" float topIntensity = texture2D(inputImageTexture, topTextureCoordinate).r;\n" +
" float h = -topLeftIntensity - 2.0 * topIntensity - topRightIntensity + bottomLeftIntensity + 2.0 * bottomIntensity + bottomRightIntensity;\n" +
" float v = -bottomLeftIntensity - 2.0 * leftIntensity - topLeftIntensity + bottomRightIntensity + 2.0 * rightIntensity + topRightIntensity;\n" +
"\n" +
" float mag = length(vec2(h, v));\n" +
"\n" +
" gl_FragColor = vec4(vec3(mag), 1.0);\n" +
"}";
public GPUImageSobelEdgeDetection() {
super(createFilters());
}
private static List<GPUImageFilter> createFilters() {
List<GPUImageFilter> filters = new ArrayList<GPUImageFilter>(2);
filters.add(new GPUImageGrayscaleFilter());
filters.add(new GPUImage3x3TextureSamplingFilter(SOBEL_EDGE_DETECTION));
return filters;
}
public void setLineSize(final float size) {
((GPUImage3x3TextureSamplingFilter) getFilters().get(1)).setLineSize(size);
}
}