Project

General

Profile

« Previous | Next » 

Revision ce0c7ca8

Added by Leszek Koltunski about 5 years ago

RubikCube: major progress with a separate RubikSettingsEnum enum - almost finished.

View differences:

src/main/java/org/distorted/magic/RubikActivity.java
34 34

  
35 35
///////////////////////////////////////////////////////////////////////////////////////////////////
36 36

  
37
public class RubikActivity extends AppCompatActivity implements RubikSettings.OnCompleteListener
37
public class RubikActivity extends AppCompatActivity
38 38
{
39 39
            static final int DEFAULT_SIZE  = 3;
40 40
    private static final int SMALLEST_SIZE = 2;
......
44 44
    public static final int MAX_SCRAMBLE = 10;
45 45

  
46 46
    private static int mSize = DEFAULT_SIZE;
47

  
48
    private int[] mPos;
49
    private int[] mType;
50

  
51 47
    private HorizontalNumberPicker mPicker;
52 48

  
53 49
///////////////////////////////////////////////////////////////////////////////////////////////////
......
60 56
      setContentView(R.layout.main);
61 57
      markButton(mSize);
62 58

  
63
      mPos = new int[RubikSettingsEnum.LENGTH];
64
      mType= new int[RubikSettingsEnum.LENGTH];
65

  
66 59
      mPicker = findViewById(R.id.rubikNumberPicker);
67 60
      mPicker.setMin(MIN_SCRAMBLE);
68 61
      mPicker.setMax(MAX_SCRAMBLE);
69 62

  
70 63
      restorePreferences();
71

  
72
      for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
73
       {
74
       applyPreferences(i);
75
       }
76 64
      }
77 65

  
78 66
///////////////////////////////////////////////////////////////////////////////////////////////////
......
117 105

  
118 106
    public void Settings(View v)
119 107
      {
120
      Bundle args = new Bundle();
121

  
122
      String name;
123

  
124
      for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
125
        {
126
        RubikSettingsEnum rse = RubikSettingsEnum.getEnum(i);
127
        name = rse.name();
128

  
129
        args.putInt(name+"_Pos" , mPos[i]);
130
        args.putInt(name+"_Type", mType[i]);
131
        }
132

  
133 108
      RubikSettings settings = new RubikSettings();
134
      settings.setArguments(args);
135 109
      settings.show(getSupportFragmentManager(), null);
136 110
      }
137 111

  
......
161 135
      view.getRenderer().solveCube();
162 136
      }
163 137

  
164
///////////////////////////////////////////////////////////////////////////////////////////////////
165

  
166
    public void onComplete(int index, int position, int type )
167
      {
168
      if( index>=0 && index<RubikSettingsEnum.LENGTH )
169
        {
170
        mPos[index] = position;
171
        mType[index]= type;
172

  
173
        applyPreferences(index);
174
        }
175
      }
176

  
177 138
///////////////////////////////////////////////////////////////////////////////////////////////////
178 139

  
179 140
    public void setSize(View v)
......
223 184
     {
224 185
     SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this);
225 186
     SharedPreferences.Editor editor = preferences.edit();
226
     String name;
227 187

  
228 188
     for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
229 189
       {
230
       RubikSettingsEnum rse = RubikSettingsEnum.getEnum(i);
231
       name = rse.name();
232

  
233
       editor.putInt(name+"_Pos" , mPos[i]);
234
       editor.putInt(name+"_Type", mType[i]);
190
       RubikSettingsEnum.getEnum(i).savePreferences(editor);
235 191
       }
236 192

  
237 193
     editor.putInt("scramble", mPicker.getValue() );
......
245 201
     {
246 202
     SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this);
247 203

  
248
     String name;
249

  
250 204
     for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
251 205
       {
252
       RubikSettingsEnum rse = RubikSettingsEnum.getEnum(i);
253
       name = rse.name();
254

  
255
       mPos[i]  = preferences.getInt(name+"_Pos" , rse.getDefaultPos() );
256
       mType[i] = preferences.getInt(name+"_Type", rse.getDefaultType());
206
       RubikSettingsEnum.getEnum(i).restorePreferences(preferences);
257 207
       }
258 208

  
259 209
     int scramble= preferences.getInt("scramble", MIN_SCRAMBLE);
