Project

General

Profile

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

library / src / main / java / org / distorted / library / EffectQueueFragment.java @ 77fcb24d

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.GLES20;
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 INDEX = EffectTypes.FRAGMENT.ordinal();
41
  private static int mNumEffectsH;
42
  private static int mTypeH;
43
  private static int mUniformsH;
44
  
45
///////////////////////////////////////////////////////////////////////////////////////////////////
46
   
47
  public EffectQueueFragment(DistortedObject obj)
48
    { 
49
    super(obj,NUM_UNIFORMS,INDEX);
50
    }
51

    
52
///////////////////////////////////////////////////////////////////////////////////////////////////
53

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

    
61
///////////////////////////////////////////////////////////////////////////////////////////////////
62
  
63
  synchronized void compute(long currTime) 
64
    { 
65
    if( currTime==mTime ) return;
66
    if( mTime==0 ) mTime = currTime;
67
    long step = (currTime-mTime);
68
   
69
    for(int i=0; i<mNumEffects; i++)
70
      {
71
      if( mInter[0][i]!=null && mInter[0][i].interpolateMain(mUniforms ,NUM_UNIFORMS*i, mCurrentDuration[i], step) )
72
        {
73
        for(int j=0; j<mNumListeners; j++)   
74
          EffectMessageSender.newMessage( mListeners.elementAt(j),
75
                                          EffectMessage.EFFECT_FINISHED,
76
                                          (mID[i]<<EffectTypes.LENGTH)+EffectTypes.FRAGMENT.type,
77
                                          mName[i],
78
                                          mBitmapID,
79
                                          null);
80
      
81
        if( EffectNames.isUnity(mName[i], mUniforms, NUM_UNIFORMS*i) )
82
          {
83
          remove(i);
84
          i--;
85
          continue;
86
          }
87
        else mInter[0][i] = null;
88
        }
89

    
90
      if( mInter[1][i]!=null )
91
        {
92
        mInter[1][i].interpolateMain( mUniforms, NUM_UNIFORMS*i+4, mCurrentDuration[i]);
93

    
94
        mUniforms[NUM_UNIFORMS*i+4] = mUniforms[NUM_UNIFORMS*i+4]-mObjHalfX;
95
        mUniforms[NUM_UNIFORMS*i+5] =-mUniforms[NUM_UNIFORMS*i+5]+mObjHalfY;
96
        }
97

    
98
      if( mInter[2][i]!=null ) mInter[2][i].interpolateMain(mUniforms, NUM_UNIFORMS*i+1, mCurrentDuration[i]);
99

    
100
      mCurrentDuration[i] += step;
101
      }
102
   
103
    mTime = currTime;  
104
    }
105

    
106
///////////////////////////////////////////////////////////////////////////////////////////////////
107

    
108
  protected void moveEffect(int index)
109
    {
110
    mUniforms[NUM_UNIFORMS*index  ] = mUniforms[NUM_UNIFORMS*(index+1)  ];
111
    mUniforms[NUM_UNIFORMS*index+1] = mUniforms[NUM_UNIFORMS*(index+1)+1];
112
    mUniforms[NUM_UNIFORMS*index+2] = mUniforms[NUM_UNIFORMS*(index+1)+2];
113
    mUniforms[NUM_UNIFORMS*index+3] = mUniforms[NUM_UNIFORMS*(index+1)+3];
114

    
115
    if( mInter[1][index]==null )
116
      {
117
      mUniforms[NUM_UNIFORMS*index+4] = mUniforms[NUM_UNIFORMS*(index+1)+4];
118
      mUniforms[NUM_UNIFORMS*index+5] = mUniforms[NUM_UNIFORMS*(index+1)+5];
119
      mUniforms[NUM_UNIFORMS*index+6] = mUniforms[NUM_UNIFORMS*(index+1)+6];
120
      mUniforms[NUM_UNIFORMS*index+7] = mUniforms[NUM_UNIFORMS*(index+1)+7];
121
      }
122
    }
123
  
124
///////////////////////////////////////////////////////////////////////////////////////////////////
125
  
126
  synchronized void send() 
127
    {
128
    GLES20.glUniform1i( mNumEffectsH, mNumEffects);
129
      
130
    if( mNumEffects>0 )
131
      {     
132
      GLES20.glUniform1iv( mTypeH    ,  mNumEffects, mName    ,0);
133
      GLES20.glUniform4fv( mUniformsH,2*mNumEffects, mUniforms,0);
134
      }  
135
    }
