Project

General

Profile

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

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

1 bc0a685b 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 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 d57f3a14 Leszek Koltunski
import org.distorted.library.effect.MatrixEffectMove;
27
import org.distorted.library.effect.MatrixEffectShear;
28
import org.distorted.library.effect.VertexEffectDeform;
29
import org.distorted.library.effect.VertexEffectDistort;
30 01782e85 Leszek Koltunski
import org.distorted.library.main.Distorted;
31
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 107e4b72 Leszek Koltunski
import org.distorted.library.mesh.MeshFlat;
36 e8b6aa95 Leszek Koltunski
37 b62eb334 Leszek Koltunski
import org.distorted.library.message.EffectListener;
38
import org.distorted.library.message.EffectMessage;
39 7589635e Leszek Koltunski
import org.distorted.library.type.Dynamic3D;
40
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 b62eb334 Leszek Koltunski
class DeformRenderer implements GLSurfaceView.Renderer , EffectListener
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 ebb06a48 leszek
   private Static3D mTouchPoint;
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 d57f3a14 Leszek Koltunski
   private Static3D mMove;
69 d3c2d1ef leszek
   private int scrHeight, scrWidth;
70
   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 427ab7bf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
80
81 30c71dd5 Leszek Koltunski
   DeformRenderer(GLSurfaceView view)
82 427ab7bf Leszek Koltunski
      { 
83
      mView = view;
84 f6d884d5 Leszek Koltunski
85 b62eb334 Leszek Koltunski
      mEffects    = new DistortedEffects();
86 a4d59c0b Leszek Koltunski
      mRegion     = new Static4D(0,0,0,0);
87
      mMove       = new Static3D(0,0,0);
88
      mTouchPoint = new Static3D(0,0,0);
89 7589635e Leszek Koltunski
90 b62eb334 Leszek Koltunski
      mEffects.registerForMessages(this);
91
92 7abd1d00 Leszek Koltunski
      // DISTORT
93 d57f3a14 Leszek Koltunski
      Dynamic3D releasedDistortDynamic = new Dynamic3D(NUM_VECTORS*500, 0.5f);
94
      releasedDistortDynamic.setMode(Dynamic3D.MODE_PATH);
95
      Dynamic3D movingDistortDynamic = new Dynamic3D(0,0.5f);
96
      movingDistortDynamic.setMode(Dynamic3D.MODE_PATH);
97 7589635e Leszek Koltunski
98 7abd1d00 Leszek Koltunski
      vDistort = new Static3D[NUM_VECTORS];
99 7589635e Leszek Koltunski
100 427ab7bf Leszek Koltunski
      for(int i=0; i<NUM_VECTORS; i++)
101
        {
102 7abd1d00 Leszek Koltunski
        vDistort[i] = new Static3D(0,0,0);
103 d57f3a14 Leszek Koltunski
        releasedDistortDynamic.add(vDistort[i]);
104 427ab7bf Leszek Koltunski
        }
105 7589635e Leszek Koltunski
106 d57f3a14 Leszek Koltunski
      movingDistortDynamic.add(vDistort[0]);
107 7589635e Leszek Koltunski
108 7abd1d00 Leszek Koltunski
      // Deform
109 d57f3a14 Leszek Koltunski
      Dynamic3D releasedDeformDynamic = new Dynamic3D(NUM_VECTORS*500, 0.5f);
110
      releasedDeformDynamic.setMode(Dynamic3D.MODE_PATH);
111
      Dynamic3D movingDeformDynamic = new Dynamic3D(0,0.5f);
112
      movingDeformDynamic.setMode(Dynamic3D.MODE_PATH);
113 7abd1d00 Leszek Koltunski
114
      vDeform = new Static3D[NUM_VECTORS];
115
116
      for(int i=0; i<NUM_VECTORS; i++)
117 427ab7bf Leszek Koltunski
        {
118 7abd1d00 Leszek Koltunski
        vDeform[i] = new Static3D(0,0,0);
119 d57f3a14 Leszek Koltunski
        releasedDeformDynamic.add(vDeform[i]);
120 427ab7bf Leszek Koltunski
        }
121 7abd1d00 Leszek Koltunski
122 d57f3a14 Leszek Koltunski
      movingDeformDynamic.add(vDeform[0]);
123 7abd1d00 Leszek Koltunski
124
      // Shear
125 d57f3a14 Leszek Koltunski
      Dynamic3D releasedShearDynamic = new Dynamic3D(NUM_VECTORS*500, 0.5f);
126
      releasedShearDynamic.setMode(Dynamic3D.MODE_PATH);
127
      Dynamic3D movingShearDynamic = new Dynamic3D(0,0.5f);
128
      movingShearDynamic.setMode(Dynamic3D.MODE_PATH);
129 7abd1d00 Leszek Koltunski
130
      vShear = new Static3D[NUM_VECTORS];
131
132
      for(int i=0; i<NUM_VECTORS; i++)
133
        {
134
        vShear[i] = new Static3D(0,0,0);
135 d57f3a14 Leszek Koltunski
        releasedShearDynamic.add(vShear[i]);
136 7abd1d00 Leszek Koltunski
        }
137
138 d57f3a14 Leszek Koltunski
      movingShearDynamic.add(vShear[0]);
139 392e16fd Leszek Koltunski
140 e4330c89 Leszek Koltunski
      mScreen = new DistortedScreen();
141 e72c53e5 Leszek Koltunski
      mScreen.showFPS();
142 d57f3a14 Leszek Koltunski
143 a4d59c0b Leszek Koltunski
      mMovingDistort   = new VertexEffectDistort( movingDistortDynamic  , mTouchPoint, mRegion);
144
      mMovingDeform    = new VertexEffectDeform ( movingDeformDynamic   , mTouchPoint, mRegion);
145
      mMovingShear     = new MatrixEffectShear  ( movingShearDynamic    , mTouchPoint         );
146
      mReleasedDistort = new VertexEffectDistort( releasedDistortDynamic, mTouchPoint, mRegion);
147
      mReleasedDeform  = new VertexEffectDeform ( releasedDeformDynamic , mTouchPoint, mRegion);
148
      mReleasedShear   = new MatrixEffectShear  ( releasedShearDynamic  , mTouchPoint         );
149 d57f3a14 Leszek Koltunski
150 b62eb334 Leszek Koltunski
      mEffects.apply(new MatrixEffectMove(mMove));
151 427ab7bf Leszek Koltunski
      }
