Project

General

Profile

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

magiccube / src / main / java / org / distorted / states / RubikStatePlay.java @ d7e539d0

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 GridLayout mObjectGrid;
66
  private int mLevelValue;
67
  private float mButtonSize, mMenuItemSize, mMenuTextSize;
68
  private int mColCount, mRowCount;
69
  private LinearLayout mPlayLayout;
70

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

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

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

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

    
88
  void leaveState(RubikActivity act)
89
    {
90

    
91
    }
92

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

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

    
102
    mCanPrevMove = true;
103

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

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

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

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

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

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

    
126
    // BOT ////////////////////////////
127
    LinearLayout layoutLeft = act.findViewById(R.id.mainBarLeft);
128
    layoutLeft.removeAllViews();
129

    
130
    setupPrevButton(act,width);
131
    layoutLeft.addView(mPrevButton);
132
    setupSolveButton(act,width);
133
    layoutLeft.addView(mSolveButton);
134

    
135
    LinearLayout layoutRight = act.findViewById(R.id.mainBarRight);
136
    layoutRight.removeAllViews();
137
    }
138

    
139
///////////////////////////////////////////////////////////////////////////////////////////////////
140

    
141
  private void setupObjectButton(final RubikActivity act, final float width)
142
    {
143
    final int padding = (int)(width*RubikActivity.PADDING);
144
    final int margin  = (int)(width*RubikActivity.MARGIN);
145
    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);
146

    
147
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT, 1.2f);
148
    params.topMargin    = margin;
149
    params.bottomMargin = margin;
150
    params.leftMargin   = margin;
151
    params.rightMargin  = margin;
152

    
153
    mObjButton = new ImageButton(act);
154
    mObjButton.setLayoutParams(params);
155
    mObjButton.setPadding(padding,0,padding,0);
156
    mObjButton.setImageResource(icon);
157

    
158
    mObjButton.setOnClickListener( new View.OnClickListener()
159
      {
160
      @Override
161
      public void onClick(View view)
162
        {
163
        if( act.getPreRender().canPlay() )
164
          {
165
          boolean vertical = act.isVertical();
166
          mObjectGrid.setOrientation(vertical ? GridLayout.VERTICAL:GridLayout.HORIZONTAL);
167
          mObjectPopup.showAsDropDown(view, margin, margin, Gravity.LEFT);
168

    
169
          int layhei = mObjectSize * (vertical? mRowCount:mColCount);
170
          int laywid = mObjectSize * (vertical? mColCount:mRowCount);
171
          mObjectPopup.update(view, laywid, layhei);
172
          }
173
        }
174
      });
175
    }
176

    
177
///////////////////////////////////////////////////////////////////////////////////////////////////
178

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

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

    
195
    mPlayButton.setOnClickListener( new View.OnClickListener()
196
      {
197
      @Override
198
      public void onClick(View view)
199
        {
200
        mPlayPopup.showAsDropDown(view, margin, margin, Gravity.RIGHT);
201
        mPlayPopup.update(view, mPlayLayoutWidth, (int)(LEVELS_SHOWN*(mMenuItemSize+margin)+margin));
202
        }
203
      });
204
    }
205

    
206
///////////////////////////////////////////////////////////////////////////////////////////////////
207

    
208
  private void setupMenuButton(final RubikActivity act, final float width)
209
    {
210
    final int padding = (int)(width*RubikActivity.PADDING);
211
    final int margin  = (int)(width*RubikActivity.MARGIN);
212
    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);
213

    
214
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT, 1.2f);
215
    params.topMargin    = margin;
216
    params.bottomMargin = margin;
217
    params.leftMargin   = margin;
218
    params.rightMargin  = margin;
219

    
220
    mMenuButton = new ImageButton(act);
221
    mMenuButton.setLayoutParams(params);
222
    mMenuButton.setPadding(padding,0,padding,0);
223
    mMenuButton.setImageResource(icon);
