Project

General

Profile

Download (24 KB) Statistics
| Branch: | Tag: | Revision:

magiccube / src / main / java / org / distorted / states / RubikStatePlay.java @ 4fb1fc0d

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2020 Leszek Koltunski                                                               //
3
//                                                                                               //
4
// This file is part of Magic Cube.                                                              //
5
//                                                                                               //
6
// Magic Cube is free software: you can redistribute it and/or modify                            //
7
// it under the terms of the GNU General Public License as published by                          //
8
// the Free Software Foundation, either version 2 of the License, or                             //
9
// (at your option) any later version.                                                           //
10
//                                                                                               //
11
// Magic Cube is distributed in the hope that it will be useful,                                 //
12
// but WITHOUT ANY WARRANTY; without even the implied warranty of                                //
13
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                 //
14
// GNU General Public License for more details.                                                  //
15
//                                                                                               //
16
// You should have received a copy of the GNU General Public License                             //
17
// along with Magic Cube.  If not, see <http://www.gnu.org/licenses/>.                           //
18
///////////////////////////////////////////////////////////////////////////////////////////////////
19

    
20
package org.distorted.states;
21

    
22
import android.content.Context;
23
import android.content.SharedPreferences;
24
import android.graphics.drawable.BitmapDrawable;
25
import android.os.Bundle;
26
import android.util.TypedValue;
27
import android.view.Gravity;
28
import android.view.LayoutInflater;
29
import android.view.View;
30
import android.widget.Button;
31
import android.widget.GridLayout;
32
import android.widget.ImageButton;
33
import android.widget.LinearLayout;
34
import android.widget.PopupWindow;
35

    
36
import org.distorted.dialogs.RubikDialogAbout;
37
import org.distorted.dialogs.RubikDialogScores;
38
import org.distorted.main.R;
39
import org.distorted.main.RubikActivity;
40
import org.distorted.main.RubikPreRender;
41
import org.distorted.objects.RubikObject;
42
import org.distorted.objects.RubikObjectList;
43
import org.distorted.scores.RubikScores;
44

    
45
import java.util.ArrayList;
46

    
47
///////////////////////////////////////////////////////////////////////////////////////////////////
48

    
49
public class RubikStatePlay extends RubikStateAbstract implements RubikPreRender.ActionFinishedListener
50
  {
51
  private static final int DURATION_MILLIS = 750;
52
  private static final int LEVELS_SHOWN = 10;
53
  public  static final int DEF_OBJECT= RubikObjectList.CUBE.ordinal();
54
  public  static final int DEF_SIZE  =  3;
55

    
56
  private static int[] BUTTON_LABELS = { R.string.scores, R.string.patterns, R.string.solver, R.string.about };
57
  private static final int NUM_BUTTONS = BUTTON_LABELS.length;
58

    
59
  private ImageButton mObjButton, mMenuButton, mPrevButton, mSolveButton;
60
  private Button mPlayButton;
61
  private PopupWindow mObjectPopup, mMenuPopup, mPlayPopup;
62
  private int mObject = DEF_OBJECT;
63
  private int mSize   = DEF_SIZE;
64
  private int mObjectSize, mMenuLayoutWidth, mMenuLayoutHeight, mPlayLayoutWidth;
65
  private int mLevelValue;
66
  private float mButtonSize, mMenuItemSize, mMenuTextSize;
67
  private int mColCount, mRowCount;
68
  private LinearLayout mPlayLayout;
69

    
70
  private ArrayList<Move> mMoves;
71
  private boolean mCanPrevMove;
72

    
73
  private static class Move
74
    {
75
    private int mAxis, mRow, mAngle;
76

    
77
    Move(int axis, int row, int angle)
78
      {
79
      mAxis = axis;
80
      mRow  = row;
81
      mAngle= angle;
82
      }
83
    }
84

    
85
///////////////////////////////////////////////////////////////////////////////////////////////////
86

    
87
  void leaveState(RubikActivity act)
88
    {
89

    
90
    }
91

    
92
///////////////////////////////////////////////////////////////////////////////////////////////////
93

    
94
  void enterState(final RubikActivity act)
95
    {
96
    float width = act.getScreenWidthInPixels();
97
    mMenuTextSize = width*RubikActivity.MENU_MEDIUM_TEXT_SIZE;
98
    mButtonSize   = width*RubikActivity.BUTTON_TEXT_SIZE;
99
    mMenuItemSize = width*RubikActivity.MENU_ITEM_SIZE;
100

    
101
    mCanPrevMove = true;
102

    
103
    if( mMoves==null ) mMoves = new ArrayList<>();
104
    else               mMoves.clear();
105

    
106
    mRowCount = RubikObjectList.getRowCount();
107
    mColCount = RubikObjectList.getColumnCount();
108

    
109
    // TOP ////////////////////////////
110
    LinearLayout layoutTop = act.findViewById(R.id.upperBar);
111
    layoutTop.removeAllViews();
112

    
113
    setupObjectWindow(act,width);
114
    setupObjectButton(act,width);
115
    layoutTop.addView(mObjButton);
116

    
117
    setupMenuWindow(act,width);
118
    setupMenuButton(act,width);
119
    layoutTop.addView(mMenuButton);
120

    
121
    setupPlayWindow(act,width);
122
    setupPlayButton(act,width);
123
    layoutTop.addView(mPlayButton);
124

    
125
    // BOT ////////////////////////////
126
    LinearLayout layoutBot = act.findViewById(R.id.lowerBar);
127
    layoutBot.removeAllViews();
128

    
129
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT,1);
130

    
131
    LinearLayout layoutLeft = new LinearLayout(act);
132
    layoutLeft.setLayoutParams(params);
133
    LinearLayout layoutMid = new LinearLayout(act);
134
    layoutMid.setLayoutParams(params);
135
    LinearLayout layoutRight = new LinearLayout(act);
136
    layoutRight.setLayoutParams(params);
137

    
138
    setupPrevButton(act,width);
139
    layoutLeft.addView(mPrevButton);
140
    setupSolveButton(act,width);
141
    layoutRight.addView(mSolveButton);
142

    
143
    layoutBot.addView(layoutLeft);
144
    layoutBot.addView(layoutMid);
145
    layoutBot.addView(layoutRight);
146
    }
