Project

General

Profile

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

examples / src / main / java / org / distorted / examples / predeform / PredeformEffect.java @ 30f337e5

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

    
22
import android.view.View;
23
import android.widget.SeekBar;
24
import android.widget.TextView;
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.MatrixEffectRotate;
38
import org.distorted.library.effect.MatrixEffectScale;
39
import org.distorted.library.effect.MatrixEffectShear;
40
import org.distorted.library.effect.PostprocessEffectBlur;
41
import org.distorted.library.effect.PostprocessEffectGlow;
42
import org.distorted.library.effect.VertexEffectDeform;
43
import org.distorted.library.effect.VertexEffectDistort;
44
import org.distorted.library.effect.VertexEffectMove;
45
import org.distorted.library.effect.VertexEffectPinch;
46
import org.distorted.library.effect.VertexEffectQuaternion;
47
import org.distorted.library.effect.VertexEffectRotate;
48
import org.distorted.library.effect.VertexEffectScale;
49
import org.distorted.library.effect.VertexEffectShear;
50
import org.distorted.library.effect.VertexEffectSink;
51
import org.distorted.library.effect.VertexEffectSwirl;
52
import org.distorted.library.effect.VertexEffectWave;
53
import org.distorted.library.type.Dynamic1D;
54
import org.distorted.library.type.Dynamic2D;
55
import org.distorted.library.type.Dynamic3D;
56
import org.distorted.library.type.Dynamic4D;
57
import org.distorted.library.type.Dynamic5D;
58
import org.distorted.library.type.Static1D;
59
import org.distorted.library.type.Static2D;
60
import org.distorted.library.type.Static3D;
61
import org.distorted.library.type.Static4D;
62
import org.distorted.library.type.Static5D;
63

    
64
import java.lang.ref.WeakReference;
65

    
66
///////////////////////////////////////////////////////////////////////////////////////////////////
67

    
68
class PredeformEffect implements SeekBar.OnSeekBarChangeListener
69
  {
70
  private static final int BACKGROUND_ODD = 0xff555555;
71
  private static final int BACKGROUND_EVEN= 0xff333333;
72

    
73
  private final WeakReference<PredeformActivity> mAct;
74

    
75
  private final EffectName mName;
76
  private final int[] mInter;
77
  private final int[] mInterRegion;
78
  private final int[] mInterCenter;
79
  private final int[] mSeekID;
80
  private final int[] mSeekRegionID;
81
  private final int[] mSeekCenterID;
82
  private final int mDimension;
83
      private final int mRegionDimension;
84
  private TextView mText,mTextRegion,mTextCenter;
85

    
86
  private Dynamic1D mDyn1;
87
  private Dynamic2D mDyn2;
88
  private Dynamic3D mDyn3;
89
  private Dynamic4D mDyn4;
90
  private Dynamic5D mDyn5;
91
  private Static1D  mSta1;
92
  private Static2D  mSta2;
93
  private Static3D  mSta3;
94
  private Static4D  mSta4;
95
  private Static5D  mSta5;
96
  private final Dynamic4D mRegion4Dyn;
97
  private final Static4D  mRegion4Sta;
98
  private final Dynamic3D mRegion3Dyn;
99
  private final Static3D  mRegion3Sta;
100
  private final Dynamic3D mCenterDyn;
101
  private final Static3D  mCenterSta;
102

    
103
  private View mButton, mEffect, mCenter, mRegion;
104
  private long mId;
105

    
106
///////////////////////////////////////////////////////////////////////////////////////////////////
107
// requires knowledge about effect nature
108

    
109
  Effect createEffect()
110
    {
111
    Effect effect=null;
112

    
113
    switch(mName)
114
      {
115
      case ROTATE           : effect = new MatrixEffectRotate      (mDyn1, mDyn3, mCenterDyn); break;
116
      case QUATERNION       : effect = new MatrixEffectQuaternion  (mDyn4, mCenterDyn)       ; break;
117
      case MOVE             : effect = new MatrixEffectMove        (mDyn3)                   ; break;
118
      case SCALE            : effect = new MatrixEffectScale       (mDyn3)                   ; break;
119
      case SHEAR            : effect = new MatrixEffectShear       (mDyn3, mCenterDyn)       ; break;
120

    
121
      case DISTORT          : effect = new VertexEffectDistort     (mDyn3, mCenterDyn, mRegion4Dyn)              ; break;
122
      case DEFORM           : effect = new VertexEffectDeform      (mDyn3, mDyn1, mCenterDyn, mRegion4Dyn)       ; break;
123
      case SINK             : effect = new VertexEffectSink        (mDyn1, mCenterDyn, mRegion4Dyn)              ; break;
124
      case PINCH            : effect = new VertexEffectPinch       (mDyn3, mCenterDyn, mRegion4Dyn)              ; break;
125
      case SWIRL            : effect = new VertexEffectSwirl       (mDyn1, mCenterDyn, mRegion4Dyn)              ; break;
126
      case WAVE             : effect = new VertexEffectWave        (mDyn5, mCenterDyn, mRegion4Dyn)              ; break;
127
      case VERTEX_MOVE      : effect = new VertexEffectMove        (mDyn3)                                       ; break;
128
      case VERTEX_QUATERNION: effect = new VertexEffectQuaternion  (mDyn4, mCenterDyn)                           ; break;
129
      case VERTEX_ROTATE    : effect = new VertexEffectRotate      (mDyn1, mDyn3, mCenterDyn)                    ; break;
130
      case VERTEX_SCALE     : effect = new VertexEffectScale       (mDyn3)                                       ; break;
131
      case VERTEX_SHEAR     : effect = new VertexEffectShear       (mDyn3, mCenterDyn)                           ; break;
132

    
133
      case ALPHA            : effect = new FragmentEffectAlpha     (mDyn1,        mCenterDyn, mRegion3Dyn, false); break;
134
      case SMOOTH_ALPHA     : effect = new FragmentEffectAlpha     (mDyn1,        mCenterDyn, mRegion3Dyn, true ); break;
135
      case CHROMA           : effect = new FragmentEffectChroma    (mDyn1, mDyn3, mCenterDyn, mRegion3Dyn, false); break;
136
      case SMOOTH_CHROMA    : effect = new FragmentEffectChroma    (mDyn1, mDyn3, mCenterDyn, mRegion3Dyn, true ); break;
137
      case BRIGHTNESS       : effect = new FragmentEffectBrightness(mDyn1,        mCenterDyn, mRegion3Dyn, false); break;
138
      case SMOOTH_BRIGHTNESS: effect = new FragmentEffectBrightness(mDyn1,        mCenterDyn, mRegion3Dyn, true ); break;
139
      case SATURATION       : effect = new FragmentEffectSaturation(mDyn1,        mCenterDyn, mRegion3Dyn, false); break;
140
      case SMOOTH_SATURATION: effect = new FragmentEffectSaturation(mDyn1,        mCenterDyn, mRegion3Dyn, true ); break;
141
      case CONTRAST         : effect = new FragmentEffectContrast  (mDyn1,        mCenterDyn, mRegion3Dyn, false); break;
142
      case SMOOTH_CONTRAST  : effect = new FragmentEffectContrast  (mDyn1,        mCenterDyn, mRegion3Dyn, true ); break;
143

    
144
      case BLUR             : effect = new PostprocessEffectBlur   (mDyn2      ); break;
145
      case GLOW             : effect = new PostprocessEffectGlow   (mDyn2,mDyn4); break;
146
      }
147

    
148
    mId = effect.getID();
149

    
150
    return effect;
151
    }
152

    
153
///////////////////////////////////////////////////////////////////////////////////////////////////
154
// requires knowledge about effect nature
155

    
156
  private void fillStatics()
157
    {
158
    switch(mName)
159
      {
160
      ///////////////////////////////////////////////////////////////////////////////////////
161
      // MATRIX (and VERTEX-pseudo-matrix)
162
      ///////////////////////////////////////////////////////////////////////////////////////
163

    
164
      case VERTEX_ROTATE    :
165
      case ROTATE           : float an = (mInter[0]-50)*180/50.0f;
166
                              float rx = (mInter[1]-50)/ 50.0f;
167
                              float ry = (mInter[2]-50)/ 50.0f;
168
                              float rz = (mInter[3]-50)/ 50.0f;
169
                              mSta1.set(an);
170
                              mSta3.set(rx,ry,rz);
171
                              break;
172
      case VERTEX_QUATERNION:
173
      case QUATERNION       : float qx = (mInter[0]-50)/ 50.0f;
174
                              float qy = (mInter[1]-50)/ 50.0f;
175
                              float qz = (mInter[2]-50)/ 50.0f;
176
                              float qw = (mInter[3]-50)*3.1415f/50;
177
                              float cosA = (float)Math.cos(qw/2);
178
                              float len = (float)Math.sqrt(qx*qx+qy*qy+qz*qz);
179
                              float sinAnorm = (float)Math.sin(qw/2)/len;
180
                              mSta4.set(sinAnorm*qx,sinAnorm*qy,sinAnorm*qz, cosA);
181
                              break;
182
      case MOVE             : float scr= mAct.get().getScreenWidth();
183
                              float sw = scr/200.0f;
184
                              float sh = scr/200.0f;
185
                              float xm = (mInter[0]-50)*sw;
186
                              float ym = (mInter[1]-50)*sh;
187
                              float zm = (mInter[2]-50)*(sw+sh)/2;
188
                              mSta3.set(xm,ym,zm);
189
                              break;
190
      case VERTEX_SCALE     :
191
      case SCALE            : float xs = (mInter[0]>50 ? 0.04f : 0.013f)*(mInter[0]-50) + 1;
192
                              float ys = (mInter[1]>50 ? 0.04f : 0.013f)*(mInter[1]-50) + 1;
193
                              float zs = (mInter[2]>50 ? 0.04f : 0.013f)*(mInter[2]-50) + 1;
194
                              mSta3.set(xs,ys,zs);
195
                              break;
196
      case VERTEX_SHEAR     :
197
      case SHEAR            : float xsh = (mInter[0]-50)/25.0f;
198
                              float ysh = (mInter[1]-50)/25.0f;
199
                              float zsh = (mInter[2]-50)/25.0f;
200
                              mSta3.set(xsh,ysh,zsh);
201
                              break;
202

    
203
      ///////////////////////////////////////////////////////////////////////////////////////
204
      // VERTEX
205
      ///////////////////////////////////////////////////////////////////////////////////////
206

    
207
      case VERTEX_MOVE      :
208
      case DISTORT          : float ld = 0.02f;
209
                              float xd = (mInter[0]-50)*ld;
210
                              float yd = (mInter[1]-50)*ld;
211
                              float zd = (mInter[2]-50)*ld;
212
                              mSta3.set(xd,yd,zd);
213
                              break;
214
      case DEFORM           : float le = 0.02f;
215
                              float xe = (mInter[0]-50)*le;
216
                              float ye = (mInter[1]-50)*le;
217
                              float ze = (mInter[2]-50)*le;
218
                              mSta3.set(xe,ye,ze);
219
                              float re = (mInter[3])*le;
220
                              mSta1.set(re);
221
                              break;
222
      case WAVE             : float l2 = 0.02f;
223
                              float x2 = (mInter[0]-50)*l2;
224
                              float y2 = (mInter[1]-50)*l2;
225
                              float z2 = (mInter[2]-50)*180 / 50.0f;
226
                              float w2 = (mInter[3]-50)*180 / 50.0f;
227
                              float v2 = (mInter[4]-50)*180 / 50.0f;
228
                              mSta5.set(x2,y2,z2,w2,v2);
229
                              break;
230
      case SWIRL            : mSta1.set( 3.6f*(mInter[0]-50) );
231
                              break;
232
      case SINK             : mSta1.set(mInter[0] > 50 ? 50.0f/(100.01f-mInter[0]) : mInter[0] / 50.0f);
233
                              break;
234
      case PINCH            : float dp = mInter[0] > 50 ? 50.0f/(100.01f-mInter[0]) : mInter[0] / 50.0f;
235
                              float ap = (mInter[1]-50)*180 / 50.0f;
236
                              float bp = (mInter[2]-50)*180 / 50.0f;
237
                              mSta3.set(dp,ap,bp);
238
                              break;
239

    
240
      ///////////////////////////////////////////////////////////////////////////////////////
241
      // FRAGMENT
242
      ///////////////////////////////////////////////////////////////////////////////////////
243

    
244
      case ALPHA            :
245
      case SMOOTH_ALPHA     : mSta1.set(mInter[0]/100.0f);
246
                              break;
247
      case SATURATION       :
248
      case SMOOTH_SATURATION:
249
      case CONTRAST         :
250
      case SMOOTH_CONTRAST  :
251
      case BRIGHTNESS       :
252
      case SMOOTH_BRIGHTNESS: mSta1.set(mInter[0] > 50 ? 50.0f/(100.01f-mInter[0]) : mInter[0] / 50.0f);
253
                              break;
254
      case CHROMA           :
255
      case SMOOTH_CHROMA    : mSta1.set(mInter[0]/100.0f);
256
                              mSta3.set(mInter[1]/100.0f,
257
                                        mInter[2]/100.0f,
258
                                        mInter[3]/100.0f);
259
                              break;
260

    
261
      ///////////////////////////////////////////////////////////////////////////////////////
262
      // POSTPROCESS
263
      ///////////////////////////////////////////////////////////////////////////////////////
264

    
265
      case BLUR             : mSta2.set(mInter[0]/2.0f,
266
                                        mInter[1]/2.0f);
267
                              break;
268
      case GLOW             : mSta2.set(mInter[0]/2.0f,
269
                                        mInter[1]/2.0f);
270
                              mSta4.set(mInter[2]/100.0f,
271
                                        mInter[3]/100.0f,
272
                                        mInter[4]/100.0f,
273
                                        mInter[5]/100.0f );
274
                              break;
275
      }
276
    }
277

    
278
///////////////////////////////////////////////////////////////////////////////////////////////////
279

    
280
  private void setDefaultInter()
281
    {
282
    switch(mDimension)
283
      {
284
      case 6: mInter[5] = 50;
285
      case 5: mInter[4] = 50;
286
      case 4: mInter[3] = 50;
287
      case 3: mInter[2] = 50;
288
      case 2: mInter[1] = 50;
289
      case 1: mInter[0] = 50;
290
      }
291

    
292
    if( mName==EffectName.ROTATE         ||
293
        mName==EffectName.VERTEX_ROTATE   )
294
      {
295
      mInter[1]= 100;
296
      }
297
    if( mName==EffectName.QUATERNION     ||
298
        mName==EffectName.VERTEX_QUATERNION )
299
      {
300
      mInter[0]= 100;
301
      }
302
    }
303

    
304
///////////////////////////////////////////////////////////////////////////////////////////////////
305

    
306
  private void setText()
307
    {
308
    String text = mName.name();
309

    
310
    if( mSta1 !=null )
311
      {
312
      float f1 = ((int)(mSta1.get0()*100))/100.0f;
313
      text += " "+f1;
314
      }
315

    
316
    if( mSta2 !=null )
317
      {
318
      float f1 = ((int)(mSta2.get0()*100))/100.0f;
319
      float f2 = ((int)(mSta2.get1()*100))/100.0f;
320
      text += " ("+f1+","+f2+")";
321
      }
322

    
323
    if( mSta3 !=null )
324
      {
325
      float f1 = ((int)(mSta3.get0()*100))/100.0f;
326
      float f2 = ((int)(mSta3.get1()*100))/100.0f;
327
      float f3 = ((int)(mSta3.get2()*100))/100.0f;
328
      text += " ("+f1+","+f2+","+f3+")";
329
      }
330

    
331
    if( mSta4 !=null )
332
      {
333
      float f1 = ((int)(mSta4.get0()*100))/100.0f;
334
      float f2 = ((int)(mSta4.get1()*100))/100.0f;
335
      float f3 = ((int)(mSta4.get2()*100))/100.0f;
336
      float f4 = ((int)(mSta4.get3()*100))/100.0f;
337
      text += " ("+f1+","+f2+","+f3+","+f4+")";
338
      }
339

    
340
    if( mSta5 !=null )
341
      {
342
      float f1 = ((int)(mSta5.get0()*100))/100.0f;
343
      float f2 = ((int)(mSta5.get1()*100))/100.0f;
344
      float f3 = ((int)(mSta5.get2()*100))/100.0f;
345
      float f4 = ((int)(mSta5.get3()*100))/100.0f;
346
      float f5 = ((int)(mSta5.get4()*100))/100.0f;
347
      text += " ("+f1+","+f2+","+f3+","+f4+","+f5+")";
348
      }
349

    
350
    mText.setText(text);
351
    }
352

    
353
///////////////////////////////////////////////////////////////////////////////////////////////////
354

    
355
  private void fillCenterStatics()
356
    {
357
    PredeformActivity act = mAct.get();
358

    
359
    float x = (mInterCenter[0]*0.012f - 0.6f);
360
    float y = (mInterCenter[1]*0.012f - 0.6f);
361
    float z = (mInterCenter[2]*0.012f - 0.6f);
362

    
363
    if( mName.getType() == EffectType.MATRIX )
364
      {
365
      float factor = act.getScaleFactor();
366
      x *= factor;
367
      y *= factor;
368
      z *= factor;
369
      }
370

    
371
    mCenterSta.set(x,y,z);
372
    }
373

    
374
///////////////////////////////////////////////////////////////////////////////////////////////////
375

    
376
  private void setDefaultCenterInter()
377
    {
378
    mInterCenter[0] = 50;
379
    mInterCenter[1] = 50;
380
    mInterCenter[2] = 50;
381
    }
382

    
383
///////////////////////////////////////////////////////////////////////////////////////////////////
384

    
385
  private void setCenterText()
386
    {
387
    float f0 = ((int)(mCenterSta.get0()*100))/100.0f;
388
    float f1 = ((int)(mCenterSta.get1()*100))/100.0f;
389
    float f2 = ((int)(mCenterSta.get2()*100))/100.0f;
390

    
391
    mTextCenter.setText("center ("+f0+","+f1+","+f2+")");
392
    }
393

    
394
///////////////////////////////////////////////////////////////////////////////////////////////////
395

    
396
  private void fillRegionStatics()
397
    {
398
    PredeformActivity act = mAct.get();
399

    
400
    float factorX = 0.01f;
401
    float factorY = 0.01f;
402
 // float factorZ = 0.01f;
403

    
404
    int deduct = (mName.getType() == EffectType.VERTEX ? 50:0);
405

    
406
    float x = (mInterRegion[0]-deduct)*factorX;
407
    float y = (mInterRegion[1]-deduct)*factorY;
408
    float z = (mInterRegion[2]-deduct)*factorX;   // ??
409
    float r =  mInterRegion[3]        *(factorX+factorY)/2;
410

    
411
    mRegion4Sta.set(x,y,z,r);
412
    mRegion3Sta.set(x,y,z);
413
    }
414

    
415
///////////////////////////////////////////////////////////////////////////////////////////////////
416

    
417
  private void setDefaultRegionInter()
418
    {
419
    mInterRegion[0] = 50;
420
    mInterRegion[1] = 50;
421
    mInterRegion[2] = 50;
422
    mInterRegion[3] = 50;
423
    }
424

    
425
///////////////////////////////////////////////////////////////////////////////////////////////////
426

    
427
  private void setRegionText()
428
    {
429
    if( mRegionDimension==4 )
430
      {
431
      float f0 = ((int)(mRegion4Sta.get0()*100))/100.0f;
432
      float f1 = ((int)(mRegion4Sta.get1()*100))/100.0f;
433
      float f2 = ((int)(mRegion4Sta.get2()*100))/100.0f;
434
      float f3 = ((int)(mRegion4Sta.get3()*100))/100.0f;
435

    
436
      mTextRegion.setText("region (" + f0 + "," + f1 + "," + f2 + "," + f3 + ")");
437
      }
438

    
439
    if( mRegionDimension==3 )
440
      {
441
      float f0 = ((int)(mRegion4Sta.get0()*100))/100.0f;
442
      float f1 = ((int)(mRegion4Sta.get1()*100))/100.0f;
443
      float f2 = ((int)(mRegion4Sta.get2()*100))/100.0f;
444

    
445
      mTextRegion.setText("region (" + f0 + "," + f1 + "," + f2 + ")");
446
      }
447
    }
448

    
449
///////////////////////////////////////////////////////////////////////////////////////////////////
450

    
451
  private void setCenter(PredeformActivity act)
452
    {
453
    float factor = ( mName.getType() == EffectType.MATRIX ? act.getScaleFactor() : 1.0f);
454
    act.setCenter( mCenterSta.get0()/factor, mCenterSta.get1()/factor, mCenterSta.get2()/factor );
455
    }
456

    
457
///////////////////////////////////////////////////////////////////////////////////////////////////
458

    
459
  void setBackground(int pos)
460
    {
461
    int color = (pos%2==1 ? BACKGROUND_ODD:BACKGROUND_EVEN);
462

    
463
    if( mEffect!=null ) mEffect.setBackgroundColor(color);
464
    if( mCenter!=null ) mCenter.setBackgroundColor(color);
465
    if( mRegion!=null ) mRegion.setBackgroundColor(color);
466
    }
467

    
468
///////////////////////////////////////////////////////////////////////////////////////////////////
469

    
470
  PredeformEffect(EffectName name, PredeformActivity act)
471
    {
472
    mAct = new WeakReference<>(act);
473
    mName = name;
474

    
475
    mDyn1 = null;
476
    mDyn2 = null;
477
    mDyn3 = null;
478
    mDyn4 = null;
479
    mDyn5 = null;
480
    mSta1 = null;
481
    mSta2 = null;
482
    mSta3 = null;
483
    mSta4 = null;
484
    mSta5 = null;
485

    
486
    mDimension = mName.getEffectDimension();
487
    mRegionDimension = mName.getRegionDimension();
488

    
489
    switch(mDimension)
490
      {
491
      case 1 : mDyn1 = new Dynamic1D();
492
               mSta1 = new Static1D(0);
493
               mDyn1.add(mSta1);
494
               break;
495
      case 2 : mDyn2 = new Dynamic2D();
496
               mSta2 = new Static2D(0,0);
497
               mDyn2.add(mSta2);
498
               break;
499
      case 3 : mDyn3 = new Dynamic3D();
500
               mSta3 = new Static3D(0,0,0);
501
               mDyn3.add(mSta3);
502
               break;
503
      case 4 : if( mName == EffectName.QUATERNION || mName == EffectName.VERTEX_QUATERNION )
504
                 {
505
                 mDyn4 = new Dynamic4D();
506
                 mSta4 = new Static4D(0,0,0,0);
507
                 mDyn4.add(mSta4);
508
                 }
509
               else
510
                 {
511
                 mDyn3 = new Dynamic3D();
512
                 mSta3 = new Static3D(0,0,0);
513
                 mDyn3.add(mSta3);
514
                 mDyn1 = new Dynamic1D();
515
                 mSta1 = new Static1D(0);
516
                 mDyn1.add(mSta1);
517
                 }
518
               break;
519
      case 5 : if( mName == EffectName.WAVE )
520
                 {
521
                 mDyn5 = new Dynamic5D();
522
                 mSta5 = new Static5D(0, 0, 0, 0, 0);
523
                 mDyn5.add(mSta5);
524
                 }
525
               else
526
                 {
527
                 mDyn4 = new Dynamic4D();
528
                 mSta4 = new Static4D(0,0,0,0);
529
                 mDyn4.add(mSta4);
530
                 mDyn1 = new Dynamic1D();
531
                 mSta1 = new Static1D(0);
532
                 mDyn1.add(mSta1);
533
                 }
534
               break;
535
      case 6 : mDyn2 = new Dynamic2D();
536
               mSta2 = new Static2D(0,0);
537
               mDyn2.add(mSta2);
538
               mDyn4 = new Dynamic4D();
539
               mSta4 = new Static4D(0,0,0,0);
540
               mDyn4.add(mSta4);
541
               break;
542
      default: throw new RuntimeException("unsupported effect");
543
      }
544

    
545
    mInter = new int[mDimension];
546
    mSeekID= new int[mDimension];
547

    
548
    mInterRegion = new int[4];
549
    mSeekRegionID= new int[4];
550
    mRegion4Dyn  = new Dynamic4D();
551
    mRegion4Sta  = new Static4D(0,0,0,0);
552
    mRegion4Dyn.add(mRegion4Sta);
553
    mRegion3Dyn  = new Dynamic3D();
554
    mRegion3Sta  = new Static3D(0,0,0);
555
    mRegion3Dyn.add(mRegion3Sta);
556

    
557
    mInterCenter = new int[3];
558
    mSeekCenterID= new int[3];
559
    mCenterDyn   = new Dynamic3D();
560
    mCenterSta   = new Static3D(0,0,0);
561
    mCenterDyn.add(mCenterSta);
562

    
563
    mButton = null;
564
    mEffect = null;
565
    mCenter = null;
566
    mRegion = null;
567
    }
568

    
569
///////////////////////////////////////////////////////////////////////////////////////////////////
570

    
571
  View createView(int num)
572
    {
573
    SeekBar[] seek = new SeekBar[mDimension];
574

    
575
    PredeformActivity act = mAct.get();
576

    
577
    switch(mDimension)
578
      {
579
      case 1 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect1d, null);
580
               mText      = mEffect.findViewById(R.id.effect1dText);
581
               seek[0]    = mEffect.findViewById(R.id.effect1dbar1);
582
               mSeekID[0] = seek[0].getId();
583
               mButton    = mEffect.findViewById(R.id.button1dRemove);
584
               break;
585
      case 2 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect2d, null);
586
               mText      = mEffect.findViewById(R.id.effect2dText);
587
               seek[0]    = mEffect.findViewById(R.id.effect2dbar1);
588
               seek[1]    = mEffect.findViewById(R.id.effect2dbar2);
589
               mSeekID[0] = seek[0].getId();
590
               mSeekID[1] = seek[1].getId();
591
               mButton    = mEffect.findViewById(R.id.button2dRemove);
592
               break;
593
      case 3 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect3d, null);
