Project

General

Profile

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

examples / src / main / java / org / distorted / examples / generic / GenericEffect.java @ fc286c71

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 fc286c71 Leszek Koltunski
    if( mName.getType() == EffectType.MATRIX )
356
      {
357
      float factor = act.getScaleFactor();
358
      x *= factor;
359
      y *= factor;
360
      z *= factor;
361
      }
362
363 334c13fa Leszek Koltunski
    mCenterSta.set(x,y,z);
364 56cbe1cf Leszek Koltunski
    }
365
366
///////////////////////////////////////////////////////////////////////////////////////////////////
367
368
  private void setDefaultCenterInter()
369
    {
370
    mInterCenter[0] = 50;
371
    mInterCenter[1] = 50;
372 334c13fa Leszek Koltunski
    mInterCenter[2] = 50;
373 56cbe1cf Leszek Koltunski
    }
374
375
///////////////////////////////////////////////////////////////////////////////////////////////////
376
377
  private void setCenterText()
378
    {
379 bcbd5b45 Leszek Koltunski
    float f0 = ((int)(mCenterSta.get0()*100))/100.0f;
380
    float f1 = ((int)(mCenterSta.get1()*100))/100.0f;
381
    float f2 = ((int)(mCenterSta.get2()*100))/100.0f;
382 56cbe1cf Leszek Koltunski
383 334c13fa Leszek Koltunski
    mTextCenter.setText("center ("+f0+","+f1+","+f2+")");
384 56cbe1cf Leszek Koltunski
    }
385
386
///////////////////////////////////////////////////////////////////////////////////////////////////
387
388
  private void fillRegionStatics()
389
    {
390 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
391 56cbe1cf Leszek Koltunski
392
    float factorX = act.getWidth() / 100.0f;
393
    float factorY = act.getHeight()/ 100.0f;
394 529054e9 Leszek Koltunski
 // float factorZ = act.getDepth() / 100.0f;
395 56cbe1cf Leszek Koltunski
396 a418b421 Leszek Koltunski
    int deduct = (mName.getType() == EffectType.VERTEX ? 50:0);
397 76a81b6a Leszek Koltunski
398 9e7b6dbd Leszek Koltunski
    float x = (mInterRegion[0]-deduct)*factorX;
399
    float y = (mInterRegion[1]-deduct)*factorY;
400
    float z = (mInterRegion[2]-deduct)*factorX;   // ??
401
    float r =  mInterRegion[3]        *(factorX+factorY)/2;
402 56cbe1cf Leszek Koltunski
403 1585ba24 Leszek Koltunski
    mRegion4Sta.set(x,y,z,r);
404
    mRegion3Sta.set(x,y,z);
405 56cbe1cf Leszek Koltunski
    }
406
407
///////////////////////////////////////////////////////////////////////////////////////////////////
408
409
  private void setDefaultRegionInter()
410
    {
411
    mInterRegion[0] = 50;
412
    mInterRegion[1] = 50;
413
    mInterRegion[2] = 50;
414
    mInterRegion[3] = 50;
415
    }
416
417
///////////////////////////////////////////////////////////////////////////////////////////////////
418
419
  private void setRegionText()
420
    {
421 1585ba24 Leszek Koltunski
    if( mRegionDimension==4 )
422
      {
423 bcbd5b45 Leszek Koltunski
      float f0 = ((int)(mRegion4Sta.get0()*100))/100.0f;
424
      float f1 = ((int)(mRegion4Sta.get1()*100))/100.0f;
425
      float f2 = ((int)(mRegion4Sta.get2()*100))/100.0f;
426
      float f3 = ((int)(mRegion4Sta.get3()*100))/100.0f;
427 1585ba24 Leszek Koltunski
428
      mTextRegion.setText("region (" + f0 + "," + f1 + "," + f2 + "," + f3 + ")");
429
      }
430 56cbe1cf Leszek Koltunski
431 1585ba24 Leszek Koltunski
    if( mRegionDimension==3 )
432
      {
433 bcbd5b45 Leszek Koltunski
      float f0 = ((int)(mRegion4Sta.get0()*100))/100.0f;
434
      float f1 = ((int)(mRegion4Sta.get1()*100))/100.0f;
435
      float f2 = ((int)(mRegion4Sta.get2()*100))/100.0f;
436 1585ba24 Leszek Koltunski
437
      mTextRegion.setText("region (" + f0 + "," + f1 + "," + f2 + ")");
438
      }
439 56cbe1cf Leszek Koltunski
    }