147

    
148
///////////////////////////////////////////////////////////////////////////////////////////////////
149

    
150
  private void setupObjectButton(final RubikActivity act, final float width)
151
    {
152
    final int padding = (int)(width*RubikActivity.PADDING);
153
    final int margin  = (int)(width*RubikActivity.MARGIN);
154
    final int icon = RubikActivity.getDrawable(R.drawable.ui_small_cube_menu,R.drawable.ui_medium_cube_menu, R.drawable.ui_big_cube_menu, R.drawable.ui_huge_cube_menu);
155

    
156
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT, 1.2f);
157
    params.topMargin    = margin;
158
    params.bottomMargin = margin;
159
    params.leftMargin   = margin;
160
    params.rightMargin  = margin;
161

    
162
    mObjButton = new ImageButton(act);
163
    mObjButton.setLayoutParams(params);
164
    mObjButton.setPadding(padding,0,padding,0);
165
    mObjButton.setImageResource(icon);
166

    
167
    mObjButton.setOnClickListener( new View.OnClickListener()
168
      {
169
      @Override
170
      public void onClick(View view)
171
        {
172
        if( act.getPreRender().canPlay() )
173
          {
174
          mObjectPopup.setFocusable(false);
175
          mObjectPopup.update();
176

    
177
          View popupView = mObjectPopup.getContentView();
178
          popupView.setSystemUiVisibility(RubikActivity.FLAGS);
179

    
180
          mObjectPopup.showAsDropDown(view, margin, margin, Gravity.LEFT);
181
          mObjectPopup.update(view, mObjectSize*mColCount, mObjectSize*mRowCount);
182

    
183
          mObjectPopup.setFocusable(true);
184
          mObjectPopup.update();
185

    
186
          }
187
        }
188
      });