224

    
225
    mMenuButton.setOnClickListener( new View.OnClickListener()
226
      {
227
      @Override
228
      public void onClick(View view)
229
        {
230
        if( act.getPreRender().canPlay() )
231
          {
232
          mMenuPopup.showAsDropDown(view, (int)(-width/12), margin, Gravity.CENTER);
233
          mMenuPopup.update(view, mMenuLayoutWidth, mMenuLayoutHeight);
234
          }
235
        }
236
      });
237
    }
238

    
239
///////////////////////////////////////////////////////////////////////////////////////////////////
240

    
241
  private void setupSolveButton(final RubikActivity act, final float width)
242
    {
243
    int padding  = (int)(width*RubikActivity.PADDING);
244
    int margin   = (int)(width*RubikActivity.MARGIN);
245
    int widthBut = (int)(width/6);
246
    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);
247

    
248
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(widthBut, LinearLayout.LayoutParams.MATCH_PARENT);
249
    params.topMargin    = margin;
250
    params.bottomMargin = margin;
251
    params.leftMargin   = margin;
252
    params.rightMargin  = margin;
253

    
254
    mSolveButton = new ImageButton(act);
255
    mSolveButton.setLayoutParams(params);
256
    mSolveButton.setPadding(padding,0,padding,0);
257
    mSolveButton.setImageResource(icon);
258

    
259
    mSolveButton.setOnClickListener( new View.OnClickListener()
260
      {
261
      @Override
262
      public void onClick(View v)
263
        {
264
        act.getPreRender().solveObject();
265
        mMoves.clear();
266
        }
267
      });
268
    }
269

    
270
///////////////////////////////////////////////////////////////////////////////////////////////////
271

    
272
  private void setupPrevButton(final RubikActivity act, final float width)
273
    {
274
    int padding  = (int)(width*RubikActivity.PADDING);
275
    int margin   = (int)(width*RubikActivity.MARGIN);
276
    int widthBut = (int)(width/6);
277
    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);
278

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

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

    
290
    mPrevButton.setOnClickListener( new View.OnClickListener()
291
      {
292
      @Override
293
      public void onClick(View v)
294
        {
295
        RubikPreRender pre = act.getPreRender();
296
        backMove(pre);
297
        }
298
      });
299
    }
300

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

    
303
  private void setupObjectWindow(final RubikActivity act, final float width)
304
    {
305
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
306
    final View layout = layoutInflater.inflate(R.layout.popup_objects, null);
307
    mObjectGrid = layout.findViewById(R.id.objectGrid);
308

    
309
    int[] indices = RubikObjectList.getIndices();
310

    
311
    GridLayout.Spec[] rowSpecs = new GridLayout.Spec[mRowCount];
312
    GridLayout.Spec[] colSpecs = new GridLayout.Spec[mColCount];
313

    
314
    mObjectGrid.setColumnCount(mColCount);
315
    mObjectGrid.setRowCount(mRowCount);
316

    
317
    int[] nextInColumn = new int[mColCount];
318

    
319
    for(int row=0; row<mRowCount; row++)
320
      {
321
      rowSpecs[row] = GridLayout.spec(row);
322
      }
323
    for(int col=0; col<mColCount; col++)
324
      {
325
      colSpecs[col] = GridLayout.spec(col);
326
      nextInColumn[col] =0;
327
      }
328

    
329
    mObjectPopup = new PopupWindow(act);
330
    mObjectPopup.setContentView(layout);
331
    mObjectPopup.setFocusable(true);
332
    int icon = RubikActivity.getDrawable(R.drawable.ui_small_cube2,R.drawable.ui_medium_cube2, R.drawable.ui_big_cube2, R.drawable.ui_huge_cube2);
333

    
334
    BitmapDrawable bd = (BitmapDrawable) act.getResources().getDrawable(icon);
335
    int cubeWidth = bd.getIntrinsicWidth();
336
    int margin = (int)(width*RubikActivity.LARGE_MARGIN);
337
    mObjectSize = (int)(cubeWidth + 2*margin + 0.5f);
338

    
339
    for(int object=0; object<RubikObjectList.NUM_OBJECTS; object++)
340
      {
341
      final RubikObjectList list = RubikObjectList.getObject(object);
342
      final int[] sizes = list.getSizes();
343
      int[] icons = list.getIconIDs();
344
      int len = sizes.length;
345
      final int obj = object;
346
      int col = indices[object];
347

    
348
      for(int i=0; i<len; i++)
349
        {
350
        final int index = i;
351

    
352
        ImageButton button = new ImageButton(act);
353
        button.setBackgroundResource(icons[i]);
354
        button.setOnClickListener( new View.OnClickListener()
355
          {
356
          @Override
357
          public void onClick(View v)
358
            {
359
            if( act.getPreRender().canPlay() && RubikState.getCurrentState()==RubikState.PLAY )
360
              {
361
              mObject = obj;
362
              mSize   = sizes[index];
363
              act.changeObject(list,sizes[index], true);
364
              adjustLevels(act);
365
              mMoves.clear();
366
              }
367

    
368
            mObjectPopup.dismiss();
369
            }
370
          });
371

    
372
        GridLayout.LayoutParams params = new GridLayout.LayoutParams(rowSpecs[nextInColumn[col]],colSpecs[col]);
373
        params.bottomMargin = margin;
374
        params.topMargin    = margin;
375
        params.leftMargin   = margin;
376
        params.rightMargin  = margin;
377

    
378
        nextInColumn[col]++;
379

    
380
        mObjectGrid.addView(button, params);
381
        }
382
      }
383
    }
