Project

General

Profile

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

examples / src / main / java / org / distorted / examples / generic / GenericEffect.java @ 073c140a

1 56cbe1cf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2016 Leszek Koltunski                                                               //
3
//                                                                                               //
4 71c8884f Leszek Koltunski
// This file is part of Distorted.                                                               //
5 56cbe1cf Leszek Koltunski
//                                                                                               //
6 71c8884f Leszek Koltunski
// Distorted is free software: you can redistribute it and/or modify                             //
7 56cbe1cf 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 56cbe1cf 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 56cbe1cf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
19
20 2ec2dc32 Leszek Koltunski
package org.distorted.examples.generic;
21 56cbe1cf Leszek Koltunski
22
import android.view.View;
23
import android.widget.SeekBar;
24
import android.widget.TextView;
25
26
import org.distorted.examples.R;
27 06366d12 Leszek Koltunski
import org.distorted.library.effect.Effect;
28 a418b421 Leszek Koltunski
import org.distorted.library.effect.EffectName;
29
import org.distorted.library.effect.EffectType;
30 06366d12 Leszek Koltunski
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 06c636a5 Leszek Koltunski
import org.distorted.library.effect.PostprocessEffectBlur;
41
import org.distorted.library.effect.PostprocessEffectGlow;
42 06366d12 Leszek Koltunski
import org.distorted.library.effect.VertexEffectDeform;
43
import org.distorted.library.effect.VertexEffectDistort;
44 4282d39a Leszek Koltunski
import org.distorted.library.effect.VertexEffectMove;
45 06366d12 Leszek Koltunski
import org.distorted.library.effect.VertexEffectPinch;
46 4282d39a Leszek Koltunski
import org.distorted.library.effect.VertexEffectQuaternion;
47 ad98c3cb Leszek Koltunski
import org.distorted.library.effect.VertexEffectRotate;
48 60da87db Leszek Koltunski
import org.distorted.library.effect.VertexEffectScale;
49 073c140a Leszek Koltunski
import org.distorted.library.effect.VertexEffectShear;
50 06366d12 Leszek Koltunski
import org.distorted.library.effect.VertexEffectSink;
51
import org.distorted.library.effect.VertexEffectSwirl;
52
import org.distorted.library.effect.VertexEffectWave;
53 01782e85 Leszek Koltunski
import org.distorted.library.main.DistortedEffects;
54 56cbe1cf Leszek Koltunski
import org.distorted.library.type.Dynamic1D;
55
import org.distorted.library.type.Dynamic2D;
56
import org.distorted.library.type.Dynamic3D;
57
import org.distorted.library.type.Dynamic4D;
58 2f2f6176 Leszek Koltunski
import org.distorted.library.type.Dynamic5D;
59 56cbe1cf Leszek Koltunski
import org.distorted.library.type.Static1D;
60
import org.distorted.library.type.Static2D;
61
import org.distorted.library.type.Static3D;
62
import org.distorted.library.type.Static4D;
63 2f2f6176 Leszek Koltunski
import org.distorted.library.type.Static5D;
64 56cbe1cf Leszek Koltunski
65
import java.lang.ref.WeakReference;
66
67
///////////////////////////////////////////////////////////////////////////////////////////////////
68
69 46b26cdc Leszek Koltunski
class GenericEffect implements SeekBar.OnSeekBarChangeListener
70 56cbe1cf Leszek Koltunski
  {
71 3b1e9c7e Leszek Koltunski
  private static final int BACKGROUND_ODD = 0xff555555;
72
  private static final int BACKGROUND_EVEN= 0xff333333;
73
74 46b26cdc Leszek Koltunski
  private WeakReference<GenericActivity2> mAct;
75 56cbe1cf Leszek Koltunski
76 a418b421 Leszek Koltunski
  private EffectName mName;
77 56cbe1cf Leszek Koltunski
  private int[] mInter;
78
  private int[] mInterRegion;
79
  private int[] mInterCenter;
80
  private int[] mSeekID;
81
  private int[] mSeekRegionID;
82
  private int[] mSeekCenterID;
83 1585ba24 Leszek Koltunski
  private int mDimension, mRegionDimension;
84 56cbe1cf Leszek Koltunski
  private TextView mText,mTextRegion,mTextCenter;
85
86
  private Dynamic1D mDyn1;
87 c11a3a15 Leszek Koltunski
  private Dynamic2D mDyn2;
88 56cbe1cf Leszek Koltunski
  private Dynamic3D mDyn3;
89 334c13fa Leszek Koltunski
  private Dynamic4D mDyn4;
90 2f2f6176 Leszek Koltunski
  private Dynamic5D mDyn5;
91 56cbe1cf Leszek Koltunski
  private Static1D  mSta1;
92 c11a3a15 Leszek Koltunski
  private Static2D  mSta2;
93 56cbe1cf Leszek Koltunski
  private Static3D  mSta3;
94 334c13fa Leszek Koltunski
  private Static4D  mSta4;
95 2f2f6176 Leszek Koltunski
  private Static5D  mSta5;
96 1585ba24 Leszek Koltunski
  private Dynamic4D mRegion4Dyn;
97
  private Static4D  mRegion4Sta;
98
  private Dynamic3D mRegion3Dyn;
99
  private Static3D  mRegion3Sta;
100 334c13fa Leszek Koltunski
  private Dynamic3D mCenterDyn;
101
  private Static3D  mCenterSta;
102 56cbe1cf Leszek Koltunski
103 fed00329 Leszek Koltunski
  private View mButton, mEffect, mCenter, mRegion;
104 fa9053f5 Leszek Koltunski
  private long mId;
105
106 8fd9f5fa Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
107 4282d39a Leszek Koltunski
// requires knowledge about effect nature
108 8fd9f5fa Leszek Koltunski
109 d04a4886 Leszek Koltunski
  void apply(DistortedEffects effects)
110 8fd9f5fa Leszek Koltunski
    {
111 06366d12 Leszek Koltunski
    Effect effect=null;
112
113 8fd9f5fa Leszek Koltunski
    switch(mName)
114
      {
115 ad98c3cb Leszek Koltunski
      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 2a261997 Leszek Koltunski
121 1585ba24 Leszek Koltunski
      case DISTORT          : effect = new VertexEffectDistort     (mDyn3, mCenterDyn, mRegion4Dyn); break;
122
      case DEFORM           : effect = new VertexEffectDeform      (mDyn3, mCenterDyn, mRegion4Dyn); break;
123
      case SINK             : effect = new VertexEffectSink        (mDyn1, mCenterDyn, mRegion4Dyn); break;
124 5e23b17b Leszek Koltunski
      case PINCH            : effect = new VertexEffectPinch       (mDyn3, mCenterDyn, mRegion4Dyn); break;
125 1585ba24 Leszek Koltunski
      case SWIRL            : effect = new VertexEffectSwirl       (mDyn1, mCenterDyn, mRegion4Dyn); break;
126
      case WAVE             : effect = new VertexEffectWave        (mDyn5, mCenterDyn, mRegion4Dyn); break;
127 4282d39a Leszek Koltunski
      case VERTEX_MOVE      : effect = new VertexEffectMove        (mDyn3)                         ; break;
128
      case VERTEX_QUATERNION: effect = new VertexEffectQuaternion  (mDyn4, mCenterDyn)             ; break;
129 ad98c3cb Leszek Koltunski
      case VERTEX_ROTATE    : effect = new VertexEffectRotate      (mDyn1, mDyn3, mCenterDyn)      ; break;
130 60da87db Leszek Koltunski
      case VERTEX_SCALE     : effect = new VertexEffectScale       (mDyn3)                         ; break;
131 073c140a Leszek Koltunski
      case VERTEX_SHEAR     : effect = new VertexEffectShear       (mDyn3, mCenterDyn)             ; break;
132 1585ba24 Leszek Koltunski
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 06c636a5 Leszek Koltunski
144
      case BLUR             : effect = new PostprocessEffectBlur   (mDyn1       ); break;
145
      case GLOW             : effect = new PostprocessEffectGlow   (mDyn1, mDyn4); break;
146 06366d12 Leszek Koltunski
      }
147
148
    if( effect!=null )
149
      {
150
      effects.apply(effect);
151
      mId = effect.getID();
152 8fd9f5fa Leszek Koltunski
      }
153
    }
154
155
///////////////////////////////////////////////////////////////////////////////////////////////////
156 4282d39a Leszek Koltunski
// requires knowledge about effect nature
157 8fd9f5fa Leszek Koltunski
158
  private void fillStatics()
159
    {
160
    switch(mName)
161
      {
162 06c636a5 Leszek Koltunski
      ///////////////////////////////////////////////////////////////////////////////////////
163 4282d39a Leszek Koltunski
      // MATRIX (and VERTEX-pseudo-matrix)
164 06c636a5 Leszek Koltunski
      ///////////////////////////////////////////////////////////////////////////////////////
165
166 ad98c3cb Leszek Koltunski
      case VERTEX_ROTATE    :
167 5e23b17b Leszek Koltunski
      case ROTATE           : float an = (mInter[0]-50)*180/50.0f;
168 334c13fa Leszek Koltunski
                              float rx = (mInter[1]-50)/ 50.0f;
169
                              float ry = (mInter[2]-50)/ 50.0f;
170
                              float rz = (mInter[3]-50)/ 50.0f;
171 2a261997 Leszek Koltunski
                              mSta1.set(an);
172
                              mSta3.set(rx,ry,rz);
173 334c13fa Leszek Koltunski
                              break;
174 4282d39a Leszek Koltunski
      case VERTEX_QUATERNION:
175 7c8012ee Leszek Koltunski
      case QUATERNION       : float qx = (mInter[0]-50)/ 50.0f;
176
                              float qy = (mInter[1]-50)/ 50.0f;
177
                              float qz = (mInter[2]-50)/ 50.0f;
178 4282d39a Leszek Koltunski
                              float qw = (mInter[3]-50)*3.1415f/50;
179
                              float cosA = (float)Math.cos(qw/2);
180 7c8012ee Leszek Koltunski
                              float len = (float)Math.sqrt(qx*qx+qy*qy+qz*qz);
181 4282d39a Leszek Koltunski
                              float sinAnorm = (float)Math.sin(qw/2)/len;
182 7c8012ee Leszek Koltunski
                              mSta4.set(sinAnorm*qx,sinAnorm*qy,sinAnorm*qz, cosA);
183 334c13fa Leszek Koltunski
                              break;
184 65f622c1 Leszek Koltunski
      case MOVE             : float scr= mAct.get().getScreenWidth();
185 64f93787 Leszek Koltunski
                              float sw = scr/200.0f;
186
                              float sh = scr/200.0f;
187 fce25d04 leszek
                              float xm = (mInter[0]-50)*sw;
188
                              float ym = (mInter[1]-50)*sh;
189
                              float zm = (mInter[2]-50)*(sw+sh)/2;
190 334c13fa Leszek Koltunski
                              mSta3.set(xm,ym,zm);
191
                              break;
192 60da87db Leszek Koltunski
      case VERTEX_SCALE     :
193 df80818c Leszek Koltunski
      case SCALE            : float xs = (mInter[0]>50 ? 0.04f : 0.013f)*(mInter[0]-50) + 1;
194
                              float ys = (mInter[1]>50 ? 0.04f : 0.013f)*(mInter[1]-50) + 1;
195
                              float zs = (mInter[2]>50 ? 0.04f : 0.013f)*(mInter[2]-50) + 1;
196 334c13fa Leszek Koltunski
                              mSta3.set(xs,ys,zs);
197
                              break;
198 073c140a Leszek Koltunski
      case VERTEX_SHEAR     :
199 334c13fa Leszek Koltunski
      case SHEAR            : float xsh = (mInter[0]-50)/25.0f;
200
                              float ysh = (mInter[1]-50)/25.0f;
201
                              float zsh = (mInter[2]-50)/25.0f;
202
                              mSta3.set(xsh,ysh,zsh);
203
                              break;
204 7c8012ee Leszek Koltunski
205 06c636a5 Leszek Koltunski
      ///////////////////////////////////////////////////////////////////////////////////////
206
      // VERTEX
207
      ///////////////////////////////////////////////////////////////////////////////////////
208
209 4282d39a Leszek Koltunski
      case VERTEX_MOVE      :
210 76a81b6a Leszek Koltunski
      case DISTORT          :
211 334c13fa Leszek Koltunski
      case DEFORM           : float ld = mAct.get().getWidth()/50.0f;
212
                              float xd = (mInter[0]-50)*ld;
213
                              float yd = (mInter[1]-50)*ld;
214
                              float zd = (mInter[2]-50)*ld;
215
                              mSta3.set(xd,yd,zd);
216 76a81b6a Leszek Koltunski
                              break;
217 30e77a6c Leszek Koltunski
      case WAVE             : float l2 = mAct.get().getWidth()/50.0f;
218
                              float x2 = (mInter[0]-50)*l2;
219 2e7c7abf Leszek Koltunski
                              float y2 = (mInter[1]-50)*l2;
220 5e23b17b Leszek Koltunski
                              float z2 = (mInter[2]-50)*180 / 50.0f;
221
                              float w2 = (mInter[3]-50)*180 / 50.0f;
222
                              float v2 = (mInter[4]-50)*180 / 50.0f;
223 2f2f6176 Leszek Koltunski
                              mSta5.set(x2,y2,z2,w2,v2);
224 30e77a6c Leszek Koltunski
                              break;
225 76a81b6a Leszek Koltunski
      case SWIRL            : mSta1.set( 3.6f*(mInter[0]-50) );
226
                              break;
227 7908dbc2 Leszek Koltunski
      case SINK             : mSta1.set(mInter[0] > 50 ? 50.0f/(100.01f-mInter[0]) : mInter[0] / 50.0f);
228
                              break;
229
      case PINCH            : float dp = mInter[0] > 50 ? 50.0f/(100.01f-mInter[0]) : mInter[0] / 50.0f;
230 5e23b17b Leszek Koltunski
                              float ap = (mInter[1]-50)*180 / 50.0f;
231
                              float bp = (mInter[2]-50)*180 / 50.0f;
232
                              mSta3.set(dp,ap,bp);
233 7908dbc2 Leszek Koltunski
                              break;
234
235 06c636a5 Leszek Koltunski
      ///////////////////////////////////////////////////////////////////////////////////////
236
      // FRAGMENT
237
      ///////////////////////////////////////////////////////////////////////////////////////
238
239 76a81b6a Leszek Koltunski
      case ALPHA            :
240 889a962e Leszek Koltunski
      case SMOOTH_ALPHA     : mSta1.set(mInter[0]/100.0f);
241
                              break;
242 76a81b6a Leszek Koltunski
      case SATURATION       :
243
      case SMOOTH_SATURATION:
244
      case CONTRAST         :
245 889a962e Leszek Koltunski
      case SMOOTH_CONTRAST  :
246
      case BRIGHTNESS       :
247
      case SMOOTH_BRIGHTNESS: mSta1.set(mInter[0] > 50 ? 50.0f/(100.01f-mInter[0]) : mInter[0] / 50.0f);
248 76a81b6a Leszek Koltunski
                              break;
249
      case CHROMA           :
250
      case SMOOTH_CHROMA    : mSta1.set(mInter[0]/100.0f);
251 889a962e Leszek Koltunski
                              mSta3.set(mInter[1]/100.0f,
252
                                        mInter[2]/100.0f,
253
                                        mInter[3]/100.0f);
254 76a81b6a Leszek Koltunski
                              break;
255 06c636a5 Leszek Koltunski
256
      ///////////////////////////////////////////////////////////////////////////////////////
257
      // POSTPROCESS
258
      ///////////////////////////////////////////////////////////////////////////////////////
259
260
      case BLUR             : mSta1.set(mInter[0]/2.0f);
261
                              break;
262
      case GLOW             : mSta1.set(mInter[0]/2.0f);
263
                              mSta4.set(mInter[1]/100.0f,
264
                                        mInter[2]/100.0f,
265
                                        mInter[3]/100.0f,
266
                                        mInter[4]/100.0f );
267
                              break;
268 8fd9f5fa Leszek Koltunski
      }
269
    }
270
271
///////////////////////////////////////////////////////////////////////////////////////////////////
272
273
  private void setDefaultInter()
274
    {
275 c11a3a15 Leszek Koltunski
    switch(mDimension)
276 8fd9f5fa Leszek Koltunski
      {
277 c11a3a15 Leszek Koltunski
      case 5: mInter[4] = 50;
278
      case 4: mInter[3] = 50;
279
      case 3: mInter[2] = 50;
280
      case 2: mInter[1] = 50;
281
      case 1: mInter[0] = 50;
282 8fd9f5fa Leszek Koltunski
      }
283 334c13fa Leszek Koltunski
284 4282d39a Leszek Koltunski
    if( mName==EffectName.ROTATE         ||
285 ad98c3cb Leszek Koltunski
        mName==EffectName.VERTEX_ROTATE   )
286
      {
287
      mInter[1]= 100;
288
      }
289
    if( mName==EffectName.QUATERNION     ||
290 4282d39a Leszek Koltunski
        mName==EffectName.VERTEX_QUATERNION )
291
      {
292
      mInter[0]= 100;
293
      }
294 8fd9f5fa Leszek Koltunski
    }
295
296
///////////////////////////////////////////////////////////////////////////////////////////////////
297
298
  private void setText()
299
    {
300
    String text = mName.name();
301
302 f4e44230 Leszek Koltunski
    if( mSta1 !=null )
303 76a81b6a Leszek Koltunski
      {
304 bcbd5b45 Leszek Koltunski
      float f1 = ((int)(mSta1.get0()*100))/100.0f;
305 f4e44230 Leszek Koltunski
      text += " "+f1;
306 76a81b6a Leszek Koltunski
      }
307
308 c11a3a15 Leszek Koltunski
    if( mSta2 !=null )
309
      {
310 bcbd5b45 Leszek Koltunski
      float f1 = ((int)(mSta2.get0()*100))/100.0f;
311
      float f2 = ((int)(mSta2.get1()*100))/100.0f;
312 c11a3a15 Leszek Koltunski
      text += " ("+f1+","+f2+")";
313
      }
314
315 f4e44230 Leszek Koltunski
    if( mSta3 !=null )
316 8fd9f5fa Leszek Koltunski
      {
317 bcbd5b45 Leszek Koltunski
      float f1 = ((int)(mSta3.get0()*100))/100.0f;
318
      float f2 = ((int)(mSta3.get1()*100))/100.0f;
319
      float f3 = ((int)(mSta3.get2()*100))/100.0f;
320 8fd9f5fa Leszek Koltunski
      text += " ("+f1+","+f2+","+f3+")";
321
      }
322 f4e44230 Leszek Koltunski
323 334c13fa Leszek Koltunski
    if( mSta4 !=null )
324
      {
325 bcbd5b45 Leszek Koltunski
      float f1 = ((int)(mSta4.get0()*100))/100.0f;
326
      float f2 = ((int)(mSta4.get1()*100))/100.0f;
327
      float f3 = ((int)(mSta4.get2()*100))/100.0f;
328
      float f4 = ((int)(mSta4.get3()*100))/100.0f;
329 334c13fa Leszek Koltunski
      text += " ("+f1+","+f2+","+f3+","+f4+")";
330
      }
331
332 2f2f6176 Leszek Koltunski
    if( mSta5 !=null )
333 8fd9f5fa Leszek Koltunski
      {
334 bcbd5b45 Leszek Koltunski
      float f1 = ((int)(mSta5.get0()*100))/100.0f;
335
      float f2 = ((int)(mSta5.get1()*100))/100.0f;
336
      float f3 = ((int)(mSta5.get2()*100))/100.0f;
337
      float f4 = ((int)(mSta5.get3()*100))/100.0f;
338
      float f5 = ((int)(mSta5.get4()*100))/100.0f;
339 2f2f6176 Leszek Koltunski
      text += " ("+f1+","+f2+","+f3+","+f4+","+f5+")";
340 8fd9f5fa Leszek Koltunski
      }
341
342
    mText.setText(text);
343
    }
344
345 56cbe1cf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
346
347
  private void fillCenterStatics()
348
    {
349 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
350 fce25d04 leszek
351 529054e9 Leszek Koltunski
    float x = (mInterCenter[0]*0.012f - 0.6f)*act.getWidth();
352
    float y = (mInterCenter[1]*0.012f - 0.6f)*act.getHeight();
353
    float z = (mInterCenter[2]*0.012f - 0.6f)*act.getDepth();
354 334c13fa Leszek Koltunski
355
    mCenterSta.set(x,y,z);
356 56cbe1cf Leszek Koltunski
    }
357
358
///////////////////////////////////////////////////////////////////////////////////////////////////
359
360
  private void setDefaultCenterInter()
361
    {
362
    mInterCenter[0] = 50;
363
    mInterCenter[1] = 50;
364 334c13fa Leszek Koltunski
    mInterCenter[2] = 50;
365 56cbe1cf Leszek Koltunski
    }
366
367
///////////////////////////////////////////////////////////////////////////////////////////////////
368
369
  private void setCenterText()
370
    {
371 bcbd5b45 Leszek Koltunski
    float f0 = ((int)(mCenterSta.get0()*100))/100.0f;
372
    float f1 = ((int)(mCenterSta.get1()*100))/100.0f;
373
    float f2 = ((int)(mCenterSta.get2()*100))/100.0f;
374 56cbe1cf Leszek Koltunski
375 334c13fa Leszek Koltunski
    mTextCenter.setText("center ("+f0+","+f1+","+f2+")");
376 56cbe1cf Leszek Koltunski
    }
377
378
///////////////////////////////////////////////////////////////////////////////////////////////////
379
380
  private void fillRegionStatics()
381
    {
382 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
383 56cbe1cf Leszek Koltunski
384
    float factorX = act.getWidth() / 100.0f;
385
    float factorY = act.getHeight()/ 100.0f;
386 529054e9 Leszek Koltunski
 // float factorZ = act.getDepth() / 100.0f;
387 56cbe1cf Leszek Koltunski
388 a418b421 Leszek Koltunski
    int deduct = (mName.getType() == EffectType.VERTEX ? 50:0);
389 76a81b6a Leszek Koltunski
390 9e7b6dbd Leszek Koltunski
    float x = (mInterRegion[0]-deduct)*factorX;
391
    float y = (mInterRegion[1]-deduct)*factorY;
392
    float z = (mInterRegion[2]-deduct)*factorX;   // ??
393
    float r =  mInterRegion[3]        *(factorX+factorY)/2;
394 56cbe1cf Leszek Koltunski
395 1585ba24 Leszek Koltunski
    mRegion4Sta.set(x,y,z,r);
396
    mRegion3Sta.set(x,y,z);
397 56cbe1cf Leszek Koltunski
    }
398
399
///////////////////////////////////////////////////////////////////////////////////////////////////
400
401
  private void setDefaultRegionInter()
402
    {
403
    mInterRegion[0] = 50;
404
    mInterRegion[1] = 50;
405
    mInterRegion[2] = 50;
406
    mInterRegion[3] = 50;
407
    }
408
409
///////////////////////////////////////////////////////////////////////////////////////////////////
410
411
  private void setRegionText()
412
    {
413 1585ba24 Leszek Koltunski
    if( mRegionDimension==4 )
414
      {
415 bcbd5b45 Leszek Koltunski
      float f0 = ((int)(mRegion4Sta.get0()*100))/100.0f;
416
      float f1 = ((int)(mRegion4Sta.get1()*100))/100.0f;
417
      float f2 = ((int)(mRegion4Sta.get2()*100))/100.0f;
418
      float f3 = ((int)(mRegion4Sta.get3()*100))/100.0f;
419 1585ba24 Leszek Koltunski
420
      mTextRegion.setText("region (" + f0 + "," + f1 + "," + f2 + "," + f3 + ")");
421
      }
422 56cbe1cf Leszek Koltunski
423 1585ba24 Leszek Koltunski
    if( mRegionDimension==3 )
424
      {
425 bcbd5b45 Leszek Koltunski
      float f0 = ((int)(mRegion4Sta.get0()*100))/100.0f;
426
      float f1 = ((int)(mRegion4Sta.get1()*100))/100.0f;
427
      float f2 = ((int)(mRegion4Sta.get2()*100))/100.0f;
428 1585ba24 Leszek Koltunski
429
      mTextRegion.setText("region (" + f0 + "," + f1 + "," + f2 + ")");
430
      }
431 56cbe1cf Leszek Koltunski
    }
432
433 3b1e9c7e Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
434
435
  void setBackground(int pos)
436
    {
437
    int color = (pos%2==1 ? BACKGROUND_ODD:BACKGROUND_EVEN);
438
439
    if( mEffect!=null ) mEffect.setBackgroundColor(color);
440
    if( mCenter!=null ) mCenter.setBackgroundColor(color);
441
    if( mRegion!=null ) mRegion.setBackgroundColor(color);
442
    }
443
444 56cbe1cf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
445
446 46b26cdc Leszek Koltunski
  GenericEffect(EffectName name, GenericActivity2 act)
447 56cbe1cf Leszek Koltunski
    {
448
    mAct = new WeakReference<>(act);
449
    mName = name;
450
451 f4e44230 Leszek Koltunski
    mDyn1 = null;
452 c11a3a15 Leszek Koltunski
    mDyn2 = null;
453 f4e44230 Leszek Koltunski
    mDyn3 = null;
454 334c13fa Leszek Koltunski
    mDyn4 = null;
455 2f2f6176 Leszek Koltunski
    mDyn5 = null;
456 f4e44230 Leszek Koltunski
    mSta1 = null;
457 c11a3a15 Leszek Koltunski
    mSta2 = null;
458 f4e44230 Leszek Koltunski
    mSta3 = null;
459 334c13fa Leszek Koltunski
    mSta4 = null;
460 2f2f6176 Leszek Koltunski
    mSta5 = null;
461 f4e44230 Leszek Koltunski
462 1585ba24 Leszek Koltunski
    mDimension = mName.getEffectDimension();
463
    mRegionDimension = mName.getRegionDimension();
464 8fd9f5fa Leszek Koltunski
465 76a81b6a Leszek Koltunski
    switch(mDimension)
466 8fd9f5fa Leszek Koltunski
      {
467 76a81b6a Leszek Koltunski
      case 1 : mDyn1 = new Dynamic1D();
468
               mSta1 = new Static1D(0);
469
               mDyn1.add(mSta1);
470
               break;
471 c11a3a15 Leszek Koltunski
      case 2 : mDyn2 = new Dynamic2D();
472
               mSta2 = new Static2D(0,0);
473
               mDyn2.add(mSta2);
474
               break;
475 76a81b6a Leszek Koltunski
      case 3 : mDyn3 = new Dynamic3D();
476
               mSta3 = new Static3D(0,0,0);
477
               mDyn3.add(mSta3);
478
               break;
479 4282d39a Leszek Koltunski
      case 4 : if( mName == EffectName.QUATERNION || mName == EffectName.VERTEX_QUATERNION )
480 334c13fa Leszek Koltunski
                 {
481
                 mDyn4 = new Dynamic4D();
482
                 mSta4 = new Static4D(0,0,0,0);
483
                 mDyn4.add(mSta4);
484
                 }
485
               else
486
                 {
487
                 mDyn3 = new Dynamic3D();
488
                 mSta3 = new Static3D(0,0,0);
489
                 mDyn3.add(mSta3);
490
                 mDyn1 = new Dynamic1D();
491
                 mSta1 = new Static1D(0);
492
                 mDyn1.add(mSta1);
493
                 }
494 2f2f6176 Leszek Koltunski
               break;
495 06c636a5 Leszek Koltunski
      case 5 : if( mName == EffectName.WAVE )
496
                 {
497
                 mDyn5 = new Dynamic5D();
498
                 mSta5 = new Static5D(0, 0, 0, 0, 0);
499
                 mDyn5.add(mSta5);
500
                 }
501
               else
502
                 {
503
                 mDyn4 = new Dynamic4D();
504
                 mSta4 = new Static4D(0,0,0,0);
505
                 mDyn4.add(mSta4);
506
                 mDyn1 = new Dynamic1D();
507
                 mSta1 = new Static1D(0);
508
                 mDyn1.add(mSta1);
509
                 }
510 76a81b6a Leszek Koltunski
               break;
511
      default: throw new RuntimeException("unsupported effect");
512 8fd9f5fa Leszek Koltunski
      }
513 56cbe1cf Leszek Koltunski
514
    mInter = new int[mDimension];
515
    mSeekID= new int[mDimension];
516
517
    mInterRegion = new int[4];
518
    mSeekRegionID= new int[4];
519 1585ba24 Leszek Koltunski
    mRegion4Dyn  = new Dynamic4D();
520
    mRegion4Sta  = new Static4D(0,0,0,0);
521
    mRegion4Dyn.add(mRegion4Sta);
522
    mRegion3Dyn  = new Dynamic3D();
523
    mRegion3Sta  = new Static3D(0,0,0);
524
    mRegion3Dyn.add(mRegion3Sta);
525 56cbe1cf Leszek Koltunski
526 334c13fa Leszek Koltunski
    mInterCenter = new int[3];
527
    mSeekCenterID= new int[3];
528
    mCenterDyn   = new Dynamic3D();
529
    mCenterSta   = new Static3D(0,0,0);
530 56cbe1cf Leszek Koltunski
    mCenterDyn.add(mCenterSta);
531 fed00329 Leszek Koltunski
532
    mButton = null;
533
    mEffect = null;
534
    mCenter = null;
535
    mRegion = null;
536 56cbe1cf Leszek Koltunski
    }
537
538
///////////////////////////////////////////////////////////////////////////////////////////////////
539
540 3b1e9c7e Leszek Koltunski
  View createView(int num)
541 56cbe1cf Leszek Koltunski
    {
542
    SeekBar[] seek = new SeekBar[mDimension];
543
544 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
545 56cbe1cf Leszek Koltunski
546
    switch(mDimension)
547
      {
548 fed00329 Leszek Koltunski
      case 1 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect1d, null);
549 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect1dText);
550
               seek[0]    = mEffect.findViewById(R.id.effect1dbar1);
551 56cbe1cf Leszek Koltunski
               mSeekID[0] = seek[0].getId();
552 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button1dRemove);
553 56cbe1cf Leszek Koltunski
               break;