189
    }
190

    
191
///////////////////////////////////////////////////////////////////////////////////////////////////
192

    
193
  private void setupPlayButton(final RubikActivity act, final float width)
194
    {
195
    final int padding = (int)(width*RubikActivity.PADDING);
196
    final int margin  = (int)(width*RubikActivity.MARGIN);
197
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT, 1.2f);
198
    params.topMargin    = margin;
199
    params.bottomMargin = margin;
200
    params.leftMargin   = margin;
201
    params.rightMargin  = margin;
202

    
203
    mPlayButton = new Button(act);
204
    mPlayButton.setLayoutParams(params);
205
    mPlayButton.setPadding(padding,0,padding,0);
206
    mPlayButton.setTextSize(TypedValue.COMPLEX_UNIT_PX, mButtonSize);
207
    mPlayButton.setText(R.string.play);
208

    
209
    mPlayButton.setOnClickListener( new View.OnClickListener()
210
      {
211
      @Override
212
      public void onClick(View view)
213
        {
214
        mPlayPopup.setFocusable(false);
215
        mPlayPopup.update();
216

    
217
        View popupView = mPlayPopup.getContentView();
218
        popupView.setSystemUiVisibility(RubikActivity.FLAGS);
219

    
220
        mPlayPopup.showAsDropDown(view, margin, margin, Gravity.RIGHT);
221
        mPlayPopup.update(view, mPlayLayoutWidth, (int)(LEVELS_SHOWN*(mMenuItemSize+margin)+margin));
222

    
223
        mPlayPopup.setFocusable(true);
224
        mPlayPopup.update();
225
        }
226
      });
227
    }
228

    
229
///////////////////////////////////////////////////////////////////////////////////////////////////
230

    
231
  private void setupMenuButton(final RubikActivity act, final float width)
232
    {
233
    final int padding = (int)(width*RubikActivity.PADDING);
234
    final int margin  = (int)(width*RubikActivity.MARGIN);
235
    final int icon = RubikActivity.getDrawable(R.drawable.ui_small_menu,R.drawable.ui_medium_menu, R.drawable.ui_big_menu, R.drawable.ui_huge_menu);
236

    
237
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT, 1.2f);
238
    params.topMargin    = margin;
239
    params.bottomMargin = margin;
240
    params.leftMargin   = margin;
241
    params.rightMargin  = margin;
242

    
243
    mMenuButton = new ImageButton(act);
244
    mMenuButton.setLayoutParams(params);
245
    mMenuButton.setPadding(padding,0,padding,0);
246
    mMenuButton.setImageResource(icon);
247

    
248
    mMenuButton.setOnClickListener( new View.OnClickListener()
249
      {
250
      @Override
251
      public void onClick(View view)
252
        {
253
        if( act.getPreRender().canPlay() )
254
          {
255
          mMenuPopup.setFocusable(false);
256
          mMenuPopup.update();
257

    
258
          View popupView = mMenuPopup.getContentView();
259
          popupView.setSystemUiVisibility(RubikActivity.FLAGS);
260

    
261
          mMenuPopup.showAsDropDown(view, (int)(-width/12), margin, Gravity.CENTER);
262
          mMenuPopup.update(view, mMenuLayoutWidth, mMenuLayoutHeight);
263

    
264
          mMenuPopup.setFocusable(true);
265
          mMenuPopup.update();
266
          }
267
        }
268
      });
269
    }
270

    
271
///////////////////////////////////////////////////////////////////////////////////////////////////
272

    
273
  private void setupSolveButton(final RubikActivity act, final float width)