152
153
///////////////////////////////////////////////////////////////////////////////////////////////////
154
155 42f65cb4 Leszek Koltunski
   void setMode(EffectName mode)
156 427ab7bf Leszek Koltunski
      {
157
      mMode = mode;  
158
      }
159
   
160
///////////////////////////////////////////////////////////////////////////////////////////////////
161
162 30c71dd5 Leszek Koltunski
   void setRegionRadius(int r)
163 427ab7bf Leszek Koltunski
      {
164 1585ba24 Leszek Koltunski
      mRadius = ( r==100 ? 100.0f : r/200.0f);
165 9e7b6dbd Leszek Koltunski
      mRegion.set4(mRadius*scrWidth);
166 427ab7bf Leszek Koltunski
      }
167
168 b62eb334 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
169
// keep aborting the 'released' effects, otherwise we are quickly going to run out of room in
170
// effect queues.
171
172
   public void effectMessage(final EffectMessage em, final long effectID, final long objectID)
173
     {
174
     switch(em)
175
        {
176
        case EFFECT_FINISHED: mEffects.abortById(effectID); break;
177
        }
178
     }
179
180 427ab7bf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
181
   
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 9e7b6dbd Leszek Koltunski
     mRegion.set4(mRadius*scrWidth);
195 f4f3a440 Leszek Koltunski
196 f6d884d5 Leszek Koltunski
     Canvas stretchCanvas;
