Project

General

Profile

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

examples / src / main / java / org / distorted / examples / earth / EarthRenderer.java @ 823f63f7

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.earth;
21

    
22
import android.graphics.Bitmap;
23
import android.graphics.BitmapFactory;
24
import android.opengl.GLSurfaceView;
25

    
26
import org.distorted.examples.R;
27
import org.distorted.library.effect.Effect;
28
import org.distorted.library.effect.EffectName;
29
import org.distorted.library.effect.EffectType;
30
import org.distorted.library.effect.FragmentEffectAlpha;
31
import org.distorted.library.effect.FragmentEffectBrightness;
32
import org.distorted.library.effect.FragmentEffectChroma;
33
import org.distorted.library.effect.FragmentEffectContrast;
34
import org.distorted.library.effect.FragmentEffectSaturation;
35
import org.distorted.library.effect.MatrixEffectMove;
36
import org.distorted.library.effect.MatrixEffectQuaternion;
37
import org.distorted.library.effect.MatrixEffectScale;
38
import org.distorted.library.effect.VertexEffectDeform;
39
import org.distorted.library.effect.VertexEffectDistort;
40
import org.distorted.library.effect.VertexEffectPinch;
41
import org.distorted.library.effect.VertexEffectSink;
42
import org.distorted.library.effect.VertexEffectSwirl;
43
import org.distorted.library.effect.VertexEffectWave;
44
import org.distorted.library.main.Distorted;
45
import org.distorted.library.main.DistortedEffects;
46
import org.distorted.library.main.DistortedScreen;
47
import org.distorted.library.main.DistortedTexture;
48
import org.distorted.library.mesh.MeshBase;
49
import org.distorted.library.mesh.MeshSphere;
50
import org.distorted.library.type.Dynamic3D;
51
import org.distorted.library.type.DynamicQuat;
52
import org.distorted.library.type.Static1D;
53
import org.distorted.library.type.Static3D;
54
import org.distorted.library.type.Static4D;
55

    
56
import java.io.IOException;
57
import java.io.InputStream;
58

    
59
import javax.microedition.khronos.egl.EGLConfig;
60
import javax.microedition.khronos.opengles.GL10;
61

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

    
64
class EarthRenderer implements GLSurfaceView.Renderer
65
{
66
    private static final int   SIZE    =     500;
67
    private static final int   RADIUS_V= SIZE/10;
68
    private static final int   RADIUS_F= SIZE/15;
69
    private static final int   LEVEL   =      32;
70
    private static final float FOV     =   30.0f;
71
    private static final float NEAR    =    0.1f;
72
    private static final int   MAX_EFF =      20;
73
    private static final float SCALE   =   1.10f;
74

    
75
    private GLSurfaceView mView;
76
    private DistortedTexture mTexture;
77
    private DistortedEffects mEffects;
78
    private MeshBase mMesh;
79
    private DistortedScreen mScreen;
80
    private int mObjWidth, mObjHeight, mObjDepth;
81
    private Static3D mMove, mScaleFactor, mCenter;
82

    
83
    private int mScrWidth, mScrHeight;
84
    private float mLevel;
85

    
86
    private Static3D mColor;
87
    private Static3D mRegionF;
88
    private Static4D mRegionV;
89
    private Static1D mStrength;
90

    
91
    Static4D mQuat1, mQuat2;
92
    int mScreenMin;
93

    
94
///////////////////////////////////////////////////////////////////////////////////////////////////
95

    
96
    EarthRenderer(GLSurfaceView v)
97
      {
98
      mView = v;
99

    
100
      mLevel = SCALE;
101

    
102
      DistortedEffects.setMax(EffectType.VERTEX  , MAX_EFF);
103
      DistortedEffects.setMax(EffectType.FRAGMENT, MAX_EFF);
104

    
105
      mStrength   = new Static1D(0.5f);
106
      mColor      = new Static3D(255,0,0);
107
      mRegionF    = new Static3D(RADIUS_F,RADIUS_F,RADIUS_F);
108
      mRegionV    = new Static4D(0,0,0,RADIUS_V);
109
      mMove       = new Static3D(0,0,0);
110
      mScaleFactor= new Static3D(1,1,1);
111
      mCenter     = new Static3D(0,0,0);
112

    
113
      Dynamic3D scale = new Dynamic3D(0,0.5f);
114
      scale.add(mScaleFactor);
115

    
116
      mMesh     = new MeshSphere(LEVEL);
117
      mTexture  = new DistortedTexture(SIZE,SIZE);
118

    
119
      mObjWidth = mTexture.getWidth();
120
      mObjHeight= mTexture.getHeight();
121
      mObjDepth = mTexture.getDepth(mMesh);
122

    
123
      mQuat1 = new Static4D(0,0,0,1);  // unity
124
      mQuat2 = new Static4D(0,0,0,1);  // quaternions
125
      
126
      DynamicQuat quatInt1 = new DynamicQuat(0,0.5f);
127
      DynamicQuat quatInt2 = new DynamicQuat(0,0.5f);
128

    
129
      quatInt1.add(mQuat1);
130
      quatInt2.add(mQuat2);
131

    
132
      mEffects = new DistortedEffects();
133
      mEffects.apply( new MatrixEffectMove(mMove) );
134
      mEffects.apply( new MatrixEffectScale(scale));
135
      mEffects.apply( new MatrixEffectQuaternion(quatInt1, mCenter) );
136
      mEffects.apply( new MatrixEffectQuaternion(quatInt2, mCenter) );
137

    
138
      mScreen = new DistortedScreen();
139
      mScreen.setProjection(FOV, NEAR);
140
      }
141

    
142
///////////////////////////////////////////////////////////////////////////////////////////////////
143
   
144
    public void onDrawFrame(GL10 glUnused) 
145
      {
146
      mScreen.render( System.currentTimeMillis() );
147
      }
148

    
149
///////////////////////////////////////////////////////////////////////////////////////////////////
150
    
151
    public void onSurfaceChanged(GL10 glUnused, int width, int height) 
152
      {
153
      mScrWidth = width;
154
      mScrHeight= height;
155
      mScreenMin= width<height ? width:height;
156

    
157
      adjustFactor();
158

    
159
      mCenter.set( (float)mObjWidth/2, (float)mObjHeight/2, (float)mObjDepth/2 );
160
      mScreen.resize(width, height);
161
      }
162

    
163
///////////////////////////////////////////////////////////////////////////////////////////////////
164

    
165
    void setLevel(int level)
166
      {
167
      float N=3.0f;
168

    
169
      // MAP: 0--> SCALE/N   50-->SCALE   100->SCALE*N
170
      mLevel = SCALE* (1.0f+  (level>=50 ? N-1 : (N-1)/N) * (level-50)/50.0f);
171

    
172
      adjustFactor();
173
      }
174

    
175
///////////////////////////////////////////////////////////////////////////////////////////////////
176

    
177
    private void adjustFactor()
178
      {
179
      float xW = (float)mScrWidth /mObjWidth;
180
      float xH = (float)mScrHeight/mObjHeight;
181

    
182
      float factor = xW>xH ? mLevel*xH : mLevel*xW;
183

    
184
      mMove.set( (mScrWidth-factor*mObjWidth)/2 , (mScrHeight-factor*mObjHeight)/2 , 0);
185
      mScaleFactor.set(factor,factor,factor);
186
      }
187

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

    
190
    void addNewPoint(float longitude, float latitude, EffectName name)
191
      {
192
      final float CORR = 10.0F;
193
      Static3D vector;
194
      Effect effect =null;
195

    
196
      double sinLON = Math.sin(longitude);
197
      double cosLON = Math.cos(longitude);
198
      double sinLAT = Math.sin(latitude);
199
      double cosLAT = Math.cos(latitude);
200

    
201
      float x = (float)(sinLON*cosLAT)/2.0f;
202
      float y = (float)        sinLAT /2.0f;
203
      float z = (float)(cosLON*cosLAT)/2.0f;
204

    
205
      Static3D center = new Static3D( (0.5f+x)*mObjWidth, (0.5f+y)*mObjHeight, (0.5f+z)*mObjDepth);
206

    
207
      //android.util.Log.e("earth", "center "+(x*mObjWidth)+" "+(y*mObjHeight)+" "+(z*mObjDepth));
208
      //android.util.Log.e("earth", "longitude: "+longitude+" latitude:"+latitude);
209

    
210
      switch(name)
211
        {
212
        case DISTORT          : vector = new Static3D( +x*mObjWidth/CORR, +y*mObjHeight/CORR, +z*mObjDepth/CORR);
213
                                effect = new VertexEffectDistort( vector, center, mRegionV); break;
214
        case DEFORM           : vector = new Static3D( +x*mObjWidth/CORR, +y*mObjHeight/CORR, +z*mObjDepth/CORR);
215
                                effect = new VertexEffectDeform ( vector, center, mRegionV); break;
216
        /*
217
        case SINK             : effect = new VertexEffectSink   (mDyn1, center, mRegionV); break;
218
        case PINCH            : effect = new VertexEffectPinch  (mDyn2, center, mRegionV); break;
219
        case SWIRL            : effect = new VertexEffectSwirl  (mDyn1, center, mRegionV); break;
220
        case WAVE             : effect = new VertexEffectWave   (mDyn5, center, mRegionV); break;
221
        */
222
        case ALPHA            : effect = new FragmentEffectAlpha     (mStrength,        center, mRegionF, false); break;
223
        case SMOOTH_ALPHA     : effect = new FragmentEffectAlpha     (mStrength,        center, mRegionF, true ); break;
224
        case CHROMA           : effect = new FragmentEffectChroma    (mStrength, mColor,center, mRegionF, false); break;
225
        case SMOOTH_CHROMA    : effect = new FragmentEffectChroma    (mStrength, mColor,center, mRegionF, true ); break;
226
        case BRIGHTNESS       : effect = new FragmentEffectBrightness(mStrength,        center, mRegionF, false); break;
227
        case SMOOTH_BRIGHTNESS: effect = new FragmentEffectBrightness(mStrength,        center, mRegionF, true ); break;
228
        case SATURATION       : effect = new FragmentEffectSaturation(mStrength,        center, mRegionF, false); break;
229
        case SMOOTH_SATURATION: effect = new FragmentEffectSaturation(mStrength,        center, mRegionF, true ); break;
230
        case CONTRAST         : effect = new FragmentEffectContrast  (mStrength,        center, mRegionF, false); break;
231
        case SMOOTH_CONTRAST  : effect = new FragmentEffectContrast  (mStrength,        center, mRegionF, true ); break;
232

    
233
        default               : android.util.Log.e("EarthRenderer", "unexpected effect: "+name.toString() );
234
        }
235

    
236
      if( effect!=null )
237
        {
238
        mEffects.apply(effect);
239
        }
240
      }
241

    
242
///////////////////////////////////////////////////////////////////////////////////////////////////
243

    
244
    void removeAll()
245
      {
246
      mEffects.abortByType(EffectType.VERTEX);
247
      mEffects.abortByType(EffectType.FRAGMENT);
248
      }
249

    
250
///////////////////////////////////////////////////////////////////////////////////////////////////
251
    
252
    public void onSurfaceCreated(GL10 glUnused, EGLConfig config) 
253
      {
254
      InputStream is = mView.getContext().getResources().openRawResource(R.raw.world);
255
      Bitmap bitmap;
256

    
257
      try
258
        {
259
        bitmap = BitmapFactory.decodeStream(is);
260
        }
261
      finally
262
        {
263
        try
264
          {
265
          is.close();
266
          }
267
        catch(IOException e) { }
268
        }
269

    
270
      mTexture.setTexture(bitmap);
271

    
272
      mScreen.detachAll();
273
      mScreen.attach(mTexture,mEffects,mMesh);
274

    
275
      Effect.enableEffects(EffectType.FRAGMENT);
276
      Effect.enableEffects(EffectType.VERTEX);
277

    
278
      try
279
        {
280
        Distorted.onCreate(mView.getContext());
281
        }
282
      catch(Exception ex)
283
        {
284
        android.util.Log.e("Earth", ex.getMessage() );
285
        }
286
      }
287
}
(2-2/4)