274
    {
275
    int padding  = (int)(width*RubikActivity.PADDING);
276
    int margin   = (int)(width*RubikActivity.MARGIN);
277
    int icon = RubikActivity.getDrawable(R.drawable.ui_small_cube_solve,R.drawable.ui_medium_cube_solve, R.drawable.ui_big_cube_solve, R.drawable.ui_huge_cube_solve);
278

    
279
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT);
280
    params.topMargin    = margin;
281
    params.bottomMargin = margin;
282
    params.leftMargin   = margin;
283
    params.rightMargin  = margin;
284

    
285
    mSolveButton = new ImageButton(act);
286
    mSolveButton.setLayoutParams(params);
287
    mSolveButton.setPadding(padding,0,padding,0);
288
    mSolveButton.setImageResource(icon);
289

    
290
    mSolveButton.setOnClickListener( new View.OnClickListener()
291
      {
292
      @Override
293
      public void onClick(View v)
294
        {
295
        act.getPreRender().solveObject();
296
        mMoves.clear();
297
        }
298
      });
299
    }
300

    
301
///////////////////////////////////////////////////////////////////////////////////////////////////
302

    
303
  private void setupPrevButton(final RubikActivity act, final float width)
304
    {
305
    int padding  = (int)(width*RubikActivity.PADDING);
306
    int margin   = (int)(width*RubikActivity.MARGIN);
307
    int icon = RubikActivity.getDrawable(R.drawable.ui_small_cube_back,R.drawable.ui_medium_cube_back, R.drawable.ui_big_cube_back, R.drawable.ui_huge_cube_back);
308

    
309
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT);
310
    params.topMargin    = margin;
311
    params.bottomMargin = margin;
312
    params.leftMargin   = margin;
313
    params.rightMargin  = margin;
314

    
315
    mPrevButton = new ImageButton(act);
316
    mPrevButton.setLayoutParams(params);
317
    mPrevButton.setPadding(padding,0,padding,0);
318
    mPrevButton.setImageResource(icon);
319

    
320
    mPrevButton.setOnClickListener( new View.OnClickListener()
321
      {
322
      @Override
323
      public void onClick(View v)
324
        {
325
        RubikPreRender pre = act.getPreRender();
326
        backMove(pre);
327
        }
328
      });
329
    }
330

    
331
///////////////////////////////////////////////////////////////////////////////////////////////////
332

    
333
  private void setupObjectWindow(final RubikActivity act, final float width)
