Project

General

Profile

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

examples / src / main / java / org / distorted / examples / deform / DeformRenderer.java @ a39e8df4

1 bc0a685b Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2016 Leszek Koltunski                                                               //
3
//                                                                                               //
4 71c8884f Leszek Koltunski
// This file is part of Distorted.                                                               //
5 bc0a685b Leszek Koltunski
//                                                                                               //
6 71c8884f Leszek Koltunski
// Distorted is free software: you can redistribute it and/or modify                             //
7 bc0a685b 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 71c8884f Leszek Koltunski
// Distorted is distributed in the hope that it will be useful,                                  //
12 bc0a685b 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 71c8884f Leszek Koltunski
// along with Distorted.  If not, see <http://www.gnu.org/licenses/>.                            //
18 bc0a685b Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
19 427ab7bf Leszek Koltunski
20 5068fa06 Leszek Koltunski
package org.distorted.examples.deform;
21 427ab7bf Leszek Koltunski
22
import javax.microedition.khronos.egl.EGLConfig;
23
import javax.microedition.khronos.opengles.GL10;
24
25 42f65cb4 Leszek Koltunski
import org.distorted.library.effect.EffectName;
26 d1abb41e Leszek Koltunski
import org.distorted.library.effect.MatrixEffectScale;
27 d57f3a14 Leszek Koltunski
import org.distorted.library.effect.MatrixEffectShear;
28
import org.distorted.library.effect.VertexEffectDeform;
29
import org.distorted.library.effect.VertexEffectDistort;
30 e3900503 Leszek Koltunski
import org.distorted.library.main.DistortedLibrary;
31 01782e85 Leszek Koltunski
import org.distorted.library.main.DistortedEffects;
32
import org.distorted.library.main.DistortedScreen;
33
import org.distorted.library.main.DistortedTexture;
34 57d7fdba Leszek Koltunski
import org.distorted.library.mesh.MeshBase;
35 f2085b96 Leszek Koltunski
import org.distorted.library.mesh.MeshSquare;
36 e8b6aa95 Leszek Koltunski
37 b62eb334 Leszek Koltunski
import org.distorted.library.message.EffectListener;
38 7589635e Leszek Koltunski
import org.distorted.library.type.Dynamic3D;
39 513b2e9c Leszek Koltunski
import org.distorted.library.type.Static1D;
40 7589635e Leszek Koltunski
import org.distorted.library.type.Static3D;
41
import org.distorted.library.type.Static4D;
42 427ab7bf Leszek Koltunski
43 dc10a48d Leszek Koltunski
import android.app.ActivityManager;
44
import android.content.Context;
45
import android.content.pm.ConfigurationInfo;
46
import android.content.res.Resources;
47 427ab7bf Leszek Koltunski
import android.graphics.Bitmap;
48
import android.graphics.Canvas;
49
import android.graphics.Paint;
50
import android.graphics.Paint.Style;
51
import android.opengl.GLSurfaceView;
52
53 dc10a48d Leszek Koltunski
import java.io.InputStream;
54
55 427ab7bf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
56
57 dc10a48d Leszek Koltunski
class DeformRenderer implements GLSurfaceView.Renderer, EffectListener, DistortedLibrary.LibraryUser
58 f6d884d5 Leszek Koltunski
   {
59 e8b6aa95 Leszek Koltunski
   private static final int NUM_VECTORS =  8;
60
   private static final int NUM_LINES   = 10;
61 42ec9110 Leszek Koltunski
   private static final float QUOT      = 0.6f;
62 427ab7bf Leszek Koltunski
63 dc10a48d Leszek Koltunski
   private final GLSurfaceView mView;
64
   private final Resources mResources;
65
   private final DistortedTexture mTexture;
66
   private final DistortedEffects mEffects;
67
   private final DistortedScreen mScreen;
68
   private final Static3D mTouchPoint, mScale;
69
   private final Static3D[] vDistort, vDeform, vShear;
70
   private final Static4D mRegion;
71
   private final MatrixEffectShear mMovingShear, mReleasedShear;
72
   private final VertexEffectDistort mMovingDistort, mReleasedDistort;
73
   private final VertexEffectDeform mMovingDeform, mReleasedDeform;
74
   private final Dynamic3D mReleasedDistortDynamic, mReleasedDeformDynamic, mReleasedShearDynamic;
75 30c71dd5 Leszek Koltunski
76 dc10a48d Leszek Koltunski
   private MeshBase mMesh;
77
   private EffectName mMode = EffectName.DISTORT;
78 d3c2d1ef leszek
   private int scrHeight, scrWidth;
79 16b22aab Leszek Koltunski
   private int textureWidth, textureHeight;
80 d3c2d1ef leszek
   private float mRadius;
81 d57f3a14 Leszek Koltunski
   private long mLastEffect = -1;
82
83 427ab7bf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
84
85 30c71dd5 Leszek Koltunski
   DeformRenderer(GLSurfaceView view)
86 427ab7bf Leszek Koltunski
      { 
87
      mView = view;
88 dc10a48d Leszek Koltunski
      mResources = view.getResources();
89 f6d884d5 Leszek Koltunski
90 d1abb41e Leszek Koltunski
      mTexture    = new DistortedTexture();
91 698ad0a8 Leszek Koltunski
      mEffects    = new DistortedEffects();
92 a4d59c0b Leszek Koltunski
      mRegion     = new Static4D(0,0,0,0);
93
      mTouchPoint = new Static3D(0,0,0);
94 d1abb41e Leszek Koltunski
      mScale      = new Static3D(1,1,1);
95
96
      mEffects.apply( new MatrixEffectScale(mScale) );
97 7589635e Leszek Koltunski
98 7abd1d00 Leszek Koltunski
      // DISTORT
99 52e8e76a Leszek Koltunski
      mReleasedDistortDynamic = new Dynamic3D(NUM_VECTORS*500, 0.5f);
100
      mReleasedDistortDynamic.setMode(Dynamic3D.MODE_PATH);
101 d57f3a14 Leszek Koltunski
      Dynamic3D movingDistortDynamic = new Dynamic3D(0,0.5f);
102
      movingDistortDynamic.setMode(Dynamic3D.MODE_PATH);
103 7589635e Leszek Koltunski
104 7abd1d00 Leszek Koltunski
      vDistort = new Static3D[NUM_VECTORS];
105 7589635e Leszek Koltunski
106 427ab7bf Leszek Koltunski
      for(int i=0; i<NUM_VECTORS; i++)
107
        {
108 7abd1d00 Leszek Koltunski
        vDistort[i] = new Static3D(0,0,0);
109 52e8e76a Leszek Koltunski
        mReleasedDistortDynamic.add(vDistort[i]);
110 427ab7bf Leszek Koltunski
        }
111 7589635e Leszek Koltunski
112 d57f3a14 Leszek Koltunski
      movingDistortDynamic.add(vDistort[0]);
113 7589635e Leszek Koltunski
114 7abd1d00 Leszek Koltunski
      // Deform
115 52e8e76a Leszek Koltunski
      mReleasedDeformDynamic = new Dynamic3D(NUM_VECTORS*500, 0.5f);
116
      mReleasedDeformDynamic.setMode(Dynamic3D.MODE_PATH);
117 d57f3a14 Leszek Koltunski
      Dynamic3D movingDeformDynamic = new Dynamic3D(0,0.5f);
118
      movingDeformDynamic.setMode(Dynamic3D.MODE_PATH);
119 7abd1d00 Leszek Koltunski
120
      vDeform = new Static3D[NUM_VECTORS];
121
122
      for(int i=0; i<NUM_VECTORS; i++)
123 427ab7bf Leszek Koltunski
        {
124 7abd1d00 Leszek Koltunski
        vDeform[i] = new Static3D(0,0,0);
125 52e8e76a Leszek Koltunski
        mReleasedDeformDynamic.add(vDeform[i]);
126 427ab7bf Leszek Koltunski
        }
127 7abd1d00 Leszek Koltunski
128 d57f3a14 Leszek Koltunski
      movingDeformDynamic.add(vDeform[0]);
129 7abd1d00 Leszek Koltunski
130
      // Shear
131 52e8e76a Leszek Koltunski
      mReleasedShearDynamic = new Dynamic3D(NUM_VECTORS*500, 0.5f);
132
      mReleasedShearDynamic.setMode(Dynamic3D.MODE_PATH);
133 d57f3a14 Leszek Koltunski
      Dynamic3D movingShearDynamic = new Dynamic3D(0,0.5f);
134
      movingShearDynamic.setMode(Dynamic3D.MODE_PATH);
135 7abd1d00 Leszek Koltunski
136
      vShear = new Static3D[NUM_VECTORS];
137
138
      for(int i=0; i<NUM_VECTORS; i++)
139
        {
140
        vShear[i] = new Static3D(0,0,0);
141 52e8e76a Leszek Koltunski
        mReleasedShearDynamic.add(vShear[i]);
142 7abd1d00 Leszek Koltunski
        }
143
144 d57f3a14 Leszek Koltunski
      movingShearDynamic.add(vShear[0]);
145 392e16fd Leszek Koltunski
146 e4330c89 Leszek Koltunski
      mScreen = new DistortedScreen();
147 e72c53e5 Leszek Koltunski
      mScreen.showFPS();
148 d57f3a14 Leszek Koltunski
149 513b2e9c Leszek Koltunski
      Static1D deformRadius = new Static1D(0.5f);
150
151 52e8e76a Leszek Koltunski
      mMovingDistort   = new VertexEffectDistort( movingDistortDynamic   ,               mTouchPoint, mRegion);
152
      mMovingDeform    = new VertexEffectDeform ( movingDeformDynamic    , deformRadius, mTouchPoint, mRegion);
153
      mMovingShear     = new MatrixEffectShear  ( movingShearDynamic     ,               mTouchPoint         );
154
      mReleasedDistort = new VertexEffectDistort( mReleasedDistortDynamic,               mTouchPoint, mRegion);
155
      mReleasedDeform  = new VertexEffectDeform ( mReleasedDeformDynamic , deformRadius, mTouchPoint, mRegion);
156
      mReleasedShear   = new MatrixEffectShear  ( mReleasedShearDynamic  ,               mTouchPoint         );
157 427ab7bf Leszek Koltunski
      }
158
159
///////////////////////////////////////////////////////////////////////////////////////////////////
160
161 42f65cb4 Leszek Koltunski
   void setMode(EffectName mode)
162 427ab7bf Leszek Koltunski
      {
163
      mMode = mode;  
164
      }
165
   
166
///////////////////////////////////////////////////////////////////////////////////////////////////
167
168 30c71dd5 Leszek Koltunski
   void setRegionRadius(int r)
169 427ab7bf Leszek Koltunski
      {
170 d1abb41e Leszek Koltunski
      mRadius = ( r==100 ? 100.0f : r/100.0f);
171
      mRegion.set3(mRadius);
172 427ab7bf Leszek Koltunski
      }
173
174 b62eb334 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
175
// keep aborting the 'released' effects, otherwise we are quickly going to run out of room in
176
// effect queues.
177
178 8d5a8e06 Leszek Koltunski
   public void effectFinished(final long effectID)
179 b62eb334 Leszek Koltunski
     {
180 8d5a8e06 Leszek Koltunski
     mEffects.abortById(effectID);
181 b62eb334 Leszek Koltunski
     }
182
183 427ab7bf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
184 386fd702 Leszek Koltunski
185 f6d884d5 Leszek Koltunski
   public void onDrawFrame(GL10 glUnused)
186
     {
187 24ab1cf8 leszek
     mScreen.render(System.currentTimeMillis());
188 f6d884d5 Leszek Koltunski
     }
189 427ab7bf Leszek Koltunski
190
///////////////////////////////////////////////////////////////////////////////////////////////////
191
    
192 f6d884d5 Leszek Koltunski
   public void onSurfaceChanged(GL10 glUnused, int width, int height)
193
     {
194
     scrHeight = height;
195
     scrWidth  = width;
196 6161fe9a Leszek Koltunski
197 d1abb41e Leszek Koltunski
     mRegion.set3(mRadius);
198 f4f3a440 Leszek Koltunski
199 f6d884d5 Leszek Koltunski
     Canvas stretchCanvas;
200 42ec9110 Leszek Koltunski
     textureWidth = (int)(QUOT*width);
201
     textureHeight= (int)(QUOT*height);
202 b0ebdf5e Leszek Koltunski
203 b62eb334 Leszek Koltunski
     if( mMesh!=null ) mMesh.markForDeletion();
204 f2085b96 Leszek Koltunski
     mMesh = new MeshSquare(50,50*textureHeight/textureWidth);
205 d1abb41e Leszek Koltunski
206
     mScale.set(textureWidth,textureHeight,1);
207 698ad0a8 Leszek Koltunski
208 16b22aab Leszek Koltunski
     Bitmap stretchBitmap = Bitmap.createBitmap(textureWidth,textureHeight, Bitmap.Config.ARGB_8888);
209 f6d884d5 Leszek Koltunski
     stretchCanvas = new Canvas(stretchBitmap);
210 b0ebdf5e Leszek Koltunski
211 24ab1cf8 leszek
     Paint paint = new Paint();
212
     paint.setColor(0xff008800);
213
     paint.setStyle(Style.FILL);
214 16b22aab Leszek Koltunski
     stretchCanvas.drawRect(0, 0, textureWidth, textureHeight, paint);
215 24ab1cf8 leszek
     paint.setColor(0xffffffff);
216 b0ebdf5e Leszek Koltunski
217 f6d884d5 Leszek Koltunski
     for(int i=0; i<=NUM_LINES ; i++ )
218
       {
219 16b22aab Leszek Koltunski
       stretchCanvas.drawRect(textureWidth*i/NUM_LINES-1,                           0, textureWidth*i/NUM_LINES+1, textureHeight              , paint);
220
       stretchCanvas.drawRect(                         0, textureHeight*i/NUM_LINES-1, textureWidth              , textureHeight*i/NUM_LINES+1, paint);
221 f6d884d5 Leszek Koltunski
       }
222 b0ebdf5e Leszek Koltunski
223 b62eb334 Leszek Koltunski
     mTexture.setTexture(stretchBitmap);
224 b0ebdf5e Leszek Koltunski
225
     mScreen.detachAll();
226 b62eb334 Leszek Koltunski
     mScreen.attach(mTexture,mEffects,mMesh);
227 b0ebdf5e Leszek Koltunski
228
     mScreen.resize(width, height);
229
     }
230
231
///////////////////////////////////////////////////////////////////////////////////////////////////
232
    
233
   public void onSurfaceCreated(GL10 glUnused, EGLConfig config)
234
     {
235 885b9cca leszek
     VertexEffectDistort.enable();
236
     VertexEffectDeform.enable();
237 b0ebdf5e Leszek Koltunski
238 dc10a48d Leszek Koltunski
     DistortedLibrary.onSurfaceCreated(this);
239 f6d884d5 Leszek Koltunski
     }
240 427ab7bf Leszek Koltunski
241
///////////////////////////////////////////////////////////////////////////////////////////////////
242
243 f6d884d5 Leszek Koltunski
   void down(int x, int y)
244
     {
245 42ec9110 Leszek Koltunski
     float xt = (((float)x)/scrWidth-0.5f)/QUOT;
246
     float yt = (0.5f-((float)y)/scrHeight)/QUOT;
247 f6d884d5 Leszek Koltunski
248
     switch(mMode)
249
       {
250
       case DISTORT: vDistort[0].set(0,0,0);
251 b62eb334 Leszek Koltunski
                     mEffects.apply(mMovingDistort);
252 ebb06a48 leszek
                     mLastEffect = mMovingDistort.getID();
253 e8e54972 Leszek Koltunski
                     mTouchPoint.set(xt,yt,0);
254 f6d884d5 Leszek Koltunski
                     break;
255
       case DEFORM : vDeform[0].set(0,0,0);
256 b62eb334 Leszek Koltunski
                     mEffects.apply(mMovingDeform);
257 d57f3a14 Leszek Koltunski
                     mLastEffect = mMovingDeform.getID();
258 e8e54972 Leszek Koltunski
                     mTouchPoint.set(xt,yt,0);
259 f6d884d5 Leszek Koltunski
                     break;
260
       case SHEAR  : vShear[0].set(0,0,0);
261 b62eb334 Leszek Koltunski
                     mEffects.apply(mMovingShear);
262 d57f3a14 Leszek Koltunski
                     mLastEffect = mMovingShear.getID();
263 42ec9110 Leszek Koltunski
                     mTouchPoint.set(textureWidth*xt,textureHeight*yt,0);
264 f6d884d5 Leszek Koltunski
                     break;
265
       }
266
     }
267 427ab7bf Leszek Koltunski
    
268
///////////////////////////////////////////////////////////////////////////////////////////////////
269
270 f6d884d5 Leszek Koltunski
   void move(int x, int y)
271
     {
272 d1abb41e Leszek Koltunski
     float xm = (float)x/textureWidth;
273
     float ym = (float)y/textureHeight;
274
275 f6d884d5 Leszek Koltunski
     switch(mMode)
276
       {
277 d1abb41e Leszek Koltunski
       case DISTORT: vDistort[0].set( xm,-ym, 0);
278 f6d884d5 Leszek Koltunski
                     break;
279 d1abb41e Leszek Koltunski
       case DEFORM:  vDeform[0].set ( xm,-ym, 0);
280 f6d884d5 Leszek Koltunski
                     break;
281 d1abb41e Leszek Koltunski
       case SHEAR:   vShear[0].set  ( xm,-ym, 0);
282 f6d884d5 Leszek Koltunski
                     break;
283
       }
284
     }
285 427ab7bf Leszek Koltunski
    
286
///////////////////////////////////////////////////////////////////////////////////////////////////
287
288 f6d884d5 Leszek Koltunski
   void up()
289
     {
290 b62eb334 Leszek Koltunski
     mEffects.abortById(mLastEffect);
291 f6d884d5 Leszek Koltunski
292 d1abb41e Leszek Koltunski
     final float DAMP = -0.65f;
293 f6d884d5 Leszek Koltunski
294
     switch(mMode)
295
       {
296
       case DISTORT: for(int i=1; i<NUM_VECTORS-1; i++)
297
                       {
298 d1abb41e Leszek Koltunski
                       vDistort[i].set( vDistort[i-1].get0()*DAMP, vDistort[i-1].get1()*DAMP, 0 );
299 f6d884d5 Leszek Koltunski
                       }
300 e3eab072 Leszek Koltunski
                     vDistort[NUM_VECTORS-1].set(0,0,0);
301 b62eb334 Leszek Koltunski
                     mEffects.apply(mReleasedDistort);
302 52e8e76a Leszek Koltunski
                     mReleasedDistortDynamic.resetToBeginning();
303 8d5a8e06 Leszek Koltunski
                     mReleasedDistort.notifyWhenFinished(this);
304 f6d884d5 Leszek Koltunski
                     break;
305
       case DEFORM : for(int i=1; i<NUM_VECTORS-1; i++)
306
                       {
307 d1abb41e Leszek Koltunski
                       vDeform[i].set( vDeform[i-1].get0()*DAMP, vDeform[i-1].get1()*DAMP, 0 );
308 f6d884d5 Leszek Koltunski
                       }
309 e3eab072 Leszek Koltunski
                     vDeform[NUM_VECTORS-1].set(0,0,0);
310 b62eb334 Leszek Koltunski
                     mEffects.apply(mReleasedDeform);
311 52e8e76a Leszek Koltunski
                     mReleasedDeformDynamic.resetToBeginning();
312 8d5a8e06 Leszek Koltunski
                     mReleasedDeform.notifyWhenFinished(this);
313 f6d884d5 Leszek Koltunski
                     break;
314
       case SHEAR  : for(int i=1; i<NUM_VECTORS-1; i++)
315
                       {
316 d1abb41e Leszek Koltunski
                       vShear[i].set( vShear[i-1].get0()*DAMP, vShear[i-1].get1()*DAMP, 0 );
317 f6d884d5 Leszek Koltunski
                       }
318 e3eab072 Leszek Koltunski
                     vShear[NUM_VECTORS-1].set(0,0,0);
319 b62eb334 Leszek Koltunski
                     mEffects.apply(mReleasedShear);
320 52e8e76a Leszek Koltunski
                     mReleasedShearDynamic.resetToBeginning();
321 8d5a8e06 Leszek Koltunski
                     mReleasedShear.notifyWhenFinished(this);
322 f6d884d5 Leszek Koltunski
                     break;
323
       }
324
     }
325 dc10a48d Leszek Koltunski
326
///////////////////////////////////////////////////////////////////////////////////////////////////
327
328
   public void distortedException(Exception ex)
329
     {
330
     android.util.Log.e("Deform", ex.getMessage() );
331
     }
332
333
///////////////////////////////////////////////////////////////////////////////////////////////////
334
335
   public InputStream localFile(int fileID)
336
      {
337
      return mResources.openRawResource(fileID);
338
      }
339
340
///////////////////////////////////////////////////////////////////////////////////////////////////
341
342
   public void logMessage(String message)
343
      {
344
      android.util.Log.e("Deform", message );
345
      }
346 f6d884d5 Leszek Koltunski
   }