1 /* 2 * Copyright (C) 2008-2012 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.renderscript; 18 19 import android.annotation.UnsupportedAppUsage; 20 21 22 /** 23 * @hide 24 * @deprecated in API 16 25 * <p>ProgramFragmentFixedFunction is a helper class that provides 26 * a way to make a simple fragment shader without writing any 27 * GLSL code. This class allows for display of constant color, interpolated 28 * color from the vertex shader, or combinations of the both 29 * blended with results of up to two texture lookups.</p 30 * 31 **/ 32 public class ProgramFragmentFixedFunction extends ProgramFragment { 33 ProgramFragmentFixedFunction(long id, RenderScript rs) { 34 super(id, rs); 35 } 36 37 static class InternalBuilder extends BaseProgramBuilder { 38 /** 39 * @deprecated in API 16 40 */ 41 public InternalBuilder(RenderScript rs) { 42 super(rs); 43 } 44 45 /** 46 * @deprecated in API 16 47 * Creates ProgramFragmentFixedFunction from the current state 48 * of the builder 49 * 50 * @return ProgramFragmentFixedFunction 51 */ 52 public ProgramFragmentFixedFunction create() { 53 mRS.validate(); 54 long[] tmp = new long[(mInputCount + mOutputCount + mConstantCount + mTextureCount) * 2]; 55 String[] texNames = new String[mTextureCount]; 56 int idx = 0; 57 58 for (int i=0; i < mInputCount; i++) { 59 tmp[idx++] = ProgramParam.INPUT.mID; 60 tmp[idx++] = mInputs[i].getID(mRS); 61 } 62 for (int i=0; i < mOutputCount; i++) { 63 tmp[idx++] = ProgramParam.OUTPUT.mID; 64 tmp[idx++] = mOutputs[i].getID(mRS); 65 } 66 for (int i=0; i < mConstantCount; i++) { 67 tmp[idx++] = ProgramParam.CONSTANT.mID; 68 tmp[idx++] = mConstants[i].getID(mRS); 69 } 70 for (int i=0; i < mTextureCount; i++) { 71 tmp[idx++] = ProgramParam.TEXTURE_TYPE.mID; 72 tmp[idx++] = mTextureTypes[i].mID; 73 texNames[i] = mTextureNames[i]; 74 } 75 76 long id = mRS.nProgramFragmentCreate(mShader, texNames, tmp); 77 ProgramFragmentFixedFunction pf = new ProgramFragmentFixedFunction(id, mRS); 78 initProgram(pf); 79 return pf; 80 } 81 } 82 83 /** 84 * @deprecated in API 16 85 */ 86 public static class Builder { 87 /** 88 * @deprecated in API 16 89 */ 90 public static final int MAX_TEXTURE = 2; 91 int mNumTextures; 92 boolean mPointSpriteEnable; 93 boolean mVaryingColorEnable; 94 String mShader; 95 RenderScript mRS; 96 97 /** 98 * @deprecated in API 16 99 * EnvMode describes how textures are combined with the existing 100 * color in the fixed function fragment shader 101 * 102 **/ 103 public enum EnvMode { 104 /** 105 * @deprecated in API 16 106 **/ 107 @UnsupportedAppUsage 108 REPLACE (1), 109 /** 110 * @deprecated in API 16 111 **/ 112 @UnsupportedAppUsage 113 MODULATE (2), 114 /** 115 * @deprecated in API 16 116 **/ 117 DECAL (3); 118 119 int mID; 120 EnvMode(int id) { 121 mID = id; 122 } 123 } 124 125 /** 126 * @deprecated in API 16 127 * Format describes the pixel format of textures in the fixed 128 * function fragment shader and how they are sampled 129 * 130 **/ 131 public enum Format { 132 /** 133 * @deprecated in API 16 134 **/ 135 @UnsupportedAppUsage 136 ALPHA (1), 137 /** 138 * @deprecated in API 16 139 **/ 140 LUMINANCE_ALPHA (2), 141 /** 142 * @deprecated in API 16 143 **/ 144 @UnsupportedAppUsage 145 RGB (3), 146 /** 147 * @deprecated in API 16 148 **/ 149 @UnsupportedAppUsage 150 RGBA (4); 151 152 int mID; 153 Format(int id) { 154 mID = id; 155 } 156 } 157 158 private class Slot { 159 EnvMode env; 160 Format format; 161 Slot(EnvMode _env, Format _fmt) { 162 env = _env; 163 format = _fmt; 164 } 165 } 166 Slot[] mSlots; 167 168 private void buildShaderString() { 169 mShader = "//rs_shader_internal\n"; 170 mShader += "varying lowp vec4 varColor;\n"; 171 mShader += "varying vec2 varTex0;\n"; 172 173 mShader += "void main() {\n"; 174 if (mVaryingColorEnable) { 175 mShader += " lowp vec4 col = varColor;\n"; 176 } else { 177 mShader += " lowp vec4 col = UNI_Color;\n"; 178 } 179 180 if (mNumTextures != 0) { 181 if (mPointSpriteEnable) { 182 mShader += " vec2 t0 = gl_PointCoord;\n"; 183 } else { 184 mShader += " vec2 t0 = varTex0.xy;\n"; 185 } 186 } 187 188 for(int i = 0; i < mNumTextures; i ++) { 189 switch(mSlots[i].env) { 190 case REPLACE: 191 switch (mSlots[i].format) { 192 case ALPHA: 193 mShader += " col.a = texture2D(UNI_Tex0, t0).a;\n"; 194 break; 195 case LUMINANCE_ALPHA: 196 mShader += " col.rgba = texture2D(UNI_Tex0, t0).rgba;\n"; 197 break; 198 case RGB: 199 mShader += " col.rgb = texture2D(UNI_Tex0, t0).rgb;\n"; 200 break; 201 case RGBA: 202 mShader += " col.rgba = texture2D(UNI_Tex0, t0).rgba;\n"; 203 break; 204 } 205 break; 206 case MODULATE: 207 switch (mSlots[i].format) { 208 case ALPHA: 209 mShader += " col.a *= texture2D(UNI_Tex0, t0).a;\n"; 210 break; 211 case LUMINANCE_ALPHA: 212 mShader += " col.rgba *= texture2D(UNI_Tex0, t0).rgba;\n"; 213 break; 214 case RGB: 215 mShader += " col.rgb *= texture2D(UNI_Tex0, t0).rgb;\n"; 216 break; 217 case RGBA: 218 mShader += " col.rgba *= texture2D(UNI_Tex0, t0).rgba;\n"; 219 break; 220 } 221 break; 222 case DECAL: 223 mShader += " col = texture2D(UNI_Tex0, t0);\n"; 224 break; 225 } 226 } 227 228 mShader += " gl_FragColor = col;\n"; 229 mShader += "}\n"; 230 } 231 232 /** 233 * @deprecated 234 * Creates a builder for fixed function fragment program 235 * 236 * @param rs Context to which the program will belong. 237 */ 238 @UnsupportedAppUsage 239 public Builder(RenderScript rs) { 240 mRS = rs; 241 mSlots = new Slot[MAX_TEXTURE]; 242 mPointSpriteEnable = false; 243 } 244 245 /** 246 * @deprecated in API 16 247 * Adds a texture to be fetched as part of the fixed function 248 * fragment program 249 * 250 * @param env specifies how the texture is combined with the 251 * current color 252 * @param fmt specifies the format of the texture and how its 253 * components will be used to combine with the 254 * current color 255 * @param slot index of the texture to apply the operations on 256 * 257 * @return this 258 */ 259 @UnsupportedAppUsage 260 public Builder setTexture(EnvMode env, Format fmt, int slot) 261 throws IllegalArgumentException { 262 if((slot < 0) || (slot >= MAX_TEXTURE)) { 263 throw new IllegalArgumentException("MAX_TEXTURE exceeded."); 264 } 265 mSlots[slot] = new Slot(env, fmt); 266 return this; 267 } 268 269 /** 270 * @deprecated in API 16 271 * Specifies whether the texture coordinate passed from the 272 * vertex program is replaced with an openGL internal point 273 * sprite texture coordinate 274 * 275 **/ 276 public Builder setPointSpriteTexCoordinateReplacement(boolean enable) { 277 mPointSpriteEnable = enable; 278 return this; 279 } 280 281 /** 282 * @deprecated in API 16 283 * Specifies whether the varying color passed from the vertex 284 * program or the constant color set on the fragment program is 285 * used in the final color calculation in the fixed function 286 * fragment shader 287 * 288 **/ 289 @UnsupportedAppUsage 290 public Builder setVaryingColor(boolean enable) { 291 mVaryingColorEnable = enable; 292 return this; 293 } 294 295 /** 296 * @deprecated in API 16 297 * Creates the fixed function fragment program from the current 298 * state of the builder. 299 * 300 */ 301 @UnsupportedAppUsage 302 public ProgramFragmentFixedFunction create() { 303 InternalBuilder sb = new InternalBuilder(mRS); 304 mNumTextures = 0; 305 for(int i = 0; i < MAX_TEXTURE; i ++) { 306 if(mSlots[i] != null) { 307 mNumTextures ++; 308 } 309 } 310 buildShaderString(); 311 sb.setShader(mShader); 312 313 Type constType = null; 314 if (!mVaryingColorEnable) { 315 Element.Builder b = new Element.Builder(mRS); 316 b.add(Element.F32_4(mRS), "Color"); 317 Type.Builder typeBuilder = new Type.Builder(mRS, b.create()); 318 typeBuilder.setX(1); 319 constType = typeBuilder.create(); 320 sb.addConstant(constType); 321 } 322 for (int i = 0; i < mNumTextures; i ++) { 323 sb.addTexture(TextureType.TEXTURE_2D); 324 } 325 326 ProgramFragmentFixedFunction pf = sb.create(); 327 pf.mTextureCount = MAX_TEXTURE; 328 if (!mVaryingColorEnable) { 329 Allocation constantData = Allocation.createTyped(mRS,constType); 330 FieldPacker fp = new FieldPacker(16); 331 Float4 f4 = new Float4(1.f, 1.f, 1.f, 1.f); 332 fp.addF32(f4); 333 constantData.setFromFieldPacker(0, fp); 334 pf.bindConstants(constantData, 0); 335 } 336 return pf; 337 } 338 } 339 } 340 341 342 343 344