334
    {
335
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
336
    final View layout = layoutInflater.inflate(R.layout.popup_objects, null);
337
    GridLayout objectGrid = layout.findViewById(R.id.objectGrid);
338

    
339
    int[] indices = RubikObjectList.getIndices();
340

    
341
    GridLayout.Spec[] rowSpecs = new GridLayout.Spec[mRowCount];
342
    GridLayout.Spec[] colSpecs = new GridLayout.Spec[mColCount];
343

    
344
    objectGrid.setColumnCount(mColCount);
345
    objectGrid.setRowCount(mRowCount);
346

    
347
    int[] nextInColumn = new int[mColCount];
348

    
349
    for(int row=0; row<mRowCount; row++)
350
      {
351
      rowSpecs[row] = GridLayout.spec(row);
352
      }
353
    for(int col=0; col<mColCount; col++)
354
      {
355
      colSpecs[col] = GridLayout.spec(col);
356
      nextInColumn[col] =0;
357
      }
358

    
359
    mObjectPopup = new PopupWindow(act);
360
    mObjectPopup.setContentView(layout);
361
    mObjectPopup.setFocusable(true);
362
    int icon = RubikActivity.getDrawable(R.drawable.ui_small_cube2,R.drawable.ui_medium_cube2, R.drawable.ui_big_cube2, R.drawable.ui_huge_cube2);
363

    
364
    BitmapDrawable bd = (BitmapDrawable) act.getResources().getDrawable(icon);
365
    int cubeWidth = bd.getIntrinsicWidth();
366
    int margin = (int)(width*RubikActivity.LARGE_MARGIN);
367
    mObjectSize = (int)(cubeWidth + 2*margin + 0.5f);
368

    
369
    for(int object=0; object<RubikObjectList.NUM_OBJECTS; object++)
370
      {
371
      final RubikObjectList list = RubikObjectList.getObject(object);
372
      final int[] sizes = list.getSizes();
373
      int[] icons = list.getIconIDs();
374
      int len = sizes.length;
375
      final int obj = object;
376
      int col = indices[object];
377

    
378
      for(int i=0; i<len; i++)
379
        {
380
        final int index = i;
381

    
382
        ImageButton button = new ImageButton(act);
383
        button.setBackgroundResource(icons[i]);
384
        button.setOnClickListener( new View.OnClickListener()
385
          {
386
          @Override
387
          public void onClick(View v)
388
            {
389
            if( act.getPreRender().canPlay() && RubikState.getCurrentState()==RubikState.PLAY )
390
              {
391
              mObject = obj;
392
              mSize   = sizes[index];
393
              act.changeObject(list,sizes[index], true);
394
              adjustLevels(act);
395
              mMoves.clear();
396
              }
397

    
398
            mObjectPopup.dismiss();
399
            }
400
          });
401

    
402
        GridLayout.LayoutParams params = new GridLayout.LayoutParams(rowSpecs[nextInColumn[col]],colSpecs[col]);
403
        params.bottomMargin = margin;
404
        params.topMargin    = margin;
405
        params.leftMargin   = margin;
406
        params.rightMargin  = margin;
407

    
408
        nextInColumn[col]++;
409

    
410
        objectGrid.addView(button, params);
411
        }
412
      }
413
    }
414

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

    
417
  private void setupMenuWindow(final RubikActivity act, final float width)
418
    {
419
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
420
    final View layout = layoutInflater.inflate(R.layout.popup_menu, null);
421
    LinearLayout menuLayout = layout.findViewById(R.id.menuGrid);
422

    
423
    mMenuPopup = new PopupWindow(act);
424
    mMenuPopup.setContentView(layout);
425
    mMenuPopup.setFocusable(true);
426
    int margin  = (int)(width*RubikActivity.MARGIN);
427
    int padding = (int)(width*RubikActivity.PADDING);
428

    
429
    mMenuLayoutWidth = (int)(width/2);
430
    mMenuLayoutHeight= (int)(2*margin + NUM_BUTTONS*(mMenuItemSize+margin));
431

    
432
    LinearLayout.LayoutParams pT = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
433
    pT.setMargins(margin, 0, margin, margin);
434
    LinearLayout.LayoutParams pM = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
435
    pM.setMargins(margin, margin, margin, margin);
436
    LinearLayout.LayoutParams pB = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
437
    pB.setMargins(margin, margin, margin, 2*margin);
438

    
439
    for(int i=0; i<NUM_BUTTONS; i++)
440
      {
441
      final int but = i;
442
      Button button = new Button(act);
443
      button.setLayoutParams(pT);//i==0 ? pT : (i==NUM_BUTTONS-1 ? pB : pM));
444
      button.setText(BUTTON_LABELS[i]);
445
      button.setTextSize(TypedValue.COMPLEX_UNIT_PX, mMenuTextSize);
446

    
447
      button.setOnClickListener( new View.OnClickListener()
448
        {
449
        @Override
450
        public void onClick(View v)
451
          {
452
          mMenuPopup.dismiss();
453
          MenuAction(act,but);
454
          }
455
        });
456

    
457
      menuLayout.addView(button);
458
      }
459
    }
460

    
461
///////////////////////////////////////////////////////////////////////////////////////////////////
462

    
463
  private void setupPlayWindow(final RubikActivity act, final float width)
