Project

General

Profile

Download (8.5 KB) Statistics
| Branch: | Revision:

library / src / main / java / org / distorted / library / effectqueue / EffectQueuePostprocess.java @ 46d463a4

1 4c1dd6e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2016 Leszek Koltunski                                                               //
3
//                                                                                               //
4 46b572b5 Leszek Koltunski
// This file is part of Distorted.                                                               //
5 4c1dd6e9 Leszek Koltunski
//                                                                                               //
6 46b572b5 Leszek Koltunski
// Distorted is free software: you can redistribute it and/or modify                             //
7 4c1dd6e9 Leszek Koltunski
// it under the terms of the GNU General Public License as published by                          //
8
// the Free Software Foundation, either version 2 of the License, or                             //
9
// (at your option) any later version.                                                           //
10
//                                                                                               //
11 46b572b5 Leszek Koltunski
// Distorted is distributed in the hope that it will be useful,                                  //
12 4c1dd6e9 Leszek Koltunski
// but WITHOUT ANY WARRANTY; without even the implied warranty of                                //
13
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                 //
14
// GNU General Public License for more details.                                                  //
15
//                                                                                               //
16
// You should have received a copy of the GNU General Public License                             //
17 46b572b5 Leszek Koltunski
// along with Distorted.  If not, see <http://www.gnu.org/licenses/>.                            //
18 4c1dd6e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
19
20 809dcae3 Leszek Koltunski
package org.distorted.library.effectqueue;
21 4c1dd6e9 Leszek Koltunski
22 a13dde77 Leszek Koltunski
import android.content.res.Resources;
23 b7074bc6 Leszek Koltunski
import android.opengl.GLES30;
24 a13dde77 Leszek Koltunski
import android.util.Log;
25 8dccc3c2 Leszek Koltunski
26 a13dde77 Leszek Koltunski
import org.distorted.library.R;
27 da9b3f07 Leszek Koltunski
import org.distorted.library.effect.EffectType;
28 fe82a979 Leszek Koltunski
import org.distorted.library.effect.PostprocessEffect;
29 a13dde77 Leszek Koltunski
import org.distorted.library.effect.VertexEffect;
30 c90aca24 Leszek Koltunski
import org.distorted.library.main.DistortedEffects;
31 7602a827 Leszek Koltunski
import org.distorted.library.main.DistortedLibrary;
32 809dcae3 Leszek Koltunski
import org.distorted.library.main.DistortedFramebuffer;
33
import org.distorted.library.main.DistortedNode;
34 7602a827 Leszek Koltunski
import org.distorted.library.main.InternalOutputSurface;
35
import org.distorted.library.main.InternalRenderState;
36 715e7726 Leszek Koltunski
import org.distorted.library.mesh.MeshBase;
37 ed06301f Leszek Koltunski
import org.distorted.library.message.EffectMessageSender;
38 a13dde77 Leszek Koltunski
import org.distorted.library.program.DistortedProgram;
39
40
import java.io.InputStream;
41 8fa96e69 Leszek Koltunski
42 4c1dd6e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
43 809dcae3 Leszek Koltunski
/**
44
 * Not part of public API, do not document
45
 *
46
 * @y.exclude
47
 */
