Project

General

Profile

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

magiccube / src / main / java / org / distorted / states / RubikStatePlay.java @ 92843d3b

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
    setupPrevButton(act,width);
130
    layoutBot.addView(mPrevButton);
131
    setupSolveButton(act,width);
132
    layoutBot.addView(mSolveButton);
133
    }
134

    
135
///////////////////////////////////////////////////////////////////////////////////////////////////
136

    
137
  private void setupObjectButton(final RubikActivity act, final float width)
138
    {
139
    final int padding = (int)(width*RubikActivity.PADDING);
140
    final int margin  = (int)(width*RubikActivity.MARGIN);
141
    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);
142

    
143
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT, 1.2f);
144
    params.topMargin    = margin;
145
    params.bottomMargin = margin;
146
    params.leftMargin   = margin;
147
    params.rightMargin  = margin;
148

    
149
    mObjButton = new ImageButton(act);
150
    mObjButton.setLayoutParams(params);
151
    mObjButton.setPadding(padding,0,padding,0);
152
    mObjButton.setImageResource(icon);
153

    
154
    mObjButton.setOnClickListener( new View.OnClickListener()
155
      {
156
      @Override
157
      public void onClick(View view)
158
        {
159
        if( act.getPreRender().canPlay() )
160
          {
161
          mObjectPopup.setFocusable(false);
162
          mObjectPopup.update();
163

    
164
          View popupView = mObjectPopup.getContentView();
165
          popupView.setSystemUiVisibility(RubikActivity.FLAGS);
166

    
167
          mObjectPopup.showAsDropDown(view, margin, margin, Gravity.LEFT);
168
          mObjectPopup.update(view, mObjectSize*mColCount, mObjectSize*mRowCount);
169

    
170
          mObjectPopup.setFocusable(true);
171
          mObjectPopup.update();
172

    
173
          }
174
        }
175
      });
176
    }
177

    
178
///////////////////////////////////////////////////////////////////////////////////////////////////
179

    
180
  private void setupPlayButton(final RubikActivity act, final float width)
181
    {
182
    final int padding = (int)(width*RubikActivity.PADDING);
183
    final int margin  = (int)(width*RubikActivity.MARGIN);
184
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT, 1.2f);
185
    params.topMargin    = margin;
186
    params.bottomMargin = margin;
187
    params.leftMargin   = margin;
188
    params.rightMargin  = margin;
189

    
190
    mPlayButton = new Button(act);
191
    mPlayButton.setLayoutParams(params);
192
    mPlayButton.setPadding(padding,0,padding,0);
193
    mPlayButton.setTextSize(TypedValue.COMPLEX_UNIT_PX, mButtonSize);
194
    mPlayButton.setText(R.string.play);
195

    
196
    mPlayButton.setOnClickListener( new View.OnClickListener()
197
      {
198
      @Override
199
      public void onClick(View view)
200
        {
201
        mPlayPopup.setFocusable(false);
202
        mPlayPopup.update();
203

    
204
        View popupView = mPlayPopup.getContentView();
205
        popupView.setSystemUiVisibility(RubikActivity.FLAGS);
206

    
207
        mPlayPopup.showAsDropDown(view, margin, margin, Gravity.RIGHT);
208
        mPlayPopup.update(view, mPlayLayoutWidth, (int)(LEVELS_SHOWN*(mMenuItemSize+margin)+margin));
209

    
210
        mPlayPopup.setFocusable(true);
211
        mPlayPopup.update();
212
        }
213
      });
214
    }
215

    
216
///////////////////////////////////////////////////////////////////////////////////////////////////
217

    
218
  private void setupMenuButton(final RubikActivity act, final float width)
219
    {
220
    final int padding = (int)(width*RubikActivity.PADDING);
221
    final int margin  = (int)(width*RubikActivity.MARGIN);
222
    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);
223

    
224
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT, 1.2f);
225
    params.topMargin    = margin;
226
    params.bottomMargin = margin;
227
    params.leftMargin   = margin;
228
    params.rightMargin  = margin;
229

    
230
    mMenuButton = new ImageButton(act);
231
    mMenuButton.setLayoutParams(params);