260 210

  
261 211
     mPicker.setValue(scramble);
262 212
     }
263

  
264
///////////////////////////////////////////////////////////////////////////////////////////////////
265

  
266
   private void applyPreferences(int index)
267
     {
268
     RubikSurfaceView view = findViewById(R.id.rubikSurfaceView);
269
     RubikRenderer renderer = view.getRenderer();
270

  
271
     renderer.setPos (index, translateDuration(mPos[index])+1);
272
     renderer.setType(index, mType[index] );
273
     }
274

  
275
///////////////////////////////////////////////////////////////////////////////////////////////////
276

  
277
   public static int translateDuration(int pos)
278
     {
279
     return (pos/2)*100;
280
     }
281 213
}
src/main/java/org/distorted/magic/RubikRenderer.java
56 56
    private RubikCube mOldCube, mNewCube;
57 57
    private int mScreenWidth, mScreenHeight;
58 58
    private MeshFlat mMesh;
59
    private int[] mPos;
60
    private int[] mType;
61 59

  
62 60
///////////////////////////////////////////////////////////////////////////////////////////////////
63 61

  
......
90 88
      mCanScramble = true;
91 89
      mCanSolve    = true;
92 90

  
93
      mPos  = new int[RubikSettingsEnum.LENGTH];
94
      mType = new int[RubikSettingsEnum.LENGTH];
95

  
96
      for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
97
        {
98
        mPos[i] = 1000;
99
        }
100

  
101 91
      mMesh= new MeshFlat(20,20);
102 92
      mNextCubeSize =RubikActivity.getSize();
103 93
      }
......
144 134
        mCanDrag   = false;
145 135
        mCanRotate = false;
146 136
        mNextCubeSize = 0;
147

  
148
        sizeChangeEffect();
137
        changeSizeNow();
149 138
        }
150 139

  
151 140
      if( mSolveCube )
......
239 228
       }
240 229
     }
241 230

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

  
244
   private void sizeChangeEffect()
245
     {
246
     try
247
       {
248
       SizeChangeEffect effect = SizeChangeEffect.create(mType[0]);
249
       mSizeChangeEffectID = effect.start(mPos[0],mScreen,mOldCube,mNewCube,this);
250
       }
251
     catch(Exception ex)
252
       {
253
       android.util.Log.e("Renderer", "failed to create SizeChangeEffect, exception: "+ex.getMessage());
254

  
255
       if( mOldCube!=null ) mScreen.detach(mOldCube);
256
       mScreen.attach(mNewCube);
257
       mCanRotate = true;
258
       mCanDrag   = true;
259
       }
260
     }
261

  
262 231
///////////////////////////////////////////////////////////////////////////////////////////////////
263 232

  
264 233
   private float computeFOV(float cameraDistance, int screenHeight)
......
275 244
     mFinishRotation = true;
276 245
     }
277 246

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

  
280
   void setPos(int index, int pos)
281
     {
282
     if( index>=0 && index<RubikSettingsEnum.LENGTH )  mPos[index] = pos;
283
     }
284

  
285
///////////////////////////////////////////////////////////////////////////////////////////////////
286

  
287
   void setType(int index, int type)
288
     {
289
     if( index>=0 && index<RubikSettingsEnum.LENGTH )  mType[index] = type;
290
     }
291

  
292 247
///////////////////////////////////////////////////////////////////////////////////////////////////
293 248

  
294 249
   boolean createCube(int newSize)
......
304 259

  
305 260
///////////////////////////////////////////////////////////////////////////////////////////////////
306 261

  
307
   private void createCubeNow(int newSize)
262
   private void recomputeScaleFactor(int screenWidth, int screenHeight)
308 263
     {
309
     if( mOldCube!=null ) mOldCube.releaseResources();
310
     mOldCube = mNewCube;
264
     mCubeSizeInScreenSpace = CUBE_SCREEN_RATIO*(screenWidth>screenHeight ? screenHeight:screenWidth);
311 265

  
312
     DistortedTexture texture = new DistortedTexture(TEXTURE_SIZE,TEXTURE_SIZE);
313
     DistortedEffects effects = new DistortedEffects();
266
     if( mNewCube!=null )
267
       {
268
       mNewCube.recomputeScaleFactor(screenWidth, screenHeight, mCubeSizeInScreenSpace);
269
       }
270
     }