594
               mText      = mEffect.findViewById(R.id.effect3dText);
595
               seek[0]    = mEffect.findViewById(R.id.effect3dbar1);
596
               seek[1]    = mEffect.findViewById(R.id.effect3dbar2);
597
               seek[2]    = mEffect.findViewById(R.id.effect3dbar3);
598
               mSeekID[0] = seek[0].getId();
599
               mSeekID[1] = seek[1].getId();
600
               mSeekID[2] = seek[2].getId();
601
               mButton    = mEffect.findViewById(R.id.button3dRemove);
602
               break;
603
      case 4 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect4d, null);
604
               mText      = mEffect.findViewById(R.id.effect4dText);
605
               seek[0]    = mEffect.findViewById(R.id.effect4dbar1);
606
               seek[1]    = mEffect.findViewById(R.id.effect4dbar2);
607
               seek[2]    = mEffect.findViewById(R.id.effect4dbar3);
608
               seek[3]    = mEffect.findViewById(R.id.effect4dbar4);
609
               mSeekID[0] = seek[0].getId();
610
               mSeekID[1] = seek[1].getId();
611
               mSeekID[2] = seek[2].getId();
612
               mSeekID[3] = seek[3].getId();
613
               mButton    = mEffect.findViewById(R.id.button4dRemove);