232
    mMenuButton.setPadding(padding,0,padding,0);
233
    mMenuButton.setImageResource(icon);
234

    
235
    mMenuButton.setOnClickListener( new View.OnClickListener()
236
      {
237
      @Override
238
      public void onClick(View view)
239
        {
240
        if( act.getPreRender().canPlay() )
241
          {
242
          mMenuPopup.setFocusable(false);
243
          mMenuPopup.update();
244

    
245
          View popupView = mMenuPopup.getContentView();
246
          popupView.setSystemUiVisibility(RubikActivity.FLAGS);
247

    
248
          mMenuPopup.showAsDropDown(view, (int)(-width/12), margin, Gravity.CENTER);
249
          mMenuPopup.update(view, mMenuLayoutWidth, mMenuLayoutHeight);
250

    
251
          mMenuPopup.setFocusable(true);
252
          mMenuPopup.update();
253
          }
254
        }
255
      });
256
    }
257

    
258
///////////////////////////////////////////////////////////////////////////////////////////////////
259

    
260
  private void setupSolveButton(final RubikActivity act, final float width)
261
    {
262
    int padding  = (int)(width*RubikActivity.PADDING);
263
    int margin   = (int)(width*RubikActivity.MARGIN);
264
    int widthBut = (int)(width/6);
265
    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);
266

    
267
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(widthBut, LinearLayout.LayoutParams.MATCH_PARENT);
268
    params.topMargin    = margin;
269
    params.bottomMargin = margin;
270
    params.leftMargin   = margin;
271
    params.rightMargin  = margin;
272

    
273
    mSolveButton = new ImageButton(act);
274
    mSolveButton.setLayoutParams(params);
275
    mSolveButton.setPadding(padding,0,padding,0);
276
    mSolveButton.setImageResource(icon);
277

    
278
    mSolveButton.setOnClickListener( new View.OnClickListener()
279
      {
280
      @Override
281
      public void onClick(View v)
282
        {
283
        act.getPreRender().solveObject();
284
        mMoves.clear();
285
        }
286
      });
287
    }
288

    
289
///////////////////////////////////////////////////////////////////////////////////////////////////
290

    
291
  private void setupPrevButton(final RubikActivity act, final float width)
292
    {
293
    int padding  = (int)(width*RubikActivity.PADDING);
294
    int margin   = (int)(width*RubikActivity.MARGIN);
295
    int widthBut = (int)(width/6);
296
    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);
297

    
298
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(widthBut, LinearLayout.LayoutParams.MATCH_PARENT);
299
    params.topMargin    = margin;
300
    params.bottomMargin = margin;
301
    params.leftMargin   = margin;
302
    params.rightMargin  = margin;
303

    
304
    mPrevButton = new ImageButton(act);
305
    mPrevButton.setLayoutParams(params);
306
    mPrevButton.setPadding(padding,0,padding,0);
307
    mPrevButton.setImageResource(icon);
308

    
309
    mPrevButton.setOnClickListener( new View.OnClickListener()
310
      {
311
      @Override
312
      public void onClick(View v)
313
        {
314
        RubikPreRender pre = act.getPreRender();
315
        backMove(pre);
316
        }
317
      });
318
    }
319

    
320
///////////////////////////////////////////////////////////////////////////////////////////////////
321

    
322
  private void setupObjectWindow(final RubikActivity act, final float width)