314 271

  
315
     mNewCube = new RubikCube(newSize, mQuatCurrent, mQuatAccumulated, texture, mMesh, effects);
316
     mNewCube.createTexture();
272
///////////////////////////////////////////////////////////////////////////////////////////////////
317 273

  
318
     if( mScreenWidth!=0 )
274
   void scrambleCube(int num)
275
     {
276
     if( mCanScramble )
319 277
       {
320
       recomputeScaleFactor(mScreenWidth,mScreenHeight);
278
       mScrambleCube = true;
279
       mScrambleCubeNum = num;
321 280
       }
322 281
     }
323 282

  
324 283
///////////////////////////////////////////////////////////////////////////////////////////////////
325 284

  
326
   private void recomputeScaleFactor(int screenWidth, int screenHeight)
285
   void solveCube()
327 286
     {
328
     mCubeSizeInScreenSpace = CUBE_SCREEN_RATIO*(screenWidth>screenHeight ? screenHeight:screenWidth);
329

  
330
     if( mNewCube!=null )
287
     if( mCanSolve )
331 288
       {
332
       mNewCube.recomputeScaleFactor(screenWidth, screenHeight, mCubeSizeInScreenSpace);
289
       mSolveCube = true;
333 290
       }
334 291
     }
335 292

  
336 293
///////////////////////////////////////////////////////////////////////////////////////////////////
337 294

  
338
   void scrambleCube(int num)
295
   private void createCubeNow(int newSize)
339 296
     {
340
     if( mCanScramble )
297
     if( mOldCube!=null ) mOldCube.releaseResources();
298
     mOldCube = mNewCube;
299

  
300
     DistortedTexture texture = new DistortedTexture(TEXTURE_SIZE,TEXTURE_SIZE);
301
     DistortedEffects effects = new DistortedEffects();
302

  
303
     mNewCube = new RubikCube(newSize, mQuatCurrent, mQuatAccumulated, texture, mMesh, effects);
304
     mNewCube.createTexture();
305

  
306
     if( mScreenWidth!=0 )
341 307
       {
342
       mScrambleCube = true;
343
       mScrambleCubeNum = num;
308
       recomputeScaleFactor(mScreenWidth,mScreenHeight);
344 309
       }
345 310
     }
346 311

  
347 312
///////////////////////////////////////////////////////////////////////////////////////////////////
348 313

  
349
   private void scrambleCubeNow()
314
   private void changeSizeNow()