614
               break;
615
      case 5 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect5d, null);
616
               mText      = mEffect.findViewById(R.id.effect5dText);
617
               seek[0]    = mEffect.findViewById(R.id.effect5dbar1);
618
               seek[1]    = mEffect.findViewById(R.id.effect5dbar2);
619
               seek[2]    = mEffect.findViewById(R.id.effect5dbar3);
620
               seek[3]    = mEffect.findViewById(R.id.effect5dbar4);
621
               seek[4]    = mEffect.findViewById(R.id.effect5dbar5);
622
               mSeekID[0] = seek[0].getId();
623
               mSeekID[1] = seek[1].getId();
624
               mSeekID[2] = seek[2].getId();
625
               mSeekID[3] = seek[3].getId();
626
               mSeekID[4] = seek[4].getId();
627
               mButton    = mEffect.findViewById(R.id.button5dRemove);
628
               break;
629
      case 6 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect6d, null);
630
               mText      = mEffect.findViewById(R.id.effect6dText);
631
               seek[0]    = mEffect.findViewById(R.id.effect6dbar1);
632
               seek[1]    = mEffect.findViewById(R.id.effect6dbar2);
633
               seek[2]    = mEffect.findViewById(R.id.effect6dbar3);
634
               seek[3]    = mEffect.findViewById(R.id.effect6dbar4);