323
    {
324
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
325
    final View layout = layoutInflater.inflate(R.layout.popup_objects, null);
326
    GridLayout objectGrid = layout.findViewById(R.id.objectGrid);
327

    
328
    int[] indices = RubikObjectList.getIndices();
329

    
330
    GridLayout.Spec[] rowSpecs = new GridLayout.Spec[mRowCount];
331
    GridLayout.Spec[] colSpecs = new GridLayout.Spec[mColCount];
332

    
333
    objectGrid.setColumnCount(mColCount);
334
    objectGrid.setRowCount(mRowCount);
335

    
336
    int[] nextInColumn = new int[mColCount];
337

    
338
    for(int row=0; row<mRowCount; row++)
339
      {
340
      rowSpecs[row] = GridLayout.spec(row);
341
      }
342
    for(int col=0; col<mColCount; col++)
343
      {
344
      colSpecs[col] = GridLayout.spec(col);
345
      nextInColumn[col] =0;
346
      }
347

    
348
    mObjectPopup = new PopupWindow(act);
349
    mObjectPopup.setContentView(layout);
350
    mObjectPopup.setFocusable(true);
351
    int icon = RubikActivity.getDrawable(R.drawable.ui_small_cube2,R.drawable.ui_medium_cube2, R.drawable.ui_big_cube2, R.drawable.ui_huge_cube2);
352

    
353
    BitmapDrawable bd = (BitmapDrawable) act.getResources().getDrawable(icon);
354
    int cubeWidth = bd.getIntrinsicWidth();
355
    int margin = (int)(width*RubikActivity.LARGE_MARGIN);
356
    mObjectSize = (int)(cubeWidth + 2*margin + 0.5f);
357

    
358
    for(int object=0; object<RubikObjectList.NUM_OBJECTS; object++)
359
      {
360
      final RubikObjectList list = RubikObjectList.getObject(object);
361
      final int[] sizes = list.getSizes();
362
      int[] icons = list.getIconIDs();
363
      int len = sizes.length;
364
      final int obj = object;
365
      int col = indices[object];
366

    
367
      for(int i=0; i<len; i++)
368
        {
369
        final int index = i;
370

    
371
        ImageButton button = new ImageButton(act);
372
        button.setBackgroundResource(icons[i]);
373
        button.setOnClickListener( new View.OnClickListener()
374
          {
375
          @Override
376
          public void onClick(View v)
377
            {
378
            if( act.getPreRender().canPlay() && RubikState.getCurrentState()==RubikState.PLAY )
379
              {
380
              mObject = obj;
381
              mSize   = sizes[index];
382
              act.changeObject(list,sizes[index], true);
383
              adjustLevels(act);
384
              mMoves.clear();
385
              }
386

    
387
            mObjectPopup.dismiss();
388
            }
389
          });
390

    
391
        GridLayout.LayoutParams params = new GridLayout.LayoutParams(rowSpecs[nextInColumn[col]],colSpecs[col]);
392
        params.bottomMargin = margin;
393
        params.topMargin    = margin;
394
        params.leftMargin   = margin;
395
        params.rightMargin  = margin;
396

    
397
        nextInColumn[col]++;
398

    
399
        objectGrid.addView(button, params);
400
        }
401
      }
402
    }
403

    
404
///////////////////////////////////////////////////////////////////////////////////////////////////
405

    
406
  private void setupMenuWindow(final RubikActivity act, final float width)
407
    {
408
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
409
    final View layout = layoutInflater.inflate(R.layout.popup_menu, null);
410
    LinearLayout menuLayout = layout.findViewById(R.id.menuGrid);
411

    
412
    mMenuPopup = new PopupWindow(act);
413
    mMenuPopup.setContentView(layout);
414
    mMenuPopup.setFocusable(true);
415
    int margin  = (int)(width*RubikActivity.MARGIN);
416
    int padding = (int)(width*RubikActivity.PADDING);
417

    
418
    mMenuLayoutWidth = (int)(width/2);
419
    mMenuLayoutHeight= (int)(2*margin + NUM_BUTTONS*(mMenuItemSize+margin));
420

    
421
    LinearLayout.LayoutParams pT = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
422
    pT.setMargins(margin, 0, margin, margin);
423
    LinearLayout.LayoutParams pM = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
424
    pM.setMargins(margin, margin, margin, margin);
425
    LinearLayout.LayoutParams pB = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
426
    pB.setMargins(margin, margin, margin, 2*margin);
427

    
428
    for(int i=0; i<NUM_BUTTONS; i++)
429
      {
430
      final int but = i;
431
      Button button = new Button(act);
432
      button.setLayoutParams(pT);//i==0 ? pT : (i==NUM_BUTTONS-1 ? pB : pM));
433
      button.setText(BUTTON_LABELS[i]);
434
      button.setTextSize(TypedValue.COMPLEX_UNIT_PX, mMenuTextSize);
435

    
436
      button.setOnClickListener( new View.OnClickListener()
437
        {
438
        @Override
439
        public void onClick(View v)
440
          {
441
          mMenuPopup.dismiss();
442
          MenuAction(act,but);
443
          }
444
        });
445

    
446
      menuLayout.addView(button);
447
      }
448
    }
