Project

General

Profile

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

examples / src / main / java / org / distorted / examples / monalisa / MonaLisaRenderer.java @ 625c67de

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.examples.monalisa;
21

    
22
import java.io.IOException;
23
import java.io.InputStream;
24

    
25
import javax.microedition.khronos.egl.EGLConfig;
26
import javax.microedition.khronos.opengles.GL10;
27

    
28
import org.distorted.examples.R;
29
import org.distorted.library.effect.MatrixEffectScale;
30
import org.distorted.library.effect.VertexEffectDistort;
31
import org.distorted.library.main.DistortedLibrary;
32
import org.distorted.library.main.DistortedEffects;
33
import org.distorted.library.main.DistortedScreen;
34
import org.distorted.library.main.DistortedTexture;
35
import org.distorted.library.mesh.MeshSquare;
36
import org.distorted.library.type.Dynamic3D;
37
import org.distorted.library.type.Static3D;
38
import org.distorted.library.type.Static4D;
39

    
40
import android.app.ActivityManager;
41
import android.content.Context;
42
import android.content.pm.ConfigurationInfo;
43
import android.content.res.Resources;
44
import android.graphics.Bitmap;
45
import android.graphics.BitmapFactory;
46
import android.opengl.GLSurfaceView;
47

    
48
///////////////////////////////////////////////////////////////////////////////////////////////////
49

    
50
class MonaLisaRenderer implements GLSurfaceView.Renderer, DistortedLibrary.LibraryUser
51
{
52
    private final GLSurfaceView mView;
53
    private final Resources mResources;
54
    private final DistortedEffects mEffects;
55
    private final DistortedTexture mTexture;
56
    private final DistortedScreen mScreen;
57
    private final Static3D mScale;
58

    
59
    private MeshSquare mMesh;
60
    private float mBmpRatio;
61

    
62
///////////////////////////////////////////////////////////////////////////////////////////////////
63

    
64
    MonaLisaRenderer(GLSurfaceView v)
65
      {
66
      mView = v;
67
      mResources = v.getResources();
68

    
69
      // Centers of the Effects.
70
      // center = (0,0,0) would be the midpoint of the Bitmap.
71
      // MonaLisa bitmap is 320x366, this is thus (90,108) pixels from the lower-left corner
72
      Static3D centerLeft  = new Static3D( ( 90-320*0.5f)/320.0f, (108-366*0.5f)/366.0f, 0);
73
      // (176,111) from the lower left
74
      Static3D centerRight = new Static3D( (176-320*0.5f)/320.0f, (111-366*0.5f)/366.0f, 0);
75

    
76
      // two Regions defining the areas affected by the Distort effect
77
      // a Region is like a mask that specifies which area around the Center is affected by
78
      // the Distort. Here (-10,10,0) pixels from the left center, with radius 25 pixels
79
      Static4D regionLeft  = new Static4D( -10/320.0f, 10/366.0f, 0, 25/320.0f);
80
      // and likewise (10,5,0) pixels from the right Center, radius 25 pixels.
81
      Static4D regionRight = new Static4D(  10/320.0f,  5/366.0f, 0, 25/320.0f);
82

    
83
      // two dynamics for interpolating through vectors of distortion. Interpolate
84
      // every 1000 milliseconds, indefinitely ('0.0f').
85
      Dynamic3D degLeft = new Dynamic3D(1000,0.0f);
86
      Dynamic3D degRight= new Dynamic3D(1000,0.0f);
87

    
88
      // two vectors of distortion the left tip of the mouth gets distorted with -
89
      // interpolated from (0,0,0) - i.e. no distortion - to (-20 pixels, 20 pixels, 0),
90
      // i.e. slightly to the top left.
91
      degLeft.add ( new Static3D(         0,         0, 0) );
92
      degLeft.add ( new Static3D(-20/320.0f, 20/366.0f, 0) );
93

    
94
      // likewise two vectors the right tip is distorted with.
95
      degRight.add( new Static3D(         0,         0, 0) );
96
      degRight.add( new Static3D( 20/320.0f, 10/366.0f, 0) );
97

    
98
      // Equip MonaLisa with the Effects we want to draw her with - i.e. two Distorts of the mouth
99
      mEffects = new DistortedEffects();
100
      mEffects.apply( new VertexEffectDistort( degLeft , centerLeft , regionLeft ) );
101
      mEffects.apply( new VertexEffectDistort( degRight, centerRight, regionRight) );
102

    
103
      // ... and a Scale - so far by (1,1,1), i.e. no scale. The mScale point will be computed
104
      // later, in onSurfaceChanged, when we actually know the size of the screen and thus how
105
      // much to scale the initial Mesh (which is 1x1x0 in size)
106
      mScale= new Static3D(1,1,1);
107
      mEffects.apply(new MatrixEffectScale(mScale));
108

    
109
      mTexture = new DistortedTexture();
110
      mScreen  = new DistortedScreen();
111
      }
112

    
113
///////////////////////////////////////////////////////////////////////////////////////////////////
114
   
115
    public void onDrawFrame(GL10 glUnused) 
116
      {
117
      mScreen.render( System.currentTimeMillis() );
118
      }
119

    
120
///////////////////////////////////////////////////////////////////////////////////////////////////
121
    
122
    public void onSurfaceChanged(GL10 glUnused, int width, int height) 
123
      {
124
      if( width<height ) mScale.set( width,   width*mBmpRatio, 1 );
125
      else               mScale.set( height/mBmpRatio, height, 1 );
126

    
127
      mScreen.resize(width, height);
128
      }
129

    
130
///////////////////////////////////////////////////////////////////////////////////////////////////
131
    
132
    public void onSurfaceCreated(GL10 glUnused, EGLConfig config) 
133
      {
134
      InputStream is = mView.getContext().getResources().openRawResource(R.raw.monalisa);
135
      Bitmap bitmap;
136
        
137
      try 
138
        {
139
        bitmap = BitmapFactory.decodeStream(is);
140
        } 
141
      finally 
142
        {
143
        try 
144
          {
145
          is.close();
146
          } 
147
        catch(IOException ignored) { }
148
        }  
149

    
150
      mBmpRatio = (float)bitmap.getHeight()/bitmap.getWidth();
151

    
152
      // Create an underlying Mesh of 9x10 vertices - this is for the Distort
153
      // effect to have vertices to distort. We multiply by mBmpRatio here so
154
      // that the Mesh's cells are as close to squares as possible (when they
155
      // finally be rendered with a Scale - see mScale)
156
      if( mMesh==null ) mMesh = new MeshSquare(9, (int)(9*mBmpRatio) );
157

    
158
      // Every time activity goes to background, its OpenGL resources - including
159
      // Textures - get deleted. We always need to call setTexture() here to
160
      // recreate the internal OpenGL textures.
161
      mTexture.setTexture(bitmap);
162

    
163
      // Build the Scene Graph - attach all Objects we want to be rendered to the Screen.
164
      mScreen.detachAll();
165
      mScreen.attach(mTexture,mEffects,mMesh);
166

    
167
      // All effects are by default disabled! Enable all we need (and better only those)
168
      // before the call to DistortedLibrary.onCreate(). Best done here.
169
      VertexEffectDistort.enable();
170

    
171
      DistortedLibrary.onSurfaceCreated(this);
172
      }
173

    
174
///////////////////////////////////////////////////////////////////////////////////////////////////
175

    
176
    public void distortedException(Exception ex)
177
      {
178
      android.util.Log.e("MonaLisa", ex.getMessage() );
179
      }
180

    
181
///////////////////////////////////////////////////////////////////////////////////////////////////
182

    
183
    public InputStream localFile(int fileID)
184
      {
185
      return mResources.openRawResource(fileID);
186
      }
187

    
188
///////////////////////////////////////////////////////////////////////////////////////////////////
189

    
190
    public void logMessage(String message)
191
      {
192
      android.util.Log.e("MonaLisa", message );
193
      }
194
}
(2-2/3)