440
441 fc286c71 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
442
443
  private void setCenter(GenericActivity2 act)
444
    {
445
    float factor = ( mName.getType() == EffectType.MATRIX ? act.getScaleFactor() : 1.0f);
446
    act.setCenter( mCenterSta.get0()/factor, mCenterSta.get1()/factor, mCenterSta.get2()/factor );
447
    }
448
449 3b1e9c7e Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
450
451
  void setBackground(int pos)
452
    {
453
    int color = (pos%2==1 ? BACKGROUND_ODD:BACKGROUND_EVEN);
454
455
    if( mEffect!=null ) mEffect.setBackgroundColor(color);
456
    if( mCenter!=null ) mCenter.setBackgroundColor(color);
457
    if( mRegion!=null ) mRegion.setBackgroundColor(color);
458
    }
459
460 56cbe1cf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
461
462 46b26cdc Leszek Koltunski
  GenericEffect(EffectName name, GenericActivity2 act)
463 56cbe1cf Leszek Koltunski
    {
464
    mAct = new WeakReference<>(act);
465
    mName = name;
466
467 f4e44230 Leszek Koltunski
    mDyn1 = null;
468 c11a3a15 Leszek Koltunski
    mDyn2 = null;
469 f4e44230 Leszek Koltunski
    mDyn3 = null;
470 334c13fa Leszek Koltunski
    mDyn4 = null;
471 2f2f6176 Leszek Koltunski
    mDyn5 = null;
472 f4e44230 Leszek Koltunski
    mSta1 = null;
473 c11a3a15 Leszek Koltunski
    mSta2 = null;
474 f4e44230 Leszek Koltunski
    mSta3 = null;
475 334c13fa Leszek Koltunski
    mSta4 = null;
476 2f2f6176 Leszek Koltunski
    mSta5 = null;
477 f4e44230 Leszek Koltunski
478 1585ba24 Leszek Koltunski
    mDimension = mName.getEffectDimension();
479
    mRegionDimension = mName.getRegionDimension();
480 8fd9f5fa Leszek Koltunski
481 76a81b6a Leszek Koltunski
    switch(mDimension)
482 8fd9f5fa Leszek Koltunski
      {
483 76a81b6a Leszek Koltunski
      case 1 : mDyn1 = new Dynamic1D();
484
               mSta1 = new Static1D(0);
485
               mDyn1.add(mSta1);
486
               break;
487 c11a3a15 Leszek Koltunski
      case 2 : mDyn2 = new Dynamic2D();
488
               mSta2 = new Static2D(0,0);
489
               mDyn2.add(mSta2);
490
               break;
491 76a81b6a Leszek Koltunski
      case 3 : mDyn3 = new Dynamic3D();
492
               mSta3 = new Static3D(0,0,0);
493
               mDyn3.add(mSta3);
494
               break;
495 4282d39a Leszek Koltunski
      case 4 : if( mName == EffectName.QUATERNION || mName == EffectName.VERTEX_QUATERNION )
496 334c13fa Leszek Koltunski
                 {
497
                 mDyn4 = new Dynamic4D();
498
                 mSta4 = new Static4D(0,0,0,0);
499
                 mDyn4.add(mSta4);
500
                 }
501
               else
502
                 {
503
                 mDyn3 = new Dynamic3D();
504
                 mSta3 = new Static3D(0,0,0);
505
                 mDyn3.add(mSta3);
506
                 mDyn1 = new Dynamic1D();
507
                 mSta1 = new Static1D(0);
508
                 mDyn1.add(mSta1);
509
                 }
510 2f2f6176 Leszek Koltunski
               break;
511 06c636a5 Leszek Koltunski
      case 5 : if( mName == EffectName.WAVE )
512
                 {
513
                 mDyn5 = new Dynamic5D();
514
                 mSta5 = new Static5D(0, 0, 0, 0, 0);
515
                 mDyn5.add(mSta5);
516
                 }
517
               else
518
                 {
519
                 mDyn4 = new Dynamic4D();
520
                 mSta4 = new Static4D(0,0,0,0);
521
                 mDyn4.add(mSta4);
522
                 mDyn1 = new Dynamic1D();
523
                 mSta1 = new Static1D(0);
524
                 mDyn1.add(mSta1);
525
                 }
526 76a81b6a Leszek Koltunski
               break;
527
      default: throw new RuntimeException("unsupported effect");
528 8fd9f5fa Leszek Koltunski
      }
529 56cbe1cf Leszek Koltunski
530
    mInter = new int[mDimension];
531
    mSeekID= new int[mDimension];
532
533
    mInterRegion = new int[4];
534
    mSeekRegionID= new int[4];
535 1585ba24 Leszek Koltunski
    mRegion4Dyn  = new Dynamic4D();
536
    mRegion4Sta  = new Static4D(0,0,0,0);
537
    mRegion4Dyn.add(mRegion4Sta);
538
    mRegion3Dyn  = new Dynamic3D();
539
    mRegion3Sta  = new Static3D(0,0,0);
540
    mRegion3Dyn.add(mRegion3Sta);
541 56cbe1cf Leszek Koltunski
542 334c13fa Leszek Koltunski
    mInterCenter = new int[3];
543
    mSeekCenterID= new int[3];
544
    mCenterDyn   = new Dynamic3D();
545
    mCenterSta   = new Static3D(0,0,0);
546 56cbe1cf Leszek Koltunski
    mCenterDyn.add(mCenterSta);
547 fed00329 Leszek Koltunski
548
    mButton = null;
549
    mEffect = null;
550
    mCenter = null;
551
    mRegion = null;
552 56cbe1cf Leszek Koltunski
    }