197 b0ebdf5e Leszek Koltunski
     int w=width/2;
198
     int h=height/2;
199
200 b62eb334 Leszek Koltunski
     if( mMesh!=null ) mMesh.markForDeletion();
201 5f2a53b6 leszek
202 b62eb334 Leszek Koltunski
     mMesh = new MeshFlat(50,50*h/w);
203 f6d884d5 Leszek Koltunski
     Bitmap stretchBitmap = Bitmap.createBitmap(w,h, Bitmap.Config.ARGB_8888);
204
     stretchCanvas = new Canvas(stretchBitmap);
205 b0ebdf5e Leszek Koltunski
206 24ab1cf8 leszek
     Paint paint = new Paint();
207
     paint.setColor(0xff008800);
208
     paint.setStyle(Style.FILL);
209
     stretchCanvas.drawRect(0, 0, w, h, paint);
210
     paint.setColor(0xffffffff);
211 b0ebdf5e Leszek Koltunski
212 f6d884d5 Leszek Koltunski
     for(int i=0; i<=NUM_LINES ; i++ )
213
       {
214 a4d59c0b Leszek Koltunski
       stretchCanvas.drawRect(w*i/NUM_LINES-1,               0, w*i/NUM_LINES+1, h              , paint);
215
       stretchCanvas.drawRect(              0, h*i/NUM_LINES-1, w              , h*i/NUM_LINES+1, paint);
216 f6d884d5 Leszek Koltunski
       }
217 b0ebdf5e Leszek Koltunski
218 b62eb334 Leszek Koltunski
     if( mTexture==null ) mTexture = new DistortedTexture(w,h);
219
     mTexture.setTexture(stretchBitmap);
220 b0ebdf5e Leszek Koltunski
221 d57f3a14 Leszek Koltunski
     mMove.set(scrWidth/4,scrHeight/4,0);
222 630703d1 leszek
223 b0ebdf5e Leszek Koltunski
     mScreen.detachAll();
224 b62eb334 Leszek Koltunski
     mScreen.attach(mTexture,mEffects,mMesh);
225 b0ebdf5e Leszek Koltunski
226
     mScreen.resize(width, height);
227
     }
228
229
///////////////////////////////////////////////////////////////////////////////////////////////////
230
    
231
   public void onSurfaceCreated(GL10 glUnused, EGLConfig config)
232
     {
233 885b9cca leszek
     VertexEffectDistort.enable();
234
     VertexEffectDeform.enable();
235 b0ebdf5e Leszek Koltunski
236
     try
237
       {
238
       Distorted.onCreate(mView.getContext());
239
       }
240
     catch(Exception ex)
241
       {
242 9e7b6dbd Leszek Koltunski
       android.util.Log.e("Deform", ex.toString() );
243 b0ebdf5e Leszek Koltunski
       }
244 f6d884d5 Leszek Koltunski
     }
245 427ab7bf Leszek Koltunski
246
///////////////////////////////////////////////////////////////////////////////////////////////////
247
248 f6d884d5 Leszek Koltunski
   void down(int x, int y)