635
               seek[4]    = mEffect.findViewById(R.id.effect6dbar5);
636
               seek[5]    = mEffect.findViewById(R.id.effect6dbar6);
637
               mSeekID[0] = seek[0].getId();
638
               mSeekID[1] = seek[1].getId();
639
               mSeekID[2] = seek[2].getId();
640
               mSeekID[3] = seek[3].getId();
641
               mSeekID[4] = seek[4].getId();
642
               mSeekID[5] = seek[5].getId();
643
               mButton    = mEffect.findViewById(R.id.button6dRemove);
644
               break;
645
      default: android.util.Log.e("GenericEffect", "dimension "+mDimension+" not supported!");
646
               return null;
647
      }
648

    
649
    mEffect.setBackgroundColor( num%2==1 ? BACKGROUND_EVEN: BACKGROUND_ODD );
650

    
651
    setDefaultInter();
652

    
653
    for(int i=0; i<mDimension; i++)
654
      {
655
      seek[i].setOnSeekBarChangeListener(this);
656
      seek[i].setProgress( mInter[i] );
657
      }
658

    
659
    return mEffect;
660
    }
661

    
662
///////////////////////////////////////////////////////////////////////////////////////////////////
663

    
664
  View createRegion(int num)
665
    {
666
    PredeformActivity act = mAct.get();
667

    
668
    if( mRegionDimension== 4 )
669
      {
670
      mRegion = act.getLayoutInflater().inflate(R.layout.effectregion4, null);
671
      mRegion.setBackgroundColor(num % 2 == 1 ? BACKGROUND_EVEN : BACKGROUND_ODD);
672

    
673
      SeekBar[] seek = new SeekBar[4];
674

    
675
      seek[0] = mRegion.findViewById(R.id.effectRegion4BarX);
676
      seek[1] = mRegion.findViewById(R.id.effectRegion4BarY);
677
      seek[2] = mRegion.findViewById(R.id.effectRegion4BarZ);
678
      seek[3] = mRegion.findViewById(R.id.effectRegion4BarR);
679

    
680
      mSeekRegionID[0] = seek[0].getId();
681
      mSeekRegionID[1] = seek[1].getId();
682
      mSeekRegionID[2] = seek[2].getId();
683
      mSeekRegionID[3] = seek[3].getId();
684

    
685
      mTextRegion = mRegion.findViewById(R.id.effectRegion4Text);
686

    
687
      setDefaultRegionInter();
688

    
689
      for (int i = 0; i < 4; i++)
690
        {
691
        seek[i].setOnSeekBarChangeListener(this);
692
        seek[i].setProgress(mInterRegion[i]);
693
        }
694

    
695
      act.setRegion(mRegion4Sta);
696
      }
697
    else
698
      {
699
      mRegion = act.getLayoutInflater().inflate(R.layout.effectregion3, null);
700
      mRegion.setBackgroundColor(num % 2 == 1 ? BACKGROUND_EVEN : BACKGROUND_ODD);
701

    
702
      SeekBar[] seek = new SeekBar[3];
703

    
704
      seek[0] = mRegion.findViewById(R.id.effectRegion3BarRX);
705
      seek[1] = mRegion.findViewById(R.id.effectRegion3BarRY);
706
      seek[2] = mRegion.findViewById(R.id.effectRegion3BarRZ);
707

    
708
      mSeekRegionID[0] = seek[0].getId();
709
      mSeekRegionID[1] = seek[1].getId();
710
      mSeekRegionID[2] = seek[2].getId();
711

    
712
      mTextRegion = mRegion.findViewById(R.id.effectRegion3Text);
713

    
714
      setDefaultRegionInter();
715

    
716
      for (int i = 0; i < 3; i++)
717
        {
718
        seek[i].setOnSeekBarChangeListener(this);
719
        seek[i].setProgress(mInterRegion[i]);
720
        }
721

    
722
      act.setRegion( new Static4D( mRegion3Sta.get0(), mRegion3Sta.get1(), mRegion3Sta.get2(), 1.0f) );
723
      }
724

    
725
    return mRegion;
726
    }