553
554
///////////////////////////////////////////////////////////////////////////////////////////////////
555
556 3b1e9c7e Leszek Koltunski
  View createView(int num)
557 56cbe1cf Leszek Koltunski
    {
558
    SeekBar[] seek = new SeekBar[mDimension];
559
560 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
561 56cbe1cf Leszek Koltunski
562
    switch(mDimension)
563
      {
564 fed00329 Leszek Koltunski
      case 1 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect1d, null);
565 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect1dText);
566
               seek[0]    = mEffect.findViewById(R.id.effect1dbar1);
567 56cbe1cf Leszek Koltunski
               mSeekID[0] = seek[0].getId();
568 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button1dRemove);
569 56cbe1cf Leszek Koltunski
               break;
570 fed00329 Leszek Koltunski
      case 2 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect2d, null);
571 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect2dText);
572
               seek[0]    = mEffect.findViewById(R.id.effect2dbar1);
573
               seek[1]    = mEffect.findViewById(R.id.effect2dbar2);
574 56cbe1cf Leszek Koltunski
               mSeekID[0] = seek[0].getId();
575
               mSeekID[1] = seek[1].getId();
576 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button2dRemove);
577 56cbe1cf Leszek Koltunski
               break;
578 fed00329 Leszek Koltunski
      case 3 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect3d, null);
579 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect3dText);
580
               seek[0]    = mEffect.findViewById(R.id.effect3dbar1);
581
               seek[1]    = mEffect.findViewById(R.id.effect3dbar2);
582
               seek[2]    = mEffect.findViewById(R.id.effect3dbar3);
583 56cbe1cf Leszek Koltunski
               mSeekID[0] = seek[0].getId();
584
               mSeekID[1] = seek[1].getId();
585
               mSeekID[2] = seek[2].getId();
586 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button3dRemove);
587 56cbe1cf Leszek Koltunski
               break;
588 fed00329 Leszek Koltunski
      case 4 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect4d, null);
589 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect4dText);
590
               seek[0]    = mEffect.findViewById(R.id.effect4dbar1);
591
               seek[1]    = mEffect.findViewById(R.id.effect4dbar2);