249
     {
250 a4d59c0b Leszek Koltunski
     int xt = x-scrWidth /4;
251 f6d884d5 Leszek Koltunski
     int yt = y-scrHeight/4;
252 427ab7bf Leszek Koltunski
      
253 f6d884d5 Leszek Koltunski
     if( xt<0 ) xt=0;
254 a4d59c0b Leszek Koltunski
     if( xt>scrWidth /2 ) xt=scrWidth/2;
255 f6d884d5 Leszek Koltunski
     if( yt<0 ) yt=0;
256
     if( yt>scrHeight/2 ) yt=scrHeight/2;
257 630703d1 leszek
      
258 a4d59c0b Leszek Koltunski
     mTouchPoint.set(xt, scrHeight/2-yt,0);   // OpenGL coord system and 2D coords have inverted Y axis
259 f6d884d5 Leszek Koltunski
260
     switch(mMode)
261
       {
262
       case DISTORT: vDistort[0].set(0,0,0);
263 b62eb334 Leszek Koltunski
                     mEffects.apply(mMovingDistort);
264 ebb06a48 leszek
                     mLastEffect = mMovingDistort.getID();
265 f6d884d5 Leszek Koltunski
                     break;
266
       case DEFORM : vDeform[0].set(0,0,0);
267 b62eb334 Leszek Koltunski
                     mEffects.apply(mMovingDeform);
268 d57f3a14 Leszek Koltunski
                     mLastEffect = mMovingDeform.getID();
269 f6d884d5 Leszek Koltunski
                     break;
270
       case SHEAR  : vShear[0].set(0,0,0);
271 b62eb334 Leszek Koltunski
                     mEffects.apply(mMovingShear);
272 d57f3a14 Leszek Koltunski
                     mLastEffect = mMovingShear.getID();
273 f6d884d5 Leszek Koltunski
                     break;
274
       }
275
     }
276 427ab7bf Leszek Koltunski
    
277
///////////////////////////////////////////////////////////////////////////////////////////////////
278
279 f6d884d5 Leszek Koltunski
   void move(int x, int y)
280
     {
281
     switch(mMode)
282
       {
283 a4d59c0b Leszek Koltunski
       case DISTORT: vDistort[0].set(x,-y,0);
284 f6d884d5 Leszek Koltunski
                     break;
285 a4d59c0b Leszek Koltunski
       case DEFORM:  vDeform[0].set(x,-y,0);
286 f6d884d5 Leszek Koltunski
                     break;
287 a4d59c0b Leszek Koltunski
       case SHEAR:   vShear[0].set( (float)x/(scrWidth/2), (float)(-y)/(scrHeight/2), 0);
288 f6d884d5 Leszek Koltunski
                     break;
289
       }
290
     }
291 427ab7bf Leszek Koltunski
    
292
///////////////////////////////////////////////////////////////////////////////////////////////////
293
294 f6d884d5 Leszek Koltunski
   void up()
295
     {
296 b62eb334 Leszek Koltunski
     mEffects.abortById(mLastEffect);
297 f6d884d5 Leszek Koltunski
298
     float damp = -0.65f;
299
300
     switch(mMode)
301
       {
302
       case DISTORT: for(int i=1; i<NUM_VECTORS-1; i++)
303
                       {
304 e3eab072 Leszek Koltunski
                       vDistort[i].set( vDistort[i-1].get1()*damp, vDistort[i-1].get2()*damp, 0 );
305 f6d884d5 Leszek Koltunski
                       }
306 e3eab072 Leszek Koltunski
                     vDistort[NUM_VECTORS-1].set(0,0,0);
307 b62eb334 Leszek Koltunski
                     mEffects.apply(mReleasedDistort);
308 f6d884d5 Leszek Koltunski
                     break;
309
       case DEFORM : for(int i=1; i<NUM_VECTORS-1; i++)
310
                       {
311 e3eab072 Leszek Koltunski
                       vDeform[i].set( vDeform[i-1].get1()*damp, vDeform[i-1].get2()*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 f6d884d5 Leszek Koltunski
                     break;
316
       case SHEAR  : for(int i=1; i<NUM_VECTORS-1; i++)
317
                       {
318 e3eab072 Leszek Koltunski
                       vShear[i].set( vShear[i-1].get1()*damp, vShear[i-1].get2()*damp, 0 );
319 f6d884d5 Leszek Koltunski
                       }
320 e3eab072 Leszek Koltunski
                     vShear[NUM_VECTORS-1].set(0,0,0);
321 b62eb334 Leszek Koltunski
                     mEffects.apply(mReleasedShear);
322 f6d884d5 Leszek Koltunski
                     break;
323
       }
324
     }
325
   }