554 fed00329 Leszek Koltunski
      case 2 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect2d, null);
555 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect2dText);
556
               seek[0]    = mEffect.findViewById(R.id.effect2dbar1);
557
               seek[1]    = mEffect.findViewById(R.id.effect2dbar2);
558 56cbe1cf Leszek Koltunski
               mSeekID[0] = seek[0].getId();
559
               mSeekID[1] = seek[1].getId();
560 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button2dRemove);
561 56cbe1cf Leszek Koltunski
               break;
562 fed00329 Leszek Koltunski
      case 3 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect3d, null);
563 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect3dText);
564
               seek[0]    = mEffect.findViewById(R.id.effect3dbar1);
565
               seek[1]    = mEffect.findViewById(R.id.effect3dbar2);
566
               seek[2]    = mEffect.findViewById(R.id.effect3dbar3);
567 56cbe1cf Leszek Koltunski
               mSeekID[0] = seek[0].getId();
568
               mSeekID[1] = seek[1].getId();
569
               mSeekID[2] = seek[2].getId();
570 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button3dRemove);
571 56cbe1cf Leszek Koltunski
               break;
572 fed00329 Leszek Koltunski
      case 4 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect4d, null);
573 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect4dText);
574
               seek[0]    = mEffect.findViewById(R.id.effect4dbar1);