592
               seek[2]    = mEffect.findViewById(R.id.effect4dbar3);
593
               seek[3]    = mEffect.findViewById(R.id.effect4dbar4);
594 56cbe1cf Leszek Koltunski
               mSeekID[0] = seek[0].getId();
595
               mSeekID[1] = seek[1].getId();
596
               mSeekID[2] = seek[2].getId();
597
               mSeekID[3] = seek[3].getId();
598 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button4dRemove);
599 56cbe1cf Leszek Koltunski
               break;
600 fed00329 Leszek Koltunski
      case 5 : mEffect    = act.getLayoutInflater().inflate(R.layout.effect5d, null);
601 fe7fe83e Leszek Koltunski
               mText      = mEffect.findViewById(R.id.effect5dText);
602
               seek[0]    = mEffect.findViewById(R.id.effect5dbar1);
603
               seek[1]    = mEffect.findViewById(R.id.effect5dbar2);
604
               seek[2]    = mEffect.findViewById(R.id.effect5dbar3);
605
               seek[3]    = mEffect.findViewById(R.id.effect5dbar4);
606
               seek[4]    = mEffect.findViewById(R.id.effect5dbar5);
607 2f2f6176 Leszek Koltunski
               mSeekID[0] = seek[0].getId();
608
               mSeekID[1] = seek[1].getId();
609
               mSeekID[2] = seek[2].getId();
610
               mSeekID[3] = seek[3].getId();
611
               mSeekID[4] = seek[4].getId();
612 fed00329 Leszek Koltunski
               mButton    = mEffect.findViewById(R.id.button5dRemove);
613 2f2f6176 Leszek Koltunski
               break;
614 46b26cdc Leszek Koltunski
      default: android.util.Log.e("GenericEffect", "dimension "+mDimension+" not supported!");
615 56cbe1cf Leszek Koltunski
               return null;
616
      }
617
618 3b1e9c7e Leszek Koltunski
    mEffect.setBackgroundColor( num%2==1 ? BACKGROUND_EVEN: BACKGROUND_ODD );
619
620 56cbe1cf Leszek Koltunski
    setDefaultInter();
621
622
    for(int i=0; i<mDimension; i++)
623
      {
624
      seek[i].setOnSeekBarChangeListener(this);
625
      seek[i].setProgress( mInter[i] );
626
      }
627
628 fed00329 Leszek Koltunski
    return mEffect;
629 56cbe1cf Leszek Koltunski
    }
630
631
///////////////////////////////////////////////////////////////////////////////////////////////////
632
633 3b1e9c7e Leszek Koltunski
  View createRegion(int num)