464
    {
465
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
466
    final View layout = layoutInflater.inflate(R.layout.popup_play, null);
467
    mPlayLayout = layout.findViewById(R.id.playGrid);
468

    
469
    mPlayLayoutWidth = (int)(width*0.4f);
470

    
471
    mPlayPopup = new PopupWindow(act);
472
    mPlayPopup.setContentView(layout);
473
    mPlayPopup.setFocusable(true);
474

    
475
    adjustLevels(act);
476
    }
477

    
478
///////////////////////////////////////////////////////////////////////////////////////////////////
479

    
480
  private void backMove(RubikPreRender pre)
481
    {
482
    if( mCanPrevMove )
483
      {
484
      int numMoves = mMoves.size();
485

    
486
      if( numMoves>0 )
487
        {
488
        Move move = mMoves.remove(numMoves-1);
489
        RubikObject object = pre.getObject();
490

    
491
        int axis  = move.mAxis;
492
        int row   = (1<<move.mRow);
493
        int angle = move.mAngle;
494
        int numRot= Math.abs(angle*object.getBasicAngle()/360);
495

    
496
        if( angle!=0 )
497
          {
498
          mCanPrevMove = false;
499
          pre.addRotation(this, axis, row, -angle, numRot*DURATION_MILLIS);
500
          }
501
        else
502
          {
503
          android.util.Log.e("solution", "error: trying to back move of angle 0");
504
          }
505
        }
506
      }
507
    }
508

    
509
///////////////////////////////////////////////////////////////////////////////////////////////////
510

    
511
  private void MenuAction(RubikActivity act, int button)
512
    {
513
    switch(button)
514
      {
515
      case 0: RubikStatePlay play = (RubikStatePlay) RubikState.PLAY.getStateClass();
516
              int object = play.getObject();
517
              int size   = play.getSize();
518
              int sizeIndex = RubikObjectList.getSizeIndex(object,size);
519

    
520
              Bundle bundle = new Bundle();
521
              bundle.putInt("tab", RubikObjectList.pack(object,sizeIndex) );
522
              bundle.putBoolean("submitting", false);
523

    
524
              RubikDialogScores scores = new RubikDialogScores();
525
              scores.setArguments(bundle);
526
              scores.show(act.getSupportFragmentManager(), null);
527
              break;
528
      case 1: RubikState.switchState(act,RubikState.PATT);
529
              break;
530
      case 2: RubikState.switchState(act,RubikState.SVER);
531
              break;
532
      case 3: RubikDialogAbout diag = new RubikDialogAbout();
533
              diag.show(act.getSupportFragmentManager(), null);
534
              break;
535
      }
536
    }
537

    
538
///////////////////////////////////////////////////////////////////////////////////////////////////
539

    
540
  public void savePreferences(SharedPreferences.Editor editor)
541
    {
542
    editor.putInt("statePlay_object", mObject);
543
    editor.putInt("statePlay_size"  , mSize);
544

    
545
    if( mObjectPopup!=null )
546
      {
547
      mObjectPopup.dismiss();
548
      mObjectPopup = null;
549
      }
550

    
551
    if( mMenuPopup!=null )
552
      {
553
      mMenuPopup.dismiss();
554
      mMenuPopup = null;
555
      }
556

    
557
    if( mPlayPopup!=null )
558
      {
559
      mPlayPopup.dismiss();
560
      mPlayPopup = null;
561
      }
562
    }
563

    
564
///////////////////////////////////////////////////////////////////////////////////////////////////
565

    
566
  public void restorePreferences(SharedPreferences preferences)
567
    {
568
    mObject     = preferences.getInt("statePlay_object", DEF_OBJECT);
569
    mSize       = preferences.getInt("statePlay_size"  , DEF_SIZE  );
570
    }
571

    
572
///////////////////////////////////////////////////////////////////////////////////////////////////
573

    
574
  public boolean setObjectAndSize(RubikActivity act, RubikObjectList obj, int size)