575
               seek[1]    = mEffect.findViewById(R.id.effect4dbar2);
576
               seek[2]    = mEffect.findViewById(R.id.effect4dbar3);
577
               seek[3]    = mEffect.findViewById(R.id.effect4dbar4);
578 56cbe1cf Leszek Koltunski
               mSeekID[0] = seek[0].getId();
579
               mSeekID[1] = seek[1].getId();
580
               mSeekID[2] = seek[2].getId();
581
               mSeekID[3] = seek[3].getId();
582 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button4dRemove);
583 56cbe1cf Leszek Koltunski
               break;
584 fed00329 Leszek Koltunski
      case 5 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect5d, null);
585 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect5dText);
586
               seek[0]    = mEffect.findViewById(R.id.effect5dbar1);
587
               seek[1]    = mEffect.findViewById(R.id.effect5dbar2);
588
               seek[2]    = mEffect.findViewById(R.id.effect5dbar3);
589
               seek[3]    = mEffect.findViewById(R.id.effect5dbar4);
590
               seek[4]    = mEffect.findViewById(R.id.effect5dbar5);
591 2f2f6176 Leszek Koltunski
               mSeekID[0] = seek[0].getId();
592
               mSeekID[1] = seek[1].getId();
593
               mSeekID[2] = seek[2].getId();