727

    
728
///////////////////////////////////////////////////////////////////////////////////////////////////
729

    
730
  View createCenter(int num)
731
    {
732
    PredeformActivity act = mAct.get();
733

    
734
    mCenter = act.getLayoutInflater().inflate(R.layout.effectcenter, null);
735
    mCenter.setBackgroundColor( num%2==1 ? BACKGROUND_EVEN: BACKGROUND_ODD );
736

    
737
    SeekBar[] seek = new SeekBar[3];
738

    
739
    seek[0] = mCenter.findViewById(R.id.effectCenterBarX );
740
    seek[1] = mCenter.findViewById(R.id.effectCenterBarY );
741
    seek[2] = mCenter.findViewById(R.id.effectCenterBarZ );
742

    
743
    mSeekCenterID[0] = seek[0].getId();
744
    mSeekCenterID[1] = seek[1].getId();
745
    mSeekCenterID[2] = seek[2].getId();
746

    
747
    mTextCenter = mCenter.findViewById(R.id.effectCenterText);
748

    
749
    setDefaultCenterInter();
750

    
751
    for(int i=0; i<3; i++)
752
      {
753
      seek[i].setOnSeekBarChangeListener(this);
754
      seek[i].setProgress( mInterCenter[i] );
755
      }
756

    
757
    setCenter(act);
758

    
759
    return mCenter;
760
    }