384

    
385
///////////////////////////////////////////////////////////////////////////////////////////////////
386

    
387
  private void setupMenuWindow(final RubikActivity act, final float width)
388
    {
389
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
390
    final View layout = layoutInflater.inflate(R.layout.popup_menu, null);
391
    LinearLayout menuLayout = layout.findViewById(R.id.menuGrid);
392

    
393
    mMenuPopup = new PopupWindow(act);
394
    mMenuPopup.setContentView(layout);
395
    mMenuPopup.setFocusable(true);
396
    int margin  = (int)(width*RubikActivity.MARGIN);
397
    int padding = (int)(width*RubikActivity.PADDING);
398

    
399
    mMenuLayoutWidth = (int)(width/2);
400
    mMenuLayoutHeight= (int)(2*margin + NUM_BUTTONS*(mMenuItemSize+margin));
401

    
402
    LinearLayout.LayoutParams pT = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
403
    pT.setMargins(margin, 0, margin, margin);
404
    LinearLayout.LayoutParams pM = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
405
    pM.setMargins(margin, margin, margin, margin);
406
    LinearLayout.LayoutParams pB = new LinearLayout.LayoutParams( mMenuLayoutWidth - 2*padding, (int)mMenuItemSize);
407
    pB.setMargins(margin, margin, margin, 2*margin);
408

    
409
    for(int i=0; i<NUM_BUTTONS; i++)
410
      {
411
      final int but = i;
412
      Button button = new Button(act);
413
      button.setLayoutParams(pT);//i==0 ? pT : (i==NUM_BUTTONS-1 ? pB : pM));
414
      button.setText(BUTTON_LABELS[i]);
415
      button.setTextSize(TypedValue.COMPLEX_UNIT_PX, mMenuTextSize);
416

    
417
      button.setOnClickListener( new View.OnClickListener()
418
        {
419
        @Override
420
        public void onClick(View v)
421
          {
422
          mMenuPopup.dismiss();
423
          MenuAction(act,but);
424
          }
425
        });
426

    
427
      menuLayout.addView(button);
428
      }
429
    }
430

    
431
///////////////////////////////////////////////////////////////////////////////////////////////////
432

    
433
  private void setupPlayWindow(final RubikActivity act, final float width)