48
public class EffectQueuePostprocess extends EffectQueue
49 4c1dd6e9 Leszek Koltunski
  {
50 96e3b88a Leszek Koltunski
  private static final int NUM_FLOAT_UNIFORMS = PostprocessEffect.NUM_FLOAT_UNIFORMS;
51
  private static final int NUM_INT_UNIFORMS   = PostprocessEffect.NUM_INT_UNIFORMS;
52 2b7d2abb Leszek Koltunski
  private static final boolean USE_UBO        = false;
53 da9b3f07 Leszek Koltunski
  private static final int INDEX = EffectType.POSTPROCESS.ordinal();
54 4c1dd6e9 Leszek Koltunski
55 fff1110e leszek
  private int mHalo;
56 9e771d06 Leszek Koltunski
  private float mR, mG, mB, mA;
57 a31dbc5c Leszek Koltunski
58 247d8225 Leszek Koltunski
  private static DistortedProgram mPreProgram;
59
  private static int mPreColorH;
60 9e771d06 Leszek Koltunski
  private static int mPreTextureH;
61 0bd9f644 Leszek Koltunski
  private static int mPreProgramH;
62 a13dde77 Leszek Koltunski
63 4c1dd6e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
64
65 20dbec0e Leszek Koltunski
  EffectQueuePostprocess()
66 4c1dd6e9 Leszek Koltunski
    { 
67 2b7d2abb Leszek Koltunski
    super(NUM_FLOAT_UNIFORMS, NUM_INT_UNIFORMS, USE_UBO, INDEX );
68 4c1dd6e9 Leszek Koltunski
    }
69
70 f046b159 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
71
72
  EffectQueuePostprocess(EffectQueuePostprocess source)
73
    {
74
    super(source);
75
    }
76
77 c90b9e01 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
78
79 1149be8f leszek
  void compute(long currTime)
80 4c1dd6e9 Leszek Koltunski
    {
81 15aa7d94 Leszek Koltunski
    if( currTime==mTime ) return;
82 4c1dd6e9 Leszek Koltunski
    if( mTime==0 ) mTime = currTime;
83
    long step = (currTime-mTime);
84 e02264ff leszek
85 9e771d06 Leszek Koltunski
    mR = mG = mB = mA = 0.0f;
86 fff1110e leszek
    mHalo = 0;
87
    int halo;
88 de77a6c5 Leszek Koltunski
    float[] array = mUBF.getBackingArray();
89 fff1110e leszek
90 4c1dd6e9 Leszek Koltunski
    for(int i=0; i<mNumEffects; i++)
91
      {
92 e49b26ba Leszek Koltunski
      // first zero out the 'alpha' because BLUR effect will not overwrite this (it is a 1D effect)
93
      // and if previously there was a GLOW effect here then mA would be non-zero and we don't want
94
      // that (see preprocess())
95 de77a6c5 Leszek Koltunski
      array[NUM_FLOAT_UNIFORMS*i+5]=0.0f;
96 e49b26ba Leszek Koltunski
97 de77a6c5 Leszek Koltunski
      if( mEffects[i].compute(array, NUM_FLOAT_UNIFORMS*i, currTime, step) )
98 4c1dd6e9 Leszek Koltunski
        {
99 20dbec0e Leszek Koltunski
        EffectMessageSender.newMessage(mEffects[i]);
100 4c1dd6e9 Leszek Koltunski
        }
101 a31dbc5c Leszek Koltunski
102 de77a6c5 Leszek Koltunski
      halo = (int)array[NUM_FLOAT_UNIFORMS*i];
103 fff1110e leszek
      if( halo>mHalo ) mHalo = halo;
104 4c1dd6e9 Leszek Koltunski
      }
105 e02264ff leszek
106 9e771d06 Leszek Koltunski
    // TODO  (now only really works in case of 1 effect!)
107
    if( mNumEffects>0 )
108
      {
109 de77a6c5 Leszek Koltunski
      mR = array[2];
110
      mG = array[3];
111
      mB = array[4];
112
      mA = array[5];
113 9e771d06 Leszek Koltunski
      }
114
115 95c441a2 leszek
    mTime = currTime;
116 4c1dd6e9 Leszek Koltunski
    }
117
118 984dc935 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
119 247d8225 Leszek Koltunski
120 b7074bc6 Leszek Koltunski
  public static void createPrograms(Resources resources, int GLSL)
121 a13dde77 Leszek Koltunski
    {
122
    final InputStream mainVertStream = resources.openRawResource(R.raw.main_vertex_shader);
123
    final InputStream mainFragStream = resources.openRawResource(R.raw.preprocess_fragment_shader);
124
125
    int numV = VertexEffect.getNumEnabled();
126
127 b7074bc6 Leszek Koltunski
    String version = "#version "+GLSL+" es\n";
128 8e3b71e2 Leszek Koltunski
    String mainVertHeader= version + ("#define NUM_VERTEX " + ( numV>0 ? DistortedLibrary.getMax(EffectType.VERTEX  ) : 0 ) + "\n");
129 b7074bc6 Leszek Koltunski
    String mainFragHeader= version + "\n";
130 a13dde77 Leszek Koltunski
131 e8925fcd Leszek Koltunski
    mainVertHeader += "#define MAX_COMPON " + MeshBase.getMaxEffComponents() + "\n";
132 46d463a4 Leszek Koltunski
    if( MeshBase.getUseCenters() ) mainVertHeader += "#define COMP_CENTERS\n";
133 36d65d88 Leszek Koltunski
134 a13dde77 Leszek Koltunski
    String enabledEffectV= VertexEffect.getGLSL();
135
136
    try
137
      {
138
      mPreProgram = new DistortedProgram(mainVertStream, mainFragStream, mainVertHeader, mainFragHeader,
139 b7074bc6 Leszek Koltunski
                                         enabledEffectV, null, GLSL, null);
140 a13dde77 Leszek Koltunski
      }
141
    catch(Exception e)
142
      {
143
      Log.e("POSTPROCESS", e.getClass().getSimpleName()+" trying to compile PRE program: "+e.getMessage());
144
      throw new RuntimeException(e.getMessage());
145
      }
146
147 0bd9f644 Leszek Koltunski
    mPreProgramH = mPreProgram.getProgramHandle();
148 9f9924f8 Leszek Koltunski
    EffectQueue.getUniforms( mPreProgramH,2 );
149
    MeshBase.getUniforms( mPreProgramH,2 );
150 0bd9f644 Leszek Koltunski
    mPreColorH  = GLES30.glGetUniformLocation( mPreProgramH, "u_Color"  );
151
    mPreTextureH= GLES30.glGetUniformLocation( mPreProgramH, "u_Texture");
152 86d322b5 Leszek Koltunski
    }
153
154 7266d8ef Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
155 2386a081 Leszek Koltunski
// TODO  (now only really works in case of 1 effect!)
156 7266d8ef Leszek Koltunski
157 809dcae3 Leszek Koltunski
  public int getQuality()
158 7266d8ef Leszek Koltunski
    {
159 9e771d06 Leszek Koltunski
    return mNumEffects>0 ? ((PostprocessEffect)mEffects[0]).getQuality() : 0;
160 7266d8ef Leszek Koltunski
    }
161
162 2386a081 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
163 a13dde77 Leszek Koltunski
// TODO  (now only really works in case of 1 effect!)
164 2386a081 Leszek Koltunski
165 809dcae3 Leszek Koltunski
  public boolean getRender()
166 a13dde77 Leszek Koltunski
    {
167 36d65d88 Leszek Koltunski
    return mNumEffects > 0 && ((PostprocessEffect) mEffects[0]).getRender();
168 a13dde77 Leszek Koltunski
    }
169
170
///////////////////////////////////////////////////////////////////////////////////////////////////
171
172 7602a827 Leszek Koltunski
  public int preprocess(InternalOutputSurface buffer, DistortedNode node, float distance, float mipmap, float[] projection)
173 2386a081 Leszek Koltunski
    {
174 4bb94a7d Leszek Koltunski
    MeshBase mesh = node.getMesh();
175
    DistortedEffects effects = node.getEffects();
176 2386a081 Leszek Koltunski
177 4bb94a7d Leszek Koltunski
    int width   = buffer.getWidth();
178
    int height  = buffer.getHeight();
179 809dcae3 Leszek Koltunski
180 4bb94a7d Leszek Koltunski
    InternalRenderState.setUpStencilMark(mA!=0.0f);
181
    InternalRenderState.disableBlending();
182 a13dde77 Leszek Koltunski
183 b7074bc6 Leszek Koltunski
    GLES30.glViewport(0, 0, width, height );
184 a13dde77 Leszek Koltunski
185 4bb94a7d Leszek Koltunski
    mPreProgram.useProgram();
186 a13dde77 Leszek Koltunski
187 4bb94a7d Leszek Koltunski
    mesh.bindVertexAttribs(mPreProgram);
188 9f9924f8 Leszek Koltunski
    mesh.send(mPreProgramH,2);
189 a13dde77 Leszek Koltunski
190 4bb94a7d Leszek Koltunski
    EffectQueue[] queues = effects.getQueues();
191
    EffectQueueMatrix matrix = (EffectQueueMatrix)queues[0];
192
    EffectQueueVertex vertex = (EffectQueueVertex)queues[1];
193 84d51487 Leszek Koltunski
194 62c869ad Leszek Koltunski
    matrix.send(distance, mipmap, projection, 2);
195 78ff6ea9 Leszek Koltunski
    vertex.send(mHalo*0.01f,mPreProgramH,2);
196 247d8225 Leszek Koltunski
197 4bb94a7d Leszek Koltunski
    if( mA!=0.0f )
198
      {
199 b7074bc6 Leszek Koltunski
      GLES30.glUniform4f(mPreColorH, mR, mG, mB, mA);
200
      GLES30.glUniform1i(mPreTextureH, 0);
201 4bb94a7d Leszek Koltunski
      }
202 247d8225 Leszek Koltunski
203 b7074bc6 Leszek Koltunski
    GLES30.glDrawArrays(GLES30.GL_TRIANGLE_STRIP, 0, mesh.getNumVertices() );
204 a13dde77 Leszek Koltunski
205 4bb94a7d Leszek Koltunski
    InternalRenderState.restoreBlending();
206
    InternalRenderState.unsetUpStencilMark();
207 a13dde77 Leszek Koltunski
208 4bb94a7d Leszek Koltunski
    return 1;
209 2386a081 Leszek Koltunski
    }
210
211 4b9fe2e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
212 cf7394cc leszek
213 809dcae3 Leszek Koltunski
  public int postprocess(DistortedFramebuffer buffer)
214 4b9fe2e9 Leszek Koltunski
    {
215 bed13bea leszek
    int numRenders = 0;
216 de77a6c5 Leszek Koltunski
    float[] array = mUBF.getBackingArray();
217 bed13bea leszek
218 b7074bc6 Leszek Koltunski
    GLES30.glDisable(GLES30.GL_BLEND);
219 8dccc3c2 Leszek Koltunski
220 1149be8f leszek
    for(int i=0; i<mNumEffects; i++)
221 95c441a2 leszek
      {
222 de77a6c5 Leszek Koltunski
      numRenders += ((PostprocessEffect)mEffects[i]).apply(array,NUM_FLOAT_UNIFORMS*i, buffer);
223 95c441a2 leszek
      }
224 4b9fe2e9 Leszek Koltunski
225 b7074bc6 Leszek Koltunski
    GLES30.glEnable(GLES30.GL_BLEND);
226 8dccc3c2 Leszek Koltunski
227 bed13bea leszek
    return numRenders;
228 cf7394cc leszek
    }
229 4c1dd6e9 Leszek Koltunski
  }