Android Open Source - android_effects Effects Shader






From Project

Back to project page android_effects.

License

The source code is released under:

Apache License

If you think the Android project android_effects listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/*
   Copyright 2012 Harri Smatt//from  w  w w .j a v a 2  s  .  co m

   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 fi.harism.effects;

import java.util.HashMap;

import android.opengl.GLES20;
import android.util.Log;

/**
 * Helper class for handling shaders.
 */
public final class EffectsShader {

  // Shader program handles.
  private int mIdProgram = 0;
  private int mIdShaderFragment = 0;
  private int mIdShaderVertex = 0;
  // HashMap for storing uniform/attribute handles.
  private final HashMap<String, Integer> mShaderHandleMap = new HashMap<String, Integer>();

  /**
   * Deletes program and shaders associated with it.
   */
  public void deleteProgram() {
    GLES20.glDeleteShader(mIdShaderFragment);
    GLES20.glDeleteShader(mIdShaderVertex);
    GLES20.glDeleteProgram(mIdProgram);
    mIdProgram = mIdShaderVertex = mIdShaderFragment = 0;
  }

  /**
   * Get id for given handle name. This method checks for both attribute and
   * uniform handles.
   * 
   * @param name
   *            Name of handle.
   * @return Id for given handle or -1 if none found.
   */
  public int getHandle(String name) {
    if (mShaderHandleMap.containsKey(name)) {
      return mShaderHandleMap.get(name);
    }
    int handle = GLES20.glGetAttribLocation(mIdProgram, name);
    if (handle == -1) {
      handle = GLES20.glGetUniformLocation(mIdProgram, name);
    }
    if (handle == -1) {
      // One should never leave log messages but am not going to follow
      // this rule. This line comes handy if you see repeating 'not found'
      // messages on LogCat - usually for typos otherwise annoying to
      // spot from shader code.
      Log.d("GlslShader", "Could not get attrib location for " + name);
    } else {
      mShaderHandleMap.put(name, handle);
    }
    return handle;
  }

  /**
   * Get array of ids with given names. Returned array is sized to given
   * amount name elements.
   * 
   * @param names
   *            List of handle names.
   * @return array of handle ids.
   */
  public int[] getHandles(String... names) {
    int[] res = new int[names.length];
    for (int i = 0; i < names.length; ++i) {
      res[i] = getHandle(names[i]);
    }
    return res;
  }

  /**
   * Helper method for compiling a shader.
   * 
   * @param shaderType
   *            Type of shader to compile
   * @param source
   *            String presentation for shader
   * @return id for compiled shader
   */
  private int loadShader(int shaderType, String source) throws Exception {
    int shader = GLES20.glCreateShader(shaderType);
    if (shader != 0) {
      GLES20.glShaderSource(shader, source);
      GLES20.glCompileShader(shader);
      int[] compiled = new int[1];
      GLES20.glGetShaderiv(shader, GLES20.GL_COMPILE_STATUS, compiled, 0);
      if (compiled[0] == 0) {
        String error = GLES20.glGetShaderInfoLog(shader);
        GLES20.glDeleteShader(shader);
        throw new Exception(error);
      }
    }
    return shader;
  }

  /**
   * Compiles vertex and fragment shaders and links them into a program one
   * can use for rendering. Once OpenGL context is lost and onSurfaceCreated
   * is called, there is no need to reset existing GlslShader objects but one
   * can simply reload shader.
   * 
   * @param vertexSource
   *            String presentation for vertex shader
   * @param fragmentSource
   *            String presentation for fragment shader
   */
  public void setProgram(String vertexSource, String fragmentSource)
      throws Exception {
    mIdShaderVertex = loadShader(GLES20.GL_VERTEX_SHADER, vertexSource);
    mIdShaderFragment = loadShader(GLES20.GL_FRAGMENT_SHADER,
        fragmentSource);
    int program = GLES20.glCreateProgram();
    if (program != 0) {
      GLES20.glAttachShader(program, mIdShaderVertex);
      GLES20.glAttachShader(program, mIdShaderFragment);
      GLES20.glLinkProgram(program);
      int[] linkStatus = new int[1];
      GLES20.glGetProgramiv(program, GLES20.GL_LINK_STATUS, linkStatus, 0);
      if (linkStatus[0] != GLES20.GL_TRUE) {
        String error = GLES20.glGetProgramInfoLog(program);
        deleteProgram();
        throw new Exception(error);
      }
    }
    mIdProgram = program;
    mShaderHandleMap.clear();
  }

  /**
   * Activates this shader program.
   */
  public void useProgram() {
    GLES20.glUseProgram(mIdProgram);
  }

}




Java Source Code List

fi.harism.effects.EffectsActivity.java
fi.harism.effects.EffectsShader.java
fi.harism.effects.ViewBase.java
fi.harism.effects.ViewBlob.java
fi.harism.effects.ViewCircles.java
fi.harism.effects.ViewFluffy.java
fi.harism.effects.ViewFractal.java
fi.harism.effects.ViewParticles.java
fi.harism.effects.ViewPentagons.java
fi.harism.effects.ViewRubber.java
fi.harism.effects.ViewSplines.java
fi.harism.effects.ViewStars.java
fi.harism.effects.ViewTextures.java