Project

General

Profile

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

examples / src / main / java / org / distorted / examples / deform / DeformRenderer.java @ 698ad0a8

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