350 315
     {
351 316
     try
352 317
       {
353
       ScrambleEffect effect = ScrambleEffect.create(mType[2]);
354
       mScrambleEffectID = effect.start(mPos[2],mNewCube,mScrambleCubeNum,this);
318
       int pos0 = RubikSettingsEnum.getEnum(0).getCurrentPos();
319
       int typ0 = RubikSettingsEnum.getEnum(0).getCurrentType();
320
       int pos = RubikSettingsEnum.translatePos(pos0)+1;
321
       SizeChangeEffect effect = SizeChangeEffect.create(typ0);
322
       mSizeChangeEffectID = effect.start(pos,mScreen,mOldCube,mNewCube,this);
355 323
       }
356 324
     catch(Exception ex)
357 325
       {
358
       android.util.Log.e("Renderer", "failed to create ScrambleEffect, exception: "+ex.getMessage());
326
       android.util.Log.e("Renderer", "failed to create SizeChangeEffect, exception: "+ex.getMessage());
359 327

  
328
       if( mOldCube!=null ) mScreen.detach(mOldCube);
329
       mScreen.attach(mNewCube);
360 330
       mCanRotate = true;
361 331
       mCanDrag   = true;
362 332
       }
......
364 334

  
365 335
///////////////////////////////////////////////////////////////////////////////////////////////////
366 336

  
367
   void solveCube()
337
   private void solveCubeNow()
368 338
     {
369
     if( mCanSolve )
339
     try
370 340
       {
371
       mSolveCube = true;
341
       int pos1 = RubikSettingsEnum.getEnum(1).getCurrentPos();
342
       int typ1 = RubikSettingsEnum.getEnum(1).getCurrentType();
343
       int pos = RubikSettingsEnum.translatePos(pos1)+1;
344
       SolveEffect effect = SolveEffect.create(typ1);
345
       mSolveEffectID = effect.start(pos,mScreen,mNewCube,this);
346
       }
347
     catch(Exception ex)
348
       {
349
       android.util.Log.e("Renderer", "failed to create SolveEffect, exception: "+ex.getMessage());
350

  
351
       mNewCube.solve();    //
352
       mCanRotate = true;   // just solve the cube
353
       mCanDrag   = true;   //
372 354
       }
373 355
     }
374 356

  
375 357
///////////////////////////////////////////////////////////////////////////////////////////////////
376 358

  
377
   private void solveCubeNow()
359
   private void scrambleCubeNow()
378 360
     {
379 361
     try
380 362
       {
381
       SolveEffect effect = SolveEffect.create(mType[1]);
382
       mSolveEffectID = effect.start(mPos[1],mScreen,mNewCube,this);
363
       int pos2 = RubikSettingsEnum.getEnum(2).getCurrentPos();
364
       int typ2 = RubikSettingsEnum.getEnum(2).getCurrentType();
365
       int pos = RubikSettingsEnum.translatePos(pos2)+1;
366
       ScrambleEffect effect = ScrambleEffect.create(typ2);
367
       mScrambleEffectID = effect.start(pos,mNewCube,mScrambleCubeNum,this);
383 368
       }
384 369
     catch(Exception ex)
385 370
       {
386
       android.util.Log.e("Renderer", "failed to create SolveEffect, exception: "+ex.getMessage());
371
       android.util.Log.e("Renderer", "failed to create ScrambleEffect, exception: "+ex.getMessage());
387 372

  
388
       mNewCube.solve();    //
389
       mCanRotate = true;   // just solve the cube
390
       mCanDrag   = true;   //
373
       mCanRotate = true;
374
       mCanDrag   = true;
391 375
       }
392 376
     }
393 377

  
src/main/java/org/distorted/magic/RubikSettings.java
20 20
package org.distorted.magic;
21 21

  
22 22
import android.app.Dialog;
23
import android.content.Context;
24
import android.content.DialogInterface;
25 23
import android.os.Bundle;
26 24
import android.support.annotation.NonNull;
27
import android.support.annotation.Nullable;
28 25
import android.support.v4.app.FragmentActivity;
29 26
import android.support.v7.app.AlertDialog;
30 27
import android.support.v7.app.AppCompatDialogFragment;
......
42 39

  
43 40
public class RubikSettings extends AppCompatDialogFragment implements SeekBar.OnSeekBarChangeListener, AdapterView.OnItemSelectedListener
44 41
  {
45
  public interface OnCompleteListener
46
    {
47
    void onComplete(int index, int position, int type);
48
    }
49

  
50
  private OnCompleteListener mListener;
51

  
52 42
  private TextView[] mDurationText;
53
  private int[] mSeekBarID;
54
  private int[] mSpinnerID;
55
  private int[] mPos;
56
  private int[] mType;
57 43

  
58 44
///////////////////////////////////////////////////////////////////////////////////////////////////
59 45

  
60 46
  public RubikSettings()
61 47
    {
62 48
    mDurationText = new TextView[RubikSettingsEnum.LENGTH];
63
    mSeekBarID    = new int[RubikSettingsEnum.LENGTH];
64
    mSpinnerID    = new int[RubikSettingsEnum.LENGTH];
65
    mPos          = new int[RubikSettingsEnum.LENGTH];
66
    mType         = new int[RubikSettingsEnum.LENGTH];
67
    }
68

  
69
///////////////////////////////////////////////////////////////////////////////////////////////////
70

  
71
  @Override
72
  public void onAttach(Context context)
73
    {
74
    super.onAttach(context);
75

  
76
    try
77
      {
78
      mListener = (OnCompleteListener)context;
79
      }
80
    catch (final ClassCastException e)
81
      {
82
      throw new ClassCastException(context.toString() + " must implement OnCompleteListener");
83
      }
84
    }
85

  
86
///////////////////////////////////////////////////////////////////////////////////////////////////
87

  
88
  @Override
89
  public void onCreate(@Nullable Bundle savedInstanceState)
90
    {
91
    super.onCreate(savedInstanceState);
92

  
93
    Bundle args = getArguments();
94

  
95
    String name;
96

  
97
    for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
98
      {
99
      RubikSettingsEnum rse = RubikSettingsEnum.getEnum(i);
100
      name = rse.name();
101

  
102
      try
103
        {
104
        mPos[i]  = args.getInt(name+"_Pos" );
105
        mType[i] = args.getInt(name+"_Type");
106
        }
107
      catch(NullPointerException ex)
108
        {
109
        mPos[i]  = rse.getDefaultPos();
110
        mType[i] = rse.getDefaultType();
111
        }
112
      }
113 49
    }
114 50

  
115 51
///////////////////////////////////////////////////////////////////////////////////////////////////
......
120 56
    {
121 57
    FragmentActivity act = getActivity();
122 58
    AlertDialog.Builder builder = new AlertDialog.Builder(act);
123

  
124 59
    builder.setCancelable(false);
125
    builder.setPositiveButton( R.string.save, new DialogInterface.OnClickListener()
126
      {
127
      @Override
128
      public void onClick(DialogInterface dialog, int which)
129
        {
130
        saveOptions();
131
        }
132
      });
133 60

  
134 61
    LayoutInflater inflater = act.getLayoutInflater();
135 62
    final View view = inflater.inflate(R.layout.settings, null);
......
162 89
      ///// TEXT ///////////////////////////////////////////////////////////////////////////
163 90

  
164 91
      int layoutHeight = (int)(scale*48 + 0.5f);
165
      int padding      = (int)(scale*15 + 0.5f);
92
      int padding      = (int)(scale*10 + 0.5f);
166 93

  
167 94
      LinearLayout.LayoutParams textParams = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,layoutHeight);
168 95

  
......
233 160
      seekBar.setId(index);
234 161
      innerLayout1.addView(seekBar);
235 162

  
236
      mSeekBarID[index] = seekBar.getId();
237

  
238 163
      seekBar.setOnSeekBarChangeListener(this);
239
      seekBar.setProgress(mPos[index]);
164
      seekBar.setProgress(rsEnum.getCurrentPos());
240 165

  
241 166
      ///// INNER LAYOUT2 //////////////////////////////////////////////////////////////////
242 167

  
......
272 197
      spinner.setId(index);
273 198
      innerLayout2.addView(spinner);
274 199

  
275
      mSpinnerID[index] = spinner.getId();
276

  
277 200
      spinner.setOnItemSelectedListener(this);
278 201
      String[] appear = RubikSettingsEnum.getNames(index);
279 202
      ArrayAdapter<String> adapterType = new ArrayAdapter<>(act,android.R.layout.simple_spinner_item, appear);
280 203
      adapterType.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
281 204
      spinner.setAdapter(adapterType);
282

  
283
      int type = mType[index];
284

  
285
      if(type>=0 && type<appear.length)
286
        {
287
        spinner.setSelection(type);
288
        }
289
      }
290

  
291

  
292
///////////////////////////////////////////////////////////////////////////////////////////////////
293

  
294
    private void saveOptions()
295
      {
296
      for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
297
        {
298
        mListener.onComplete(i, mPos[i], mType[i]);
299
        }
205
      spinner.setSelection(rsEnum.getCurrentType());
300 206
      }
301 207

  
302 208
///////////////////////////////////////////////////////////////////////////////////////////////////
......
305 211
      {
306 212
      int parentID = parent.getId();
307 213

  
308
      for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
214
      if( parentID>=0 && parentID< RubikSettingsEnum.LENGTH) // ith spinner's ID is equal to i (see createSettingSection)
309 215
        {
310
        if( mSpinnerID[i] == parentID )
311
          {
312
          mType[i] = pos;
313
          break;
314
          }
216
        RubikSettingsEnum.getEnum(parentID).setCurrentType(pos);
315 217
        }
316 218
      }
317 219

  
......
321 223
      {
322 224
      int barID = bar.getId();
323 225

  
324
      for (int i=0; i<RubikSettingsEnum.LENGTH; i++)
226
      if( barID>=0 && barID< RubikSettingsEnum.LENGTH) // ith seekbar's ID is equal to i (see createSettingSection)
325 227
        {
326
        if( mSeekBarID[i] == barID )
327
          {
328
          mPos[i] = progress;
329
          int ms = RubikActivity.translateDuration(mPos[i]);
330
          mDurationText[i].setText(getString(R.string.ms_placeholder,ms));
331
          break;
332
          }
228
        RubikSettingsEnum.getEnum(barID).setCurrentPos(progress);
229
        int ms = RubikSettingsEnum.translatePos(progress);
230
        mDurationText[barID].setText(getString(R.string.ms_placeholder,ms));
333 231
        }
334 232
      }
335 233

  
src/main/java/org/distorted/magic/RubikSettingsEnum.java
19 19

  
20 20
package org.distorted.magic;
21 21

  
22
///////////////////////////////////////////////////////////////////////////////////////////////////
22
import android.content.SharedPreferences;
23 23

  
24 24
import org.distorted.effect.ScrambleEffect;
25 25
import org.distorted.effect.SizeChangeEffect;
26 26
import org.distorted.effect.SolveEffect;
27 27

  
28
///////////////////////////////////////////////////////////////////////////////////////////////////
29

  
28 30
enum RubikSettingsEnum
29 31
  {
30
  SIZECHANGE  (  20, 1, R.string.sizechange_effect ),
32
  SIZECHANGE  (  20, 1, R.string.sizechange_effect),
31 33
  SOLVE       (  20, 1, R.string.solve_effect      ),
32
  SCRAMBLE    ( 100, 0, R.string.scramble_effect   );
34
  SCRAMBLE    ( 100, 1, R.string.scramble_effect   );
33 35

  
34 36
  public static final int LENGTH = values().length;
35
  private int mDefaultPos, mDefaultType;
37
  private final int mDefaultPos, mDefaultType;
38
  private int mCurrentPos, mCurrentType;
36 39
  private int mText;
37 40

  
38 41
  private static final RubikSettingsEnum[] enums;  // copy the values() to a local variable so that we
......
54 57

  
55 58
  RubikSettingsEnum( int dPos, int dType, int text )
56 59
    {
57
    mDefaultPos  = dPos;
58
    mDefaultType = dType;
60
    mDefaultPos  = mCurrentPos = dPos;
61
    mDefaultType = mCurrentType= dType;
59 62
    mText        = text;
60 63
    }
61 64

  
62 65
///////////////////////////////////////////////////////////////////////////////////////////////////
63 66

  
64
  int getDefaultPos()
67
  int getText()
65 68
    {
66
    return mDefaultPos;
69
    return mText;
67 70
    }
68 71

  
69 72
///////////////////////////////////////////////////////////////////////////////////////////////////
70 73

  
71
  int getDefaultType()
74
  int getCurrentPos()
72 75
    {
73
    return mDefaultType;
76
    return mCurrentPos;
74 77
    }
75 78

  
76 79
///////////////////////////////////////////////////////////////////////////////////////////////////
77 80

  
78
  int getText()
81
  int getCurrentType()
79 82
    {
80
    return mText;
83
    return mCurrentType;
84
    }
85

  
86
///////////////////////////////////////////////////////////////////////////////////////////////////
87

  
88
  void setCurrentPos(int pos)
89
    {
90
    mCurrentPos = pos;
91
    }
92

  
93
///////////////////////////////////////////////////////////////////////////////////////////////////
94

  
95
  void setCurrentType(int type)
96
    {
97
    mCurrentType = type;
98
    }
99

  
100
///////////////////////////////////////////////////////////////////////////////////////////////////
101

  
102
  void savePreferences(SharedPreferences.Editor editor)
103
    {
104
    String name = name();
105

  
106
    editor.putInt(name+"_Pos" , mCurrentPos );
107
    editor.putInt(name+"_Type", mCurrentType);
108
    }
109

  
110
///////////////////////////////////////////////////////////////////////////////////////////////////
111

  
112
  void restorePreferences(SharedPreferences preferences)
113
    {
114
    String name = name();
115

  
116
    mCurrentPos  = preferences.getInt(name+"_Pos" , mDefaultPos );
117
    mCurrentType = preferences.getInt(name+"_Type", mDefaultType);
81 118
    }
82 119

  
83 120
///////////////////////////////////////////////////////////////////////////////////////////////////
......
100 137

  
101 138
    return null;
102 139
    }
140

  
141
///////////////////////////////////////////////////////////////////////////////////////////////////
142

  
143
  static int translatePos(int pos)
144
     {
145
     return (pos/2)*100;
146
     }
103 147
  }

Also available in: Unified diff