449

    
450
///////////////////////////////////////////////////////////////////////////////////////////////////
451

    
452
  private void setupPlayWindow(final RubikActivity act, final float width)
453
    {
454
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
455
    final View layout = layoutInflater.inflate(R.layout.popup_play, null);
456
    mPlayLayout = layout.findViewById(R.id.playGrid);
457

    
458
    mPlayLayoutWidth = (int)(width*0.4f);
459

    
460
    mPlayPopup = new PopupWindow(act);
461
    mPlayPopup.setContentView(layout);
462
    mPlayPopup.setFocusable(true);
463

    
464
    adjustLevels(act);
465
    }
466

    
467
///////////////////////////////////////////////////////////////////////////////////////////////////
468

    
469
  private void backMove(RubikPreRender pre)
470
    {
471
    if( mCanPrevMove )
472
      {
473
      int numMoves = mMoves.size();
474

    
475
      if( numMoves>0 )
476
        {
477
        Move move = mMoves.remove(numMoves-1);
478
        RubikObject object = pre.getObject();
479

    
480
        int axis  = move.mAxis;
481
        int row   = (1<<move.mRow);
482
        int angle = move.mAngle;
483
        int numRot= Math.abs(angle*object.getBasicAngle()/360);
484

    
485
        if( angle!=0 )
486
          {
487
          mCanPrevMove = false;
488
          pre.addRotation(this, axis, row, -angle, numRot*DURATION_MILLIS);
489
          }
490
        else
491
          {
492
          android.util.Log.e("solution", "error: trying to back move of angle 0");
493
          }
494
        }
495
      }
496
    }
497

    
498
///////////////////////////////////////////////////////////////////////////////////////////////////
499

    
500
  private void MenuAction(RubikActivity act, int button)
501
    {
502
    switch(button)
503
      {
504
      case 0: RubikStatePlay play = (RubikStatePlay) RubikState.PLAY.getStateClass();
505
              int object = play.getObject();
506
              int size   = play.getSize();
507
              int sizeIndex = RubikObjectList.getSizeIndex(object,size);
508

    
509
              Bundle bundle = new Bundle();
510
              bundle.putInt("tab", RubikObjectList.pack(object,sizeIndex) );
511
              bundle.putBoolean("submitting", false);
512

    
513
              RubikDialogScores scores = new RubikDialogScores();
514
              scores.setArguments(bundle);
515
              scores.show(act.getSupportFragmentManager(), null);
516
              break;
517
      case 1: RubikState.switchState(act,RubikState.PATT);
518
              break;
519
      case 2: RubikState.switchState(act,RubikState.SVER);
520
              break;
521
      case 3: RubikDialogAbout diag = new RubikDialogAbout();
522
              diag.show(act.getSupportFragmentManager(), null);
523
              break;
524
      }
525
    }
526

    
527
///////////////////////////////////////////////////////////////////////////////////////////////////
528

    
529
  public void savePreferences(SharedPreferences.Editor editor)
530
    {
531
    editor.putInt("statePlay_object", mObject);
532
    editor.putInt("statePlay_size"  , mSize);
533

    
534
    if( mObjectPopup!=null )
535
      {
536
      mObjectPopup.dismiss();
537
      mObjectPopup = null;
538
      }
539

    
540
    if( mMenuPopup!=null )
541
      {
542
      mMenuPopup.dismiss();
543
      mMenuPopup = null;
544
      }
545

    
546
    if( mPlayPopup!=null )
547
      {
548
      mPlayPopup.dismiss();
549
      mPlayPopup = null;
550
      }
551
    }
552

    
553
///////////////////////////////////////////////////////////////////////////////////////////////////
554

    
555
  public void restorePreferences(SharedPreferences preferences)
556
    {
557
    mObject     = preferences.getInt("statePlay_object", DEF_OBJECT);
558
    mSize       = preferences.getInt("statePlay_size"  , DEF_SIZE  );
559
    }