136

    
137
///////////////////////////////////////////////////////////////////////////////////////////////////
138

    
139
  synchronized void sendZero() 
140
    {
141
    GLES20.glUniform1i( mNumEffectsH, 0);
142
    }
143

    
144
///////////////////////////////////////////////////////////////////////////////////////////////////
145
// alpha, brightness, contrast, saturation
146

    
147
  synchronized long add(EffectNames eln, Data1D data)
148
    {
149
    if( mMax[INDEX]>mNumEffects )
150
      {
151
      EffectNames.fillWithUnities(eln.ordinal(), mUniforms, NUM_UNIFORMS*mNumEffects); 
152

    
153
      if( data instanceof Dynamic1D)
154
        mInter[0][mNumEffects] = (Dynamic1D)data;
155
      else if( data instanceof Static1D )
156
        {
157
        mInter[0][mNumEffects] = null;
158
        mUniforms[NUM_UNIFORMS*mNumEffects] = ((Static1D)data).getX();
159
        }
160
      else return -1;
161

    
162
      mInter[1][mNumEffects] = null;
163
      mUniforms[NUM_UNIFORMS*mNumEffects+6] = 1000*mObjHalfX;
164
      mUniforms[NUM_UNIFORMS*mNumEffects+7] = 1000*mObjHalfY;
165

    
166
      mInter[2][mNumEffects] = null;
167

    
168
      return addBase(eln); 
169
      }
170
      
171
    return -1;
172
    }
173
  
174
///////////////////////////////////////////////////////////////////////////////////////////////////
175
// alpha, brightness, contrast, saturation
176

    
177
  synchronized long add(EffectNames eln, Data1D data, Data4D region)
178
    {
179
    if( mMax[INDEX]>mNumEffects )
180
      {
181
      EffectNames.fillWithUnities(eln.ordinal(), mUniforms, NUM_UNIFORMS*mNumEffects);
182

    
183
      if( data instanceof Dynamic1D)
184
        mInter[0][mNumEffects] = (Dynamic1D)data;
185
      else if( data instanceof Static1D )
186
        {
187
        mInter[0][mNumEffects] = null;
188
        mUniforms[NUM_UNIFORMS*mNumEffects] = ((Static1D)data).getX();
189
        }
190
      else return -1;
191

    
192
      if( region instanceof Dynamic4D)
193
        mInter[1][mNumEffects] = (Dynamic4D)region;
194
      else if( region instanceof Static4D )
195
        {
196
        mInter[1][mNumEffects]  = null;
197
        mUniforms[NUM_UNIFORMS*mNumEffects+4] = ((Static4D)region).getX()-mObjHalfX;
198
        mUniforms[NUM_UNIFORMS*mNumEffects+5] =-((Static4D)region).getY()+mObjHalfY;
199
        mUniforms[NUM_UNIFORMS*mNumEffects+6] = ((Static4D)region).getZ();
200
        mUniforms[NUM_UNIFORMS*mNumEffects+7] = ((Static4D)region).getW();
201
        }
202
      else return -1;
203

    
204
      mInter[2][mNumEffects] = null;
205

    
206
      return addBase(eln);
207
      }
208
      
209
    return -1;
210
    }
211
  
212
///////////////////////////////////////////////////////////////////////////////////////////////////
213
// chroma
214

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

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

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

    
243
      if( region instanceof Dynamic4D)
244
        mInter[1][mNumEffects] = (Dynamic4D)region;
245
      else if( region instanceof Static4D )
246
        {
247
        mInter[1][mNumEffects]  = null;
248
        mUniforms[NUM_UNIFORMS*mNumEffects+4] = ((Static4D)region).getX()-mObjHalfX;
249
        mUniforms[NUM_UNIFORMS*mNumEffects+5] =-((Static4D)region).getY()+mObjHalfY;
250
        mUniforms[NUM_UNIFORMS*mNumEffects+6] = ((Static4D)region).getZ();
251
        mUniforms[NUM_UNIFORMS*mNumEffects+7] = ((Static4D)region).getW();
252
        }
253
      else return -1;
254

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

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

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

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

    
292
      mInter[1][mNumEffects]  = null;
293
      mUniforms[NUM_UNIFORMS*mNumEffects+6] = 1000*mObjHalfX;
294
      mUniforms[NUM_UNIFORMS*mNumEffects+7] = 1000*mObjHalfY;
295

    
296
      return addBase(eln);
297
      }
298
       
299
    return -1;
300
    }
301

    
302
///////////////////////////////////////////////////////////////////////////////////////////////////
303
// end of FragmentEffect   
304
  }
(15-15/18)