575
    {
576
    if( mObject!=obj.ordinal() || mSize != size )
577
      {
578
      boolean success = false;
579

    
580
      for( int s: obj.getSizes() )
581
        if( s==size )
582
          {
583
          success = true;
584
          break;
585
          }
586

    
587
      if( success )
588
        {
589
        mObject = obj.ordinal();
590
        mSize   = size;
591

    
592
        if( mPlayLayout!=null ) adjustLevels(act);
593
        }
594

    
595
      return success;
596
      }
597

    
598
    return true;
599
    }
600

    
601
///////////////////////////////////////////////////////////////////////////////////////////////////
602

    
603
  private void adjustLevels(final RubikActivity act)
604
    {
605
    int sizeIndex = RubikObjectList.getSizeIndex(mObject,mSize);
606
    int maxLevel = RubikObjectList.getMaxLevel(mObject, sizeIndex);
607
    String[] levels = new String[maxLevel];
608

    
609
    for(int i=0; i<maxLevel; i++)
610
      {
611
      levels[i] = act.getString(R.string.lv_placeholder,i+1);
612
      }
613

    
614
    if( mLevelValue>maxLevel ) mLevelValue=1;
615

    
616
    float width = act.getScreenWidthInPixels();
617
    int margin  = (int)(width*RubikActivity.MARGIN);
618
    int padding = (int)(width*RubikActivity.PADDING);
619

    
620
    LinearLayout.LayoutParams pM = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
621
    pM.setMargins(margin, 0, margin, margin);
622
    LinearLayout.LayoutParams pT = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
623
    pT.setMargins(margin, margin, margin, margin);
624
    LinearLayout.LayoutParams pB = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
625
    pB.setMargins(margin, margin, margin, 2*margin);
626

    
627
    mPlayLayout.removeAllViews();
628

    
629
    int realSize= RubikObjectList.getSizeIndex(mObject,mSize);
630
    RubikScores scores = RubikScores.getInstance();
631

    
632
    for(int i=0; i<maxLevel; i++)
633
      {
634
      final int but = i;
635
      Button button = new Button(act);
636
      button.setLayoutParams(i==0 ? pT : (i==maxLevel-1 ? pB : pM));
637
      button.setText(levels[i]);
638
      button.setTextSize(TypedValue.COMPLEX_UNIT_PX, mMenuTextSize);
639

    
640
      int icon = scores.isSolved(mObject, realSize, i) ? R.drawable.ui_solved : R.drawable.ui_notsolved;
641
      button.setCompoundDrawablesWithIntrinsicBounds(icon,0,0,0);
642

    
643
      button.setOnClickListener( new View.OnClickListener()
644
        {
645
        @Override
646
        public void onClick(View v)
647
          {
648
          mPlayPopup.dismiss();
649
          mLevelValue = but+1;
650
          act.getPreRender().scrambleObject(mLevelValue);
651
          }
652
        });
653

    
654
      mPlayLayout.addView(button);
655
      }
656
    }
657

    
658
///////////////////////////////////////////////////////////////////////////////////////////////////
659

    
660
  int getLevel()
661
    {
662
    return mLevelValue;
663
    }
664

    
665
///////////////////////////////////////////////////////////////////////////////////////////////////
666

    
667
  public void addMove(int axis, int row, int angle)
668
    {
669
    mMoves.add(new Move(axis,row,angle));
670
    }
671

    
672
///////////////////////////////////////////////////////////////////////////////////////////////////
673

    
674
  public int getObject()
675
    {
676
    return mObject;
677
    }
678

    
679
///////////////////////////////////////////////////////////////////////////////////////////////////
680

    
681
  public int getSize()
682
    {
683
    return mSize;
684
    }
685

    
686
///////////////////////////////////////////////////////////////////////////////////////////////////
687

    
688
  public void onActionFinished(final long effectID)
689
    {
690
    mCanPrevMove = true;
691
    }
692
  }
(5-5/9)