560

    
561
///////////////////////////////////////////////////////////////////////////////////////////////////
562

    
563
  public boolean setObjectAndSize(RubikActivity act, RubikObjectList obj, int size)
564
    {
565
    if( mObject!=obj.ordinal() || mSize != size )
566
      {
567
      boolean success = false;
568

    
569
      for( int s: obj.getSizes() )
570
        if( s==size )
571
          {
572
          success = true;
573
          break;
574
          }
575

    
576
      if( success )
577
        {
578
        mObject = obj.ordinal();
579
        mSize   = size;
580

    
581
        if( mPlayLayout!=null ) adjustLevels(act);
582
        }
583

    
584
      return success;
585
      }
586

    
587
    return true;
588
    }
589

    
590
///////////////////////////////////////////////////////////////////////////////////////////////////
591

    
592
  private void adjustLevels(final RubikActivity act)
593
    {
594
    int sizeIndex = RubikObjectList.getSizeIndex(mObject,mSize);
595
    int maxLevel = RubikObjectList.getMaxLevel(mObject, sizeIndex);
596
    String[] levels = new String[maxLevel];
597

    
598
    for(int i=0; i<maxLevel; i++)
599
      {
600
      levels[i] = act.getString(R.string.lv_placeholder,i+1);
601
      }
602

    
603
    if( mLevelValue>maxLevel ) mLevelValue=1;
604

    
605
    float width = act.getScreenWidthInPixels();
606
    int margin  = (int)(width*RubikActivity.MARGIN);
607
    int padding = (int)(width*RubikActivity.PADDING);
608

    
609
    LinearLayout.LayoutParams pM = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
610
    pM.setMargins(margin, 0, margin, margin);
611
    LinearLayout.LayoutParams pT = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
612
    pT.setMargins(margin, margin, margin, margin);
613
    LinearLayout.LayoutParams pB = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
614
    pB.setMargins(margin, margin, margin, 2*margin);
615

    
616
    mPlayLayout.removeAllViews();
617

    
618
    int realSize= RubikObjectList.getSizeIndex(mObject,mSize);
619
    RubikScores scores = RubikScores.getInstance();
620

    
621
    for(int i=0; i<maxLevel; i++)
622
      {
623
      final int but = i;
624
      Button button = new Button(act);
625
      button.setLayoutParams(i==0 ? pT : (i==maxLevel-1 ? pB : pM));
626
      button.setText(levels[i]);
627
      button.setTextSize(TypedValue.COMPLEX_UNIT_PX, mMenuTextSize);
628

    
629
      int icon = scores.isSolved(mObject, realSize, i) ? R.drawable.ui_solved : R.drawable.ui_notsolved;
630
      button.setCompoundDrawablesWithIntrinsicBounds(icon,0,0,0);
631

    
632
      button.setOnClickListener( new View.OnClickListener()
633
        {
634
        @Override
635
        public void onClick(View v)
636
          {
637
          mPlayPopup.dismiss();
638
          mLevelValue = but+1;
639
          act.getPreRender().scrambleObject(mLevelValue);
640
          }
641
        });
642

    
643
      mPlayLayout.addView(button);
644
      }
645
    }
646

    
647
///////////////////////////////////////////////////////////////////////////////////////////////////
648

    
649
  int getLevel()
650
    {
651
    return mLevelValue;
652
    }
653

    
654
///////////////////////////////////////////////////////////////////////////////////////////////////
655

    
656
  public void addMove(int axis, int row, int angle)
657
    {
658
    mMoves.add(new Move(axis,row,angle));
659
    }
660

    
661
///////////////////////////////////////////////////////////////////////////////////////////////////
662

    
663
  public int getObject()
664
    {
665
    return mObject;
666
    }
667

    
668
///////////////////////////////////////////////////////////////////////////////////////////////////
669

    
670
  public int getSize()
671
    {
672
    return mSize;
673
    }
674

    
675
///////////////////////////////////////////////////////////////////////////////////////////////////
676

    
677
  public void onActionFinished(final long effectID)
678
    {
679
    mCanPrevMove = true;
680
    }
681
  }
(5-5/9)