434
    {
435
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
436
    final View layout = layoutInflater.inflate(R.layout.popup_play, null);
437
    mPlayLayout = layout.findViewById(R.id.playGrid);
438

    
439
    mPlayLayoutWidth = (int)(width*0.4f);
440

    
441
    mPlayPopup = new PopupWindow(act);
442
    mPlayPopup.setContentView(layout);
443
    mPlayPopup.setFocusable(true);
444

    
445
    adjustLevels(act);
446
    }
447

    
448
///////////////////////////////////////////////////////////////////////////////////////////////////
449

    
450
  private void backMove(RubikPreRender pre)
451
    {
452
    if( mCanPrevMove )
453
      {
454
      int numMoves = mMoves.size();
455

    
456
      if( numMoves>0 )
457
        {
458
        Move move = mMoves.remove(numMoves-1);
459
        RubikObject object = pre.getObject();
460

    
461
        int axis  = move.mAxis;
462
        int row   = (1<<move.mRow);
463
        int angle = move.mAngle;
464
        int numRot= Math.abs(angle*object.getBasicAngle()/360);
465

    
466
        if( angle!=0 )
467
          {
468
          mCanPrevMove = false;
469
          pre.addRotation(this, axis, row, -angle, numRot*DURATION_MILLIS);
470
          }
471
        else
472
          {
473
          android.util.Log.e("solution", "error: trying to back move of angle 0");
474
          }
475
        }
476
      }
477
    }
478

    
479
///////////////////////////////////////////////////////////////////////////////////////////////////
480

    
481
  private void MenuAction(RubikActivity act, int button)
482
    {
483
    switch(button)
484
      {
485
      case 0: RubikStatePlay play = (RubikStatePlay) RubikState.PLAY.getStateClass();
486
              int object = play.getObject();
487
              int size   = play.getSize();
488
              int sizeIndex = RubikObjectList.getSizeIndex(object,size);
489

    
490
              Bundle bundle = new Bundle();
491
              bundle.putInt("tab", RubikObjectList.pack(object,sizeIndex) );
492
              bundle.putBoolean("submitting", false);
493

    
494
              RubikDialogScores scores = new RubikDialogScores();
495
              scores.setArguments(bundle);
496
              scores.show(act.getSupportFragmentManager(), null);
497
              break;
498
      case 1: RubikState.switchState(act,RubikState.PATT);
499
              break;
500
      case 2: RubikState.switchState(act,RubikState.SVER);
501
              break;
502
      case 3: RubikDialogAbout diag = new RubikDialogAbout();
503
              diag.show(act.getSupportFragmentManager(), null);
504
              break;
505
      }
506
    }
507

    
508
///////////////////////////////////////////////////////////////////////////////////////////////////
509

    
510
  public void savePreferences(SharedPreferences.Editor editor)
511
    {
512
    editor.putInt("statePlay_object", mObject);
513
    editor.putInt("statePlay_size"  , mSize);
514

    
515
    if( mObjectPopup!=null )
516
      {
517
      mObjectPopup.dismiss();
518
      mObjectPopup = null;
519
      }
520

    
521
    if( mMenuPopup!=null )
522
      {
523
      mMenuPopup.dismiss();
524
      mMenuPopup = null;
525
      }
526

    
527
    if( mPlayPopup!=null )
528
      {
529
      mPlayPopup.dismiss();
530
      mPlayPopup = null;
531
      }
532
    }
533

    
534
///////////////////////////////////////////////////////////////////////////////////////////////////
535

    
536
  public void restorePreferences(SharedPreferences preferences)
537
    {
538
    mObject     = preferences.getInt("statePlay_object", DEF_OBJECT);
539
    mSize       = preferences.getInt("statePlay_size"  , DEF_SIZE  );
540
    }
541

    
542
///////////////////////////////////////////////////////////////////////////////////////////////////
543

    
544
  public boolean setObjectAndSize(RubikActivity act, RubikObjectList obj, int size)