594
               mSeekID[3] = seek[3].getId();
595
               mSeekID[4] = seek[4].getId();
596 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button5dRemove);
597 2f2f6176 Leszek Koltunski
               break;
598 46b26cdc Leszek Koltunski
      default: android.util.Log.e("GenericEffect", "dimension "+mDimension+" not supported!");
599 56cbe1cf Leszek Koltunski
               return null;
600
      }
601
602 3b1e9c7e Leszek Koltunski
    mEffect.setBackgroundColor( num%2==1 ? BACKGROUND_EVEN: BACKGROUND_ODD );
603
604 56cbe1cf Leszek Koltunski
    setDefaultInter();
605
606
    for(int i=0; i<mDimension; i++)
607
      {
608
      seek[i].setOnSeekBarChangeListener(this);
609
      seek[i].setProgress( mInter[i] );
610
      }
611
612 fed00329 Leszek Koltunski
    return mEffect;
613 56cbe1cf Leszek Koltunski
    }
614
615
///////////////////////////////////////////////////////////////////////////////////////////////////
616
617 3b1e9c7e Leszek Koltunski
  View createRegion(int num)
618 56cbe1cf Leszek Koltunski
    {
619 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
620 56cbe1cf Leszek Koltunski
621 1585ba24 Leszek Koltunski
    if( mRegionDimension== 4 )
622
      {
623
      mRegion = act.getLayoutInflater().inflate(R.layout.effectregion4, null);
624
      mRegion.setBackgroundColor(num % 2 == 1 ? BACKGROUND_EVEN : BACKGROUND_ODD);
625 56cbe1cf Leszek Koltunski
626 1585ba24 Leszek Koltunski
      SeekBar[] seek = new SeekBar[4];
627 56cbe1cf Leszek Koltunski
628 1585ba24 Leszek Koltunski
      seek[0] = mRegion.findViewById(R.id.effectRegion4BarX);
629
      seek[1] = mRegion.findViewById(R.id.effectRegion4BarY);
630
      seek[2] = mRegion.findViewById(R.id.effectRegion4BarZ);
631
      seek[3] = mRegion.findViewById(R.id.effectRegion4BarR);
632 56cbe1cf Leszek Koltunski
633 1585ba24 Leszek Koltunski
      mSeekRegionID[0] = seek[0].getId();
634
      mSeekRegionID[1] = seek[1].getId();
635
      mSeekRegionID[2] = seek[2].getId();
636
      mSeekRegionID[3] = seek[3].getId();
637 56cbe1cf Leszek Koltunski
638 1585ba24 Leszek Koltunski
      mTextRegion = mRegion.findViewById(R.id.effectRegion4Text);
639 56cbe1cf Leszek Koltunski
640 1585ba24 Leszek Koltunski
      setDefaultRegionInter();
641 56cbe1cf Leszek Koltunski
642 1585ba24 Leszek Koltunski
      for (int i = 0; i < 4; i++)
643
        {
644
        seek[i].setOnSeekBarChangeListener(this);
645
        seek[i].setProgress(mInterRegion[i]);
646
        }
647
648 1e7603bb Leszek Koltunski
      act.setRegion(mRegion4Sta);
649 56cbe1cf Leszek Koltunski
      }
650 1585ba24 Leszek Koltunski
    else
651
      {
652
      mRegion = act.getLayoutInflater().inflate(R.layout.effectregion3, null);
653
      mRegion.setBackgroundColor(num % 2 == 1 ? BACKGROUND_EVEN : BACKGROUND_ODD);
654
655
      SeekBar[] seek = new SeekBar[3];
656
657
      seek[0] = mRegion.findViewById(R.id.effectRegion3BarRX);
658
      seek[1] = mRegion.findViewById(R.id.effectRegion3BarRY);
659
      seek[2] = mRegion.findViewById(R.id.effectRegion3BarRZ);
660
661
      mSeekRegionID[0] = seek[0].getId();
662
      mSeekRegionID[1] = seek[1].getId();
663
      mSeekRegionID[2] = seek[2].getId();
664
665
      mTextRegion = mRegion.findViewById(R.id.effectRegion3Text);
666 56cbe1cf Leszek Koltunski
667 1585ba24 Leszek Koltunski
      setDefaultRegionInter();
668
669
      for (int i = 0; i < 3; i++)
670
        {
671
        seek[i].setOnSeekBarChangeListener(this);
672
        seek[i].setProgress(mInterRegion[i]);
673
        }
674
675 bcbd5b45 Leszek Koltunski
      act.setRegion( new Static4D( mRegion3Sta.get0(), mRegion3Sta.get1(), mRegion3Sta.get2(), 1.0f) );
676 1585ba24 Leszek Koltunski
      }
677 24991bc2 Leszek Koltunski
678 fed00329 Leszek Koltunski
    return mRegion;
679 56cbe1cf Leszek Koltunski
    }