634 56cbe1cf Leszek Koltunski
    {
635 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
636 56cbe1cf Leszek Koltunski
637 1585ba24 Leszek Koltunski
    if( mRegionDimension== 4 )
638
      {
639
      mRegion = act.getLayoutInflater().inflate(R.layout.effectregion4, null);
640
      mRegion.setBackgroundColor(num % 2 == 1 ? BACKGROUND_EVEN : BACKGROUND_ODD);
641 56cbe1cf Leszek Koltunski
642 1585ba24 Leszek Koltunski
      SeekBar[] seek = new SeekBar[4];
643 56cbe1cf Leszek Koltunski
644 1585ba24 Leszek Koltunski
      seek[0] = mRegion.findViewById(R.id.effectRegion4BarX);
645
      seek[1] = mRegion.findViewById(R.id.effectRegion4BarY);
646
      seek[2] = mRegion.findViewById(R.id.effectRegion4BarZ);
647
      seek[3] = mRegion.findViewById(R.id.effectRegion4BarR);
648 56cbe1cf Leszek Koltunski
649 1585ba24 Leszek Koltunski
      mSeekRegionID[0] = seek[0].getId();
650
      mSeekRegionID[1] = seek[1].getId();
651
      mSeekRegionID[2] = seek[2].getId();
652
      mSeekRegionID[3] = seek[3].getId();
653 56cbe1cf Leszek Koltunski
654 1585ba24 Leszek Koltunski
      mTextRegion = mRegion.findViewById(R.id.effectRegion4Text);
655 56cbe1cf Leszek Koltunski
656 1585ba24 Leszek Koltunski
      setDefaultRegionInter();
657 56cbe1cf Leszek Koltunski
658 1585ba24 Leszek Koltunski
      for (int i = 0; i < 4; i++)
659
        {
660
        seek[i].setOnSeekBarChangeListener(this);
661
        seek[i].setProgress(mInterRegion[i]);
662
        }
663
664 1e7603bb Leszek Koltunski
      act.setRegion(mRegion4Sta);
665 56cbe1cf Leszek Koltunski
      }
666 1585ba24 Leszek Koltunski
    else
667
      {
668
      mRegion = act.getLayoutInflater().inflate(R.layout.effectregion3, null);
669
      mRegion.setBackgroundColor(num % 2 == 1 ? BACKGROUND_EVEN : BACKGROUND_ODD);
670
671
      SeekBar[] seek = new SeekBar[3];
672
673
      seek[0] = mRegion.findViewById(R.id.effectRegion3BarRX);
674
      seek[1] = mRegion.findViewById(R.id.effectRegion3BarRY);
675
      seek[2] = mRegion.findViewById(R.id.effectRegion3BarRZ);
676
677
      mSeekRegionID[0] = seek[0].getId();
678
      mSeekRegionID[1] = seek[1].getId();
679
      mSeekRegionID[2] = seek[2].getId();
680
681
      mTextRegion = mRegion.findViewById(R.id.effectRegion3Text);
682 56cbe1cf Leszek Koltunski
683 1585ba24 Leszek Koltunski
      setDefaultRegionInter();
684
685
      for (int i = 0; i < 3; i++)
686
        {
687
        seek[i].setOnSeekBarChangeListener(this);
688
        seek[i].setProgress(mInterRegion[i]);
689
        }
690
691 bcbd5b45 Leszek Koltunski
      act.setRegion( new Static4D( mRegion3Sta.get0(), mRegion3Sta.get1(), mRegion3Sta.get2(), 1.0f) );
692 1585ba24 Leszek Koltunski
      }
693 24991bc2 Leszek Koltunski
694 fed00329 Leszek Koltunski
    return mRegion;
695 56cbe1cf Leszek Koltunski
    }
696
697
///////////////////////////////////////////////////////////////////////////////////////////////////
698
699 3b1e9c7e Leszek Koltunski
  View createCenter(int num)
700 56cbe1cf Leszek Koltunski
    {
701 46b26cdc Leszek Koltunski
    GenericActivity2 act = mAct.get();
702 56cbe1cf Leszek Koltunski
703 fed00329 Leszek Koltunski
    mCenter = act.getLayoutInflater().inflate(R.layout.effectcenter, null);
704 3b1e9c7e Leszek Koltunski
    mCenter.setBackgroundColor( num%2==1 ? BACKGROUND_EVEN: BACKGROUND_ODD );
705 56cbe1cf Leszek Koltunski
706 334c13fa Leszek Koltunski
    SeekBar[] seek = new SeekBar[3];
707 56cbe1cf Leszek Koltunski
708 fe7fe83e Leszek Koltunski
    seek[0] = mCenter.findViewById(R.id.effectCenterBarX );
709
    seek[1] = mCenter.findViewById(R.id.effectCenterBarY );
710
    seek[2] = mCenter.findViewById(R.id.effectCenterBarZ );
711 56cbe1cf Leszek Koltunski
712
    mSeekCenterID[0] = seek[0].getId();
713
    mSeekCenterID[1] = seek[1].getId();
714 334c13fa Leszek Koltunski
    mSeekCenterID[2] = seek[2].getId();
715 56cbe1cf Leszek Koltunski
716 fe7fe83e Leszek Koltunski
    mTextCenter = mCenter.findViewById(R.id.effectCenterText);
717 56cbe1cf Leszek Koltunski
718
    setDefaultCenterInter();
719
720 334c13fa Leszek Koltunski
    for(int i=0; i<3; i++)
721 56cbe1cf Leszek Koltunski
      {
722
      seek[i].setOnSeekBarChangeListener(this);
723
      seek[i].setProgress( mInterCenter[i] );
724
      }
725
726 fc286c71 Leszek Koltunski
    setCenter(act);
727 24991bc2 Leszek Koltunski
728 fed00329 Leszek Koltunski
    return mCenter;
729 56cbe1cf Leszek Koltunski
    }
