Project

General

Profile

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

library / src / main / java / org / distorted / library / main / EffectQueuePostprocess.java @ 466450b5

1 4c1dd6e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2016 Leszek Koltunski                                                               //
3
//                                                                                               //
4
// This file is part of Distorted.                                                               //
5
//                                                                                               //
6
// Distorted is free software: you can redistribute it and/or modify                             //
7
// 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
// Distorted is distributed in the hope that it will be useful,                                  //
12
// 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
// along with Distorted.  If not, see <http://www.gnu.org/licenses/>.                            //
18
///////////////////////////////////////////////////////////////////////////////////////////////////
19
20 fe82a979 Leszek Koltunski
package org.distorted.library.main;
21 4c1dd6e9 Leszek Koltunski
22 a13dde77 Leszek Koltunski
import android.content.res.Resources;
23 8dccc3c2 Leszek Koltunski
import android.opengl.GLES31;
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 4c1dd6e9 Leszek Koltunski
import org.distorted.library.message.EffectMessage;
31 a13dde77 Leszek Koltunski
import org.distorted.library.program.DistortedProgram;
32
33
import java.io.InputStream;
34 8fa96e69 Leszek Koltunski
35 4c1dd6e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
36
37
class EffectQueuePostprocess extends EffectQueue
38
  {
39 15aa7d94 Leszek Koltunski
  private static final int NUM_UNIFORMS = PostprocessEffect.NUM_UNIFORMS;
40 da9b3f07 Leszek Koltunski
  private static final int INDEX = EffectType.POSTPROCESS.ordinal();
41 4c1dd6e9 Leszek Koltunski
42 fff1110e leszek
  private int mHalo;
43 9e771d06 Leszek Koltunski
  private float mR, mG, mB, mA;
44 a31dbc5c Leszek Koltunski
45 247d8225 Leszek Koltunski
  private static DistortedProgram mPreProgram;
46
  private static int mPreColorH;
47 9e771d06 Leszek Koltunski
  private static int mPreTextureH;
48 a13dde77 Leszek Koltunski
49 4c1dd6e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
50
51
  EffectQueuePostprocess(long id)
52
    { 
53 15aa7d94 Leszek Koltunski
    super(id,NUM_UNIFORMS,INDEX );
54 4c1dd6e9 Leszek Koltunski
    }
55
56 c90b9e01 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
57
58 1149be8f leszek
  void compute(long currTime)
59 4c1dd6e9 Leszek Koltunski
    {
60 15aa7d94 Leszek Koltunski
    if( currTime==mTime ) return;
61 4c1dd6e9 Leszek Koltunski
    if( mTime==0 ) mTime = currTime;
62
    long step = (currTime-mTime);
63 e02264ff leszek
64 9e771d06 Leszek Koltunski
    mR = mG = mB = mA = 0.0f;
65 fff1110e leszek
    mHalo = 0;
66
    int halo;
67
68 4c1dd6e9 Leszek Koltunski
    for(int i=0; i<mNumEffects; i++)
69
      {
70 3a70bd6d leszek
      mCurrentDuration[i] += step;
71
72 15aa7d94 Leszek Koltunski
      if( mEffects[i].compute(mUniforms, NUM_UNIFORMS*i, mCurrentDuration[i], step) )
73 4c1dd6e9 Leszek Koltunski
        {
74
        for(int j=0; j<mNumListeners; j++)
75 26a4e5f6 leszek
          EffectMessageSender.newMessage( mListeners.get(j), EffectMessage.EFFECT_FINISHED, mEffects[i].getID(), mDistortedEffectsID);
76 4c1dd6e9 Leszek Koltunski
77 da9b3f07 Leszek Koltunski
        if( mEffects[i].isUnity( mUniforms, NUM_UNIFORMS*i) )
78 4c1dd6e9 Leszek Koltunski
          {
79 15aa7d94 Leszek Koltunski
          remove(i--);
80 6b0b4f60 leszek
          mNumEffectsToBe--;
81 1149be8f leszek
          regenerateIDandSort();
82 4c1dd6e9 Leszek Koltunski
          continue;
83
          }
84
        }
85 a31dbc5c Leszek Koltunski
86 fff1110e leszek
      halo = (int)mUniforms[NUM_UNIFORMS*i];
87
      if( halo>mHalo ) mHalo = halo;
88 4c1dd6e9 Leszek Koltunski
      }
89 e02264ff leszek
90 9e771d06 Leszek Koltunski
    // TODO  (now only really works in case of 1 effect!)
91
    if( mNumEffects>0 )
92
      {
93
      mR = mUniforms[1];
94
      mG = mUniforms[2];
95
      mB = mUniforms[3];
96
      mA = mUniforms[4];
97
      }
98
99 95c441a2 leszek
    mTime = currTime;
100 4c1dd6e9 Leszek Koltunski
    }
101
102 984dc935 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
103 247d8225 Leszek Koltunski
104
  static void createPrograms(Resources resources)
105 a13dde77 Leszek Koltunski
    {
106
    final InputStream mainVertStream = resources.openRawResource(R.raw.main_vertex_shader);
107
    final InputStream mainFragStream = resources.openRawResource(R.raw.preprocess_fragment_shader);
108
109
    int numV = VertexEffect.getNumEnabled();
110
111
    String mainVertHeader= Distorted.GLSL_VERSION + ("#define NUM_VERTEX "   + ( numV>0 ? DistortedEffects.getMax(EffectType.VERTEX  ) : 0 ) + "\n");
112
    String mainFragHeader= Distorted.GLSL_VERSION + "\n";
113
114
    String enabledEffectV= VertexEffect.getGLSL();
115
116
    try
117
      {
118
      mPreProgram = new DistortedProgram(mainVertStream, mainFragStream, mainVertHeader, mainFragHeader,
119
                                         enabledEffectV, null, Distorted.GLSL, null);
120
      }
121
    catch(Exception e)
122
      {
123
      Log.e("POSTPROCESS", e.getClass().getSimpleName()+" trying to compile PRE program: "+e.getMessage());
124
      throw new RuntimeException(e.getMessage());
125
      }
126
127
    int preProgramH = mPreProgram.getProgramHandle();
128
    EffectQueueVertex.getUniforms( preProgramH,2 );
129
    EffectQueueMatrix.getUniforms( preProgramH,2 );
130 9e771d06 Leszek Koltunski
    mPreColorH  = GLES31.glGetUniformLocation( preProgramH, "u_Color"  );
131
    mPreTextureH= GLES31.glGetUniformLocation( preProgramH, "u_Texture");
132 86d322b5 Leszek Koltunski
    }
133
134 7266d8ef Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
135 2386a081 Leszek Koltunski
// TODO  (now only really works in case of 1 effect!)
136 7266d8ef Leszek Koltunski
137 9e771d06 Leszek Koltunski
  int getQuality()
138 7266d8ef Leszek Koltunski
    {
139 9e771d06 Leszek Koltunski
    return mNumEffects>0 ? ((PostprocessEffect)mEffects[0]).getQuality() : 0;
140 7266d8ef Leszek Koltunski
    }
141
142 2386a081 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
143 a13dde77 Leszek Koltunski
// TODO  (now only really works in case of 1 effect!)
144 2386a081 Leszek Koltunski
145 9e771d06 Leszek Koltunski
  boolean getRender()
146 a13dde77 Leszek Koltunski
    {
147 9e771d06 Leszek Koltunski
    return mNumEffects>0 ? ((PostprocessEffect)mEffects[0]).getRender() : false;
148 a13dde77 Leszek Koltunski
    }
149
150
///////////////////////////////////////////////////////////////////////////////////////////////////
151
152 9e771d06 Leszek Koltunski
  int preprocess(DistortedOutputSurface buffer, DistortedNode node)
153 2386a081 Leszek Koltunski
    {
154 9e771d06 Leszek Koltunski
    buffer.setAsOutput();
155 a13dde77 Leszek Koltunski
    DistortedSurface input = node.getInternalSurface();
156 2386a081 Leszek Koltunski
157 a13dde77 Leszek Koltunski
    if( input.setAsInput() )
158
      {
159 247d8225 Leszek Koltunski
      MeshObject mesh = node.getMesh();
160 9e771d06 Leszek Koltunski
      float    margin = mHalo*buffer.mMipmap;
161 2386a081 Leszek Koltunski
162 a13dde77 Leszek Koltunski
      float halfW = input.getWidth() / 2.0f;
163
      float halfH = input.getHeight()/ 2.0f;
164
      float halfZ = halfW*mesh.zFactor;
165 2386a081 Leszek Koltunski
166 9e771d06 Leszek Koltunski
      DistortedRenderState.setUpStencilMark(mA!=0.0f);
167 a13dde77 Leszek Koltunski
168 9e771d06 Leszek Koltunski
      GLES31.glViewport(0, 0, buffer.mWidth, buffer.mHeight );
169 a13dde77 Leszek Koltunski
170
      mPreProgram.useProgram();
171
172 466450b5 Leszek Koltunski
      GLES31.glBindBuffer(GLES31.GL_ARRAY_BUFFER, mesh.getVBO() );
173 a13dde77 Leszek Koltunski
      GLES31.glVertexAttribPointer(mPreProgram.mAttribute[0], MeshObject.POS_DATA_SIZE, GLES31.GL_FLOAT, false, MeshObject.VERTSIZE, MeshObject.OFFSET0);
174
      GLES31.glVertexAttribPointer(mPreProgram.mAttribute[1], MeshObject.NOR_DATA_SIZE, GLES31.GL_FLOAT, false, MeshObject.VERTSIZE, MeshObject.OFFSET1);
175
      GLES31.glVertexAttribPointer(mPreProgram.mAttribute[2], MeshObject.TEX_DATA_SIZE, GLES31.GL_FLOAT, false, MeshObject.VERTSIZE, MeshObject.OFFSET2);
176
      GLES31.glBindBuffer(GLES31.GL_ARRAY_BUFFER, 0);
177
178 9e771d06 Leszek Koltunski
      node.getEffects().send(halfW, halfH, halfZ, margin, buffer, 2);
179 247d8225 Leszek Koltunski
180 9e771d06 Leszek Koltunski
      if( mA!=0.0f )
181 247d8225 Leszek Koltunski
        {
182 9e771d06 Leszek Koltunski
        GLES31.glUniform4f(mPreColorH, mR, mG, mB, mA);
183
        GLES31.glUniform1i(mPreTextureH, 0);
184 247d8225 Leszek Koltunski
        }
185
186 a13dde77 Leszek Koltunski
      GLES31.glDrawArrays(GLES31.GL_TRIANGLE_STRIP, 0, mesh.numVertices);
187
188
      DistortedRenderState.unsetUpStencilMark();
189
190
      return 1;
191
      }
192
    return 0;
193 2386a081 Leszek Koltunski
    }
194
195 4b9fe2e9 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
196 cf7394cc leszek
197 9e771d06 Leszek Koltunski
  int postprocess(DistortedFramebuffer buffer)
198 4b9fe2e9 Leszek Koltunski
    {
199 bed13bea leszek
    int numRenders = 0;
200
201 8dccc3c2 Leszek Koltunski
    GLES31.glDisable(GLES31.GL_BLEND);
202
203 1149be8f leszek
    for(int i=0; i<mNumEffects; i++)
204 95c441a2 leszek
      {
205 9e771d06 Leszek Koltunski
      numRenders += ((PostprocessEffect)mEffects[i]).apply(mUniforms,NUM_UNIFORMS*i, buffer);
206 95c441a2 leszek
      }
207 4b9fe2e9 Leszek Koltunski
208 8dccc3c2 Leszek Koltunski
    GLES31.glEnable(GLES31.GL_BLEND);
209
210 bed13bea leszek
    return numRenders;
211 cf7394cc leszek
    }
212 4c1dd6e9 Leszek Koltunski
  }