Project

General

Profile

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

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

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