730
731
///////////////////////////////////////////////////////////////////////////////////////////////////
732
733
  public void onProgressChanged(SeekBar bar, int progress, boolean fromUser)
734
    {
735 4282d39a Leszek Koltunski
    boolean vectorChanged=false;
736
    boolean regionChanged=false;
737
    boolean centerChanged=false;
738
739
    for(int dim=0; dim<5; dim++)
740 56cbe1cf Leszek Koltunski
      {
741 4282d39a Leszek Koltunski
      if ( mDimension>dim && bar.getId()==mSeekID[dim] )
742
        {
743
        mInter[dim] = progress;
744
        vectorChanged = true;
745
        }
746 56cbe1cf Leszek Koltunski
      }
747 4282d39a Leszek Koltunski
748
    if( vectorChanged )
749 2f2f6176 Leszek Koltunski
      {
750
      fillStatics();
751
      setText();
752
      }
753 56cbe1cf Leszek Koltunski
754 4282d39a Leszek Koltunski
    for(int reg=0; reg<4; reg++)
755 56cbe1cf Leszek Koltunski
      {
756 4282d39a Leszek Koltunski
      if( mRegionDimension>reg && bar.getId() == mSeekRegionID[reg] )
757
        {
758
        mInterRegion[reg] = progress;
759
        regionChanged = true;
760
        }
761 56cbe1cf Leszek Koltunski
      }
762 4282d39a Leszek Koltunski
763
    if( regionChanged )
764 56cbe1cf Leszek Koltunski
      {
765
      fillRegionStatics();
766
      setRegionText();
767
      }
768
769 4282d39a Leszek Koltunski
    for(int cen=0; cen<3; cen++)
770 56cbe1cf Leszek Koltunski
      {
771 4282d39a Leszek Koltunski
      if( bar.getId() == mSeekCenterID[cen] )
772
        {
773
        mInterCenter[cen] = progress;
774
        centerChanged = true;
775
        }
776 56cbe1cf Leszek Koltunski
      }
777 4282d39a Leszek Koltunski
778
    if( centerChanged )
779 334c13fa Leszek Koltunski
      {
780
      fillCenterStatics();
781
      setCenterText();
782
      }
783 24991bc2 Leszek Koltunski
784
    if( fromUser )
785
      {
786 46b26cdc Leszek Koltunski
      GenericActivity2 act = mAct.get();
787 fc286c71 Leszek Koltunski
      setCenter(act);
788 1e7603bb Leszek Koltunski
      act.setRegion(mRegion4Sta);
789 24991bc2 Leszek Koltunski
      }
790 56cbe1cf Leszek Koltunski
    }
791
792 fa9053f5 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
793
794 6f3024ae Leszek Koltunski
  boolean thisView(View v)
795 fa9053f5 Leszek Koltunski
    {
796
    return v==mButton;
797
    }
798
799 fed00329 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
800
801
  public long getId()
802
    {
803
    return mId;
804
    }
805
806 d28ddc9b Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
807
808
  public int getDimension()
809
    {
810
    return mDimension;
811
    }
812
813 fed00329 Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
814
815
  public View getEffect()
816
    {
817
    return mEffect;
818
    }
819
820
///////////////////////////////////////////////////////////////////////////////////////////////////
821
822
  public View getRegion()
823
    {
824
    return mRegion;
825
    }
826
827
///////////////////////////////////////////////////////////////////////////////////////////////////
828
829
  public View getCenter()
830
    {
831
    return mCenter;
832
    }
833
834 56cbe1cf Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
835
836
  public void onStartTrackingTouch(SeekBar bar) { }
837
838
///////////////////////////////////////////////////////////////////////////////////////////////////
839
840
  public void onStopTrackingTouch(SeekBar bar)  { }
841
  }