680
681
///////////////////////////////////////////////////////////////////////////////////////////////////
682
683 3b1e9c7e Leszek Koltunski
  View createCenter(int num)
684 56cbe1cf Leszek Koltunski
    {
685 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
686 56cbe1cf Leszek Koltunski
687 fed00329 Leszek Koltunski
    mCenter = act.getLayoutInflater().inflate(R.layout.effectcenter, null);
688 3b1e9c7e Leszek Koltunski
    mCenter.setBackgroundColor( num%2==1 ? BACKGROUND_EVEN: BACKGROUND_ODD );
689 56cbe1cf Leszek Koltunski
690 334c13fa Leszek Koltunski
    SeekBar[] seek = new SeekBar[3];
691 56cbe1cf Leszek Koltunski
692 fe7fe83e Leszek Koltunski
    seek[0] = mCenter.findViewById(R.id.effectCenterBarX );
693
    seek[1] = mCenter.findViewById(R.id.effectCenterBarY );
694
    seek[2] = mCenter.findViewById(R.id.effectCenterBarZ );
695 56cbe1cf Leszek Koltunski
696
    mSeekCenterID[0] = seek[0].getId();
697
    mSeekCenterID[1] = seek[1].getId();
698 334c13fa Leszek Koltunski
    mSeekCenterID[2] = seek[2].getId();
699 56cbe1cf Leszek Koltunski
700 fe7fe83e Leszek Koltunski
    mTextCenter = mCenter.findViewById(R.id.effectCenterText);
701 56cbe1cf Leszek Koltunski
702
    setDefaultCenterInter();
703
704 334c13fa Leszek Koltunski
    for(int i=0; i<3; i++)
705 56cbe1cf Leszek Koltunski
      {
706
      seek[i].setOnSeekBarChangeListener(this);
707
      seek[i].setProgress( mInterCenter[i] );
708
      }
709
710 1e7603bb Leszek Koltunski
    act.setCenter(mCenterSta);
711 24991bc2 Leszek Koltunski
712 fed00329 Leszek Koltunski
    return mCenter;
713 56cbe1cf Leszek Koltunski
    }