761

    
762
///////////////////////////////////////////////////////////////////////////////////////////////////
763

    
764
  public void onProgressChanged(SeekBar bar, int progress, boolean fromUser)
765
    {
766
    boolean vectorChanged=false;
767
    boolean regionChanged=false;
768
    boolean centerChanged=false;
769

    
770
    for(int dim=0; dim<6; dim++)
771
      {
772
      if ( mDimension>dim && bar.getId()==mSeekID[dim] )
773
        {
774
        mInter[dim] = progress;
775
        vectorChanged = true;
776
        }
777
      }
778

    
779
    if( vectorChanged )
780
      {
781
      fillStatics();
782
      setText();
783
      }
784

    
785
    for(int reg=0; reg<4; reg++)
786
      {
787
      if( mRegionDimension>reg && bar.getId() == mSeekRegionID[reg] )
788
        {
789
        mInterRegion[reg] = progress;
790
        regionChanged = true;
791
        }
792
      }
793

    
794
    if( regionChanged )
795
      {
796
      fillRegionStatics();
797
      setRegionText();
798
      }
799

    
800
    for(int cen=0; cen<3; cen++)
801
      {
802
      if( bar.getId() == mSeekCenterID[cen] )
803
        {
804
        mInterCenter[cen] = progress;
805
        centerChanged = true;
806
        }
807
      }
808

    
809
    if( centerChanged )
810
      {
811
      fillCenterStatics();
812
      setCenterText();
813
      }
814

    
815
    if( fromUser )
816
      {
817
      PredeformActivity act = mAct.get();
818
      setCenter(act);
819
      act.setRegion(mRegion4Sta);
820
      }
821
    }
