Project

General

Profile

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

library / src / main / java / org / distorted / library / EffectQueueFragment.java @ 50642a86

1
///////////////////////////////////////////////////////////////////////////////////////////////////
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
package org.distorted.library;
21

    
22
import android.opengl.GLES30;
23

    
24
import org.distorted.library.message.EffectMessage;
25
import org.distorted.library.type.Data1D;
26
import org.distorted.library.type.Data3D;
27
import org.distorted.library.type.Data4D;
28
import org.distorted.library.type.Dynamic1D;
29
import org.distorted.library.type.Dynamic3D;
30
import org.distorted.library.type.Dynamic4D;
31
import org.distorted.library.type.Static1D;
32
import org.distorted.library.type.Static3D;
33
import org.distorted.library.type.Static4D;
34

    
35
///////////////////////////////////////////////////////////////////////////////////////////////////
36

    
37
class EffectQueueFragment extends EffectQueue
38
  {
39
  private static final int NUM_UNIFORMS = 8;
40
  private static final int NUM_CACHE    = 4;
41
  private static final int INDEX = EffectTypes.FRAGMENT.ordinal();
42
  private static int mNumEffectsH;
43
  private static int mTypeH;
44
  private static int mUniformsH;
45
  
46
///////////////////////////////////////////////////////////////////////////////////////////////////
47
   
48
  EffectQueueFragment(long id)
49
    { 
50
    super(id,NUM_UNIFORMS,NUM_CACHE,INDEX);
51
    }
52

    
53
///////////////////////////////////////////////////////////////////////////////////////////////////
54

    
55
  static void getUniforms(int mProgramH)
56
    {
57
    mNumEffectsH= GLES30.glGetUniformLocation( mProgramH, "fNumEffects");
58
    mTypeH      = GLES30.glGetUniformLocation( mProgramH, "fType");
59
    mUniformsH  = GLES30.glGetUniformLocation( mProgramH, "fUniforms");
60
    }
61

    
62
///////////////////////////////////////////////////////////////////////////////////////////////////
63
  
64
  synchronized void compute(long currTime) 
65
    { 
66
    if( currTime==mTime ) return;
67
    if( mTime==0 ) mTime = currTime;
68
    long step = (currTime-mTime);
69
   
70
    for(int i=0; i<mNumEffects; i++)
71
      {
72
      mCurrentDuration[i] += step;
73

    
74
      if( mInter[0][i]!=null && mInter[0][i].interpolateMain(mUniforms ,NUM_UNIFORMS*i, mCurrentDuration[i], step) )
75
        {
76
        for(int j=0; j<mNumListeners; j++)   
77
          EffectMessageSender.newMessage( mListeners.elementAt(j),
78
                                          EffectMessage.EFFECT_FINISHED,
79
                                          (mID[i]<<EffectTypes.LENGTH)+EffectTypes.FRAGMENT.type,
80
                                          mName[i],
81
                                          mObjectID);
82
      
83
        if( EffectNames.isUnity(mName[i], mUniforms, NUM_UNIFORMS*i) )
84
          {
85
          remove(i);
86
          i--;
87
          continue;
88
          }
89
        else mInter[0][i] = null;
90
        }
91

    
92
      if( mInter[1][i]!=null ) mInter[1][i].interpolateMain( mCache   , NUM_CACHE*i     , mCurrentDuration[i], step);
93
      if( mInter[2][i]!=null ) mInter[2][i].interpolateMain( mUniforms, NUM_UNIFORMS*i+1, mCurrentDuration[i], step);
94
      }
95
   
96
    mTime = currTime;  
97
    }
98

    
99
///////////////////////////////////////////////////////////////////////////////////////////////////
100

    
101
  protected void moveEffect(int index)
102
    {
103
    mUniforms[NUM_UNIFORMS*index  ] = mUniforms[NUM_UNIFORMS*(index+1)  ];
104
    mUniforms[NUM_UNIFORMS*index+1] = mUniforms[NUM_UNIFORMS*(index+1)+1];
105
    mUniforms[NUM_UNIFORMS*index+2] = mUniforms[NUM_UNIFORMS*(index+1)+2];
106
    mUniforms[NUM_UNIFORMS*index+3] = mUniforms[NUM_UNIFORMS*(index+1)+3];
107

    
108
    mCache[NUM_CACHE*index  ] = mCache[NUM_CACHE*(index+1)  ];
109
    mCache[NUM_CACHE*index+1] = mCache[NUM_CACHE*(index+1)+1];
110
    mCache[NUM_CACHE*index+2] = mCache[NUM_CACHE*(index+1)+2];
111
    mCache[NUM_CACHE*index+3] = mCache[NUM_CACHE*(index+1)+3];
112
    }
113
  
114
///////////////////////////////////////////////////////////////////////////////////////////////////
115
  
116
  synchronized void send(float halfX, float halfY)
117
    {
118
    GLES30.glUniform1i( mNumEffectsH, mNumEffects);
119

    
120
    if( mNumEffects>0 )
121
      {
122
      for(int i=0; i<mNumEffects; i++)
123
        {
124
        mUniforms[NUM_UNIFORMS*i+4] = mCache[NUM_CACHE*i  ]-halfX;
125
        mUniforms[NUM_UNIFORMS*i+5] =-mCache[NUM_CACHE*i+1]+halfY;
126
        mUniforms[NUM_UNIFORMS*i+6] = mCache[NUM_CACHE*i+2];
127
        mUniforms[NUM_UNIFORMS*i+7] = mCache[NUM_CACHE*i+3];
128
        }
129

    
130
      GLES30.glUniform1iv( mTypeH    ,                 mNumEffects, mName    ,0);
131
      GLES30.glUniform4fv( mUniformsH,(NUM_UNIFORMS/4)*mNumEffects, mUniforms,0);
132
      }  
133
    }
134

    
135
///////////////////////////////////////////////////////////////////////////////////////////////////
136
// alpha, brightness, contrast, saturation
137

    
138
  synchronized long add(EffectNames eln, Data1D data)
139
    {
140
    if( mMax[INDEX]>mNumEffects )
141
      {
142
      EffectNames.fillWithUnities(eln.ordinal(), mUniforms, NUM_UNIFORMS*mNumEffects); 
143

    
144
      if( data instanceof Dynamic1D)
145
        {
146
        mInter[0][mNumEffects] = (Dynamic1D)data;
147
        }
148
      else if( data instanceof Static1D )
149
        {
150
        mInter[0][mNumEffects] = null;
151
        mUniforms[NUM_UNIFORMS*mNumEffects] = ((Static1D)data).getX();
152
        }
153
      else return -1;
154

    
155
      mInter[1][mNumEffects] = null;
156
      mCache[NUM_CACHE*mNumEffects+2] = Float.MAX_VALUE;
157
      mCache[NUM_CACHE*mNumEffects+3] = Float.MAX_VALUE;
158

    
159
      mInter[2][mNumEffects] = null;
160

    
161
      return addBase(eln); 
162
      }
163
      
164
    return -1;
165
    }
166
  
167
///////////////////////////////////////////////////////////////////////////////////////////////////
168
// alpha, brightness, contrast, saturation
169

    
170
  synchronized long add(EffectNames eln, Data1D data, Data4D region)
171
    {
172
    if( mMax[INDEX]>mNumEffects )
173
      {
174
      EffectNames.fillWithUnities(eln.ordinal(), mUniforms, NUM_UNIFORMS*mNumEffects);
175

    
176
      if( data instanceof Dynamic1D)
177
        {
178
        mInter[0][mNumEffects] = (Dynamic1D)data;
179
        }
180
      else if( data instanceof Static1D )
181
        {
182
        mInter[0][mNumEffects] = null;
183
        mUniforms[NUM_UNIFORMS*mNumEffects] = ((Static1D)data).getX();
184
        }
185
      else return -1;
186

    
187
      if( region instanceof Dynamic4D)
188
        {
189
        mInter[1][mNumEffects] = (Dynamic4D)region;
190
        }
191
      else if( region instanceof Static4D )
192
        {
193
        mInter[1][mNumEffects]  = null;
194
        mCache[NUM_CACHE*mNumEffects  ] = ((Static4D)region).getX();
195
        mCache[NUM_CACHE*mNumEffects+1] = ((Static4D)region).getY();
196
        mCache[NUM_CACHE*mNumEffects+2] = ((Static4D)region).getZ();
197
        mCache[NUM_CACHE*mNumEffects+3] = ((Static4D)region).getW();
198
        }
199
      else return -1;
200

    
201
      mInter[2][mNumEffects] = null;
202

    
203
      return addBase(eln);
204
      }
205
      
206
    return -1;
207
    }
208
  
209
///////////////////////////////////////////////////////////////////////////////////////////////////
210
// chroma
211

    
212
  synchronized long add(EffectNames eln, Data1D level, Data3D color, Data4D region)
213
    {
214
    if( mMax[INDEX]>mNumEffects )
215
      {
216
      EffectNames.fillWithUnities(eln.ordinal(), mUniforms, NUM_UNIFORMS*mNumEffects);
217

    
218
      if( level instanceof Dynamic1D)
219
        {
220
        mInter[0][mNumEffects] = (Dynamic1D)level;
221
        }
222
      else if( level instanceof Static1D )
223
        {
224
        mInter[0][mNumEffects] = null;
225
        mUniforms[NUM_UNIFORMS*mNumEffects] = ((Static1D)level).getX();
226
        }
227
      else return -1;
228

    
229
      if( color instanceof Dynamic3D)
230
        {
231
        mInter[2][mNumEffects] = (Dynamic3D)color;
232
        }
233
      else if( color instanceof Static3D )
234
        {
235
        mInter[2][mNumEffects] = null;
236
        mUniforms[NUM_UNIFORMS*mNumEffects+1] = ((Static3D)color).getX();
237
        mUniforms[NUM_UNIFORMS*mNumEffects+2] = ((Static3D)color).getY();
238
        mUniforms[NUM_UNIFORMS*mNumEffects+3] = ((Static3D)color).getZ();
239
        }
240
      else return -1;
241

    
242
      if( region instanceof Dynamic4D)
243
        {
244
        mInter[1][mNumEffects] = (Dynamic4D)region;
245
        }
246
      else if( region instanceof Static4D )
247
        {
248
        mInter[1][mNumEffects]  = null;
249
        mCache[NUM_CACHE*mNumEffects  ] = ((Static4D)region).getX();
250
        mCache[NUM_CACHE*mNumEffects+1] = ((Static4D)region).getY();
251
        mCache[NUM_CACHE*mNumEffects+2] = ((Static4D)region).getZ();
252
        mCache[NUM_CACHE*mNumEffects+3] = ((Static4D)region).getW();
253
        }
254
      else return -1;
255

    
256
      return addBase(eln); 
257
      }
258
      
259
    return -1;
260
    }
261
  
262
///////////////////////////////////////////////////////////////////////////////////////////////////
263
// chroma
264

    
265
  synchronized long add(EffectNames eln, Data1D level, Data3D color)
266
    {
267
    if( mMax[INDEX]>mNumEffects )
268
      {
269
      EffectNames.fillWithUnities(eln.ordinal(), mUniforms, NUM_UNIFORMS*mNumEffects);
270

    
271
      if( level instanceof Dynamic1D)
272
        {
273
        mInter[0][mNumEffects] = (Dynamic1D)level;
274
        }
275
      else if( level instanceof Static1D )
276
        {
277
        mInter[0][mNumEffects] = null;
278
        mUniforms[NUM_UNIFORMS*mNumEffects] = ((Static1D)level).getX();
279
        }
280
      else return -1;
281

    
282
      if( color instanceof Dynamic3D)
283
        {
284
        mInter[2][mNumEffects] = (Dynamic3D)color;
285
        }
286
      else if( color instanceof Static3D )
287
        {
288
        mInter[2][mNumEffects] = null;
289
        mUniforms[NUM_UNIFORMS*mNumEffects+1] = ((Static3D)color).getX();
290
        mUniforms[NUM_UNIFORMS*mNumEffects+2] = ((Static3D)color).getY();
291
        mUniforms[NUM_UNIFORMS*mNumEffects+3] = ((Static3D)color).getZ();
292
        }
293
      else return -1;
294

    
295
      mInter[1][mNumEffects]  = null;
296
      mCache[NUM_CACHE*mNumEffects+2] = Float.MAX_VALUE;
297
      mCache[NUM_CACHE*mNumEffects+3] = Float.MAX_VALUE;
298

    
299
      return addBase(eln);
300
      }
301
       
302
    return -1;
303
    }
304

    
305
///////////////////////////////////////////////////////////////////////////////////////////////////
306
// end of FragmentEffect   
307
  }
(16-16/23)