714
715
///////////////////////////////////////////////////////////////////////////////////////////////////
716
717
  public void onProgressChanged(SeekBar bar, int progress, boolean fromUser)
718
    {
719 4282d39a Leszek Koltunski
    boolean vectorChanged=false;
720
    boolean regionChanged=false;
721
    boolean centerChanged=false;
722
723
    for(int dim=0; dim<5; dim++)
724 56cbe1cf Leszek Koltunski
      {
725 4282d39a Leszek Koltunski
      if ( mDimension>dim && bar.getId()==mSeekID[dim] )
726
        {
727
        mInter[dim] = progress;
728
        vectorChanged = true;
729
        }
730 56cbe1cf Leszek Koltunski
      }
731 4282d39a Leszek Koltunski
732
    if( vectorChanged )
733 2f2f6176 Leszek Koltunski
      {
734
      fillStatics();
735
      setText();
736
      }
737 56cbe1cf Leszek Koltunski
738 4282d39a Leszek Koltunski
    for(int reg=0; reg<4; reg++)
739 56cbe1cf Leszek Koltunski
      {
740 4282d39a Leszek Koltunski
      if( mRegionDimension>reg && bar.getId() == mSeekRegionID[reg] )
741
        {
742
        mInterRegion[reg] = progress;
743
        regionChanged = true;
744
        }
745 56cbe1cf Leszek Koltunski
      }
746 4282d39a Leszek Koltunski
747
    if( regionChanged )
748 56cbe1cf Leszek Koltunski
      {
749
      fillRegionStatics();
750
      setRegionText();
751
      }
752
753 4282d39a Leszek Koltunski
    for(int cen=0; cen<3; cen++)
754 56cbe1cf Leszek Koltunski
      {
755 4282d39a Leszek Koltunski
      if( bar.getId() == mSeekCenterID[cen] )
756
        {
757
        mInterCenter[cen] = progress;
758
        centerChanged = true;
759
        }
760 56cbe1cf Leszek Koltunski
      }
761 4282d39a Leszek Koltunski
762
    if( centerChanged )
763 334c13fa Leszek Koltunski
      {
764
      fillCenterStatics();
765
      setCenterText();
766
      }
767 24991bc2 Leszek Koltunski
768
    if( fromUser )
769
      {
770 46b26cdc Leszek Koltunski
      GenericActivity2 act = mAct.get();
771 1e7603bb Leszek Koltunski
      act.setCenter(mCenterSta);
772
      act.setRegion(mRegion4Sta);
773 24991bc2 Leszek Koltunski
      }
774 56cbe1cf Leszek Koltunski
    }
775
776 fa9053f5 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
777
778 6f3024ae Leszek Koltunski
  boolean thisView(View v)
779 fa9053f5 Leszek Koltunski
    {
780
    return v==mButton;
781
    }
782
783 fed00329 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
784
785
  public long getId()
786
    {
787
    return mId;
788
    }
789
790 d28ddc9b Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
791
792
  public int getDimension()
793
    {
794
    return mDimension;
795
    }
796
797 fed00329 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
798
799
  public View getEffect()
800
    {
801
    return mEffect;
802
    }
803
804
///////////////////////////////////////////////////////////////////////////////////////////////////
805
806
  public View getRegion()
807
    {
808
    return mRegion;
809
    }
810
811
///////////////////////////////////////////////////////////////////////////////////////////////////
812
813
  public View getCenter()
814
    {
815
    return mCenter;
816
    }
817
818 56cbe1cf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
819
820
  public void onStartTrackingTouch(SeekBar bar) { }
821
822
///////////////////////////////////////////////////////////////////////////////////////////////////
823
824
  public void onStopTrackingTouch(SeekBar bar)  { }
825
  }