822

    
823
///////////////////////////////////////////////////////////////////////////////////////////////////
824

    
825
  boolean thisView(View v)
826
    {
827
    return v==mButton;
828
    }
829

    
830
///////////////////////////////////////////////////////////////////////////////////////////////////
831

    
832
  public long getId()
833
    {
834
    return mId;
835
    }
836

    
837
///////////////////////////////////////////////////////////////////////////////////////////////////
838

    
839
  public int getDimension()
840
    {
841
    return mDimension;
842
    }
843

    
844
///////////////////////////////////////////////////////////////////////////////////////////////////
845

    
846
  public View getEffect()
847
    {
848
    return mEffect;
849
    }
850

    
851
///////////////////////////////////////////////////////////////////////////////////////////////////
852

    
853
  public View getRegion()
854
    {
855
    return mRegion;
856
    }
857

    
858
///////////////////////////////////////////////////////////////////////////////////////////////////
859

    
860
  public View getCenter()
861
    {
862
    return mCenter;
863
    }
864

    
865
///////////////////////////////////////////////////////////////////////////////////////////////////
866

    
867
  public void onStartTrackingTouch(SeekBar bar) { }
868

    
869
///////////////////////////////////////////////////////////////////////////////////////////////////
870

    
871
  public void onStopTrackingTouch(SeekBar bar)  { }
872
  }
(3-3/7)