545
    {
546
    if( mObject!=obj.ordinal() || mSize != size )
547
      {
548
      boolean success = false;
549

    
550
      for( int s: obj.getSizes() )
551
        if( s==size )
552
          {
553
          success = true;
554
          break;
555
          }
556

    
557
      if( success )
558
        {
559
        mObject = obj.ordinal();
560
        mSize   = size;
561

    
562
        if( mPlayLayout!=null ) adjustLevels(act);
563
        }
564

    
565
      return success;
566
      }
567

    
568
    return true;
569
    }
570

    
571
///////////////////////////////////////////////////////////////////////////////////////////////////
572

    
573
  private void adjustLevels(final RubikActivity act)
574
    {
575
    int sizeIndex = RubikObjectList.getSizeIndex(mObject,mSize);
576
    int maxLevel = RubikObjectList.getMaxLevel(mObject, sizeIndex);
577
    String[] levels = new String[maxLevel];
578

    
579
    for(int i=0; i<maxLevel; i++)
580
      {
581
      levels[i] = act.getString(R.string.lv_placeholder,i+1);
582
      }
583

    
584
    if( mLevelValue>maxLevel ) mLevelValue=1;
585

    
586
    float width = act.getScreenWidthInPixels();
587
    int margin  = (int)(width*RubikActivity.MARGIN);
588
    int padding = (int)(width*RubikActivity.PADDING);
589

    
590
    LinearLayout.LayoutParams pM = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
591
    pM.setMargins(margin, 0, margin, margin);
592
    LinearLayout.LayoutParams pT = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
593
    pT.setMargins(margin, margin, margin, margin);
594
    LinearLayout.LayoutParams pB = new LinearLayout.LayoutParams( mPlayLayoutWidth - 2*padding, (int)mMenuItemSize);
595
    pB.setMargins(margin, margin, margin, 2*margin);
596

    
597
    mPlayLayout.removeAllViews();
598

    
599
    int realSize= RubikObjectList.getSizeIndex(mObject,mSize);
600
    RubikScores scores = RubikScores.getInstance();
601

    
602
    for(int i=0; i<maxLevel; i++)
603
      {
604
      final int but = i;
605
      Button button = new Button(act);
606
      button.setLayoutParams(i==0 ? pT : (i==maxLevel-1 ? pB : pM));
607
      button.setText(levels[i]);
608
      button.setTextSize(TypedValue.COMPLEX_UNIT_PX, mMenuTextSize);
609

    
610
      int icon = scores.isSolved(mObject, realSize, i) ? R.drawable.ui_solved : R.drawable.ui_notsolved;
611
      button.setCompoundDrawablesWithIntrinsicBounds(icon,0,0,0);
612

    
613
      button.setOnClickListener( new View.OnClickListener()
614
        {
615
        @Override
616
        public void onClick(View v)
617
          {
618
          mPlayPopup.dismiss();
619
          mLevelValue = but+1;
620
          act.getPreRender().scrambleObject(mLevelValue);
621
          }
622
        });
623

    
624
      mPlayLayout.addView(button);
625
      }
626
    }
627

    
628
///////////////////////////////////////////////////////////////////////////////////////////////////
629

    
630
  int getLevel()
631
    {
632
    return mLevelValue;
633
    }
634

    
635
///////////////////////////////////////////////////////////////////////////////////////////////////
636

    
637
  public void addMove(int axis, int row, int angle)
638
    {
639
    mMoves.add(new Move(axis,row,angle));
640
    }
641

    
642
///////////////////////////////////////////////////////////////////////////////////////////////////
643

    
644
  public int getObject()
645
    {
646
    return mObject;
647
    }
648

    
649
///////////////////////////////////////////////////////////////////////////////////////////////////
650

    
651
  public int getSize()
652
    {
653
    return mSize;
654
    }
655

    
656
///////////////////////////////////////////////////////////////////////////////////////////////////
657

    
658
  public void onActionFinished(final long effectID)
659
    {
660
    mCanPrevMove = true;
661
    }
662
  }
(5-5/9)