Project

General

Profile

« Previous | Next » 

Revision aa171dee

Added by Leszek Koltunski almost 5 years ago

More support for actual patterns!

View differences:

src/main/java/org/distorted/dialog/RubikDialogPatternView.java
150 150
        public void onClick(View view)
151 151
          {
152 152
          RubikStatePattern state = (RubikStatePattern) RubikState.PATT.getStateClass();
153
          state.setPattern(mTab, category, ii);
153
          state.setPattern(act, mTab, category, ii);
154 154
          int[] sizes = RubikObjectList.CUBE.getSizes();
155
          act.changeObject(RubikObjectList.CUBE,sizes[mTab]);
155
          RubikPattern pattern = RubikPattern.getInstance();
156
          String moves = pattern.getMoves(mTab, category, ii);
157
          act.changeObject(RubikObjectList.CUBE,sizes[mTab],moves);
156 158
          mDialog.rememberCategories();
157 159
          mDialog.dismiss();
158 160
          }
src/main/java/org/distorted/magic/RubikActivity.java
31 31
import org.distorted.effect.BaseEffect;
32 32
import org.distorted.library.main.DistortedLibrary;
33 33

  
34
import org.distorted.object.RubikObject;
34 35
import org.distorted.scores.RubikScores;
35 36
import org.distorted.scores.RubikScoresDownloader;
36 37
import org.distorted.object.RubikObjectList;
......
101 102
        if( sizeIndex>=0 && sizeIndex<sizes.length )
102 103
          {
103 104
          success = true;
104
          view.getRenderer().createObject( obj, size );
105
          view.getRenderer().changeObject( obj, size, null );
105 106
          }
106 107

  
107 108
        }
......
112 113
        int s = RubikStatePlay.DEF_SIZE;
113 114

  
114 115
        play.setObjectAndSize(obj,s);
115
        view.getRenderer().createObject(obj,s);
116
        view.getRenderer().changeObject(obj,s, null);
116 117
        }
117 118
      }
118 119
    
......
175 176
// PUBLIC API
176 177
///////////////////////////////////////////////////////////////////////////////////////////////////
177 178

  
178
    public void changeObject(RubikObjectList object, int size)
179
    public RubikObject getObject()
180
      {
181
      RubikSurfaceView view = findViewById(R.id.rubikSurfaceView);
182
      RubikRenderer renderer = view.getRenderer();
183
      return renderer.getObject();
184
      }
185

  
186
///////////////////////////////////////////////////////////////////////////////////////////////////
187

  
188
    public void changeObject(RubikObjectList object, int size, String moves)
179 189
      {
180 190
      RubikSurfaceView view = findViewById(R.id.rubikSurfaceView);
181 191
      RubikRenderer renderer = view.getRenderer();
182 192

  
183 193
      if( renderer.canDrag() )
184 194
        {
185
        renderer.createObject(object,size);
195
        renderer.changeObject(object,size,moves);
186 196
        }
187 197
      }
188 198

  
src/main/java/org/distorted/magic/RubikRenderer.java
61 61
    private RubikObject mOldObject, mNewObject;
62 62
    private int mScreenWidth, mScreenHeight;
63 63
    private SharedPreferences mPreferences;
64
    private String mNextMoves;
64 65

  
65 66
///////////////////////////////////////////////////////////////////////////////////////////////////
66 67

  
......
92 93

  
93 94
///////////////////////////////////////////////////////////////////////////////////////////////////
94 95

  
95
   private void createObjectNow(RubikObjectList object, int size)
96
   private void createObjectNow(RubikObjectList object, int size, String moves)
96 97
     {
97 98
     boolean firstTime = (mNewObject==null);
98 99

  
99 100
     if( mOldObject!=null ) mOldObject.releaseResources();
100 101
     mOldObject = mNewObject;
101 102

  
102
     mNewObject = object.create(size, mView.getQuatCurrent(), mView.getQuatAccumulated());
103
     mNewObject = object.create(size, mView.getQuatCurrent(), mView.getQuatAccumulated(), moves);
103 104
     mNewObject.createTexture();
104 105
     mView.setMovement(object.getObjectMovementClass());
105 106

  
......
161 162

  
162 163
///////////////////////////////////////////////////////////////////////////////////////////////////
163 164

  
164
   void createObject(RubikObjectList object, int size)
165
   void changeObject(RubikObjectList object, int size, String moves)
165 166
     {
166
     if( (object!=mNextObject || mNextSize!=size) && size>0 )
167
     if( size>0 )
167 168
       {
168 169
       mChangeObject = true;
169 170
       mNextObject = object;
170 171
       mNextSize   = size;
172
       mNextMoves  = moves;
171 173
       }
172 174
     }
173 175

  
......
192 194
       }
193 195
     }
194 196

  
195
///////////////////////////////////////////////////////////////////////////////////////////////////
196

  
197
   void setCanRotate(boolean can)
198
     {
199
     mCanRotate = can;
200
     }
201

  
202 197
///////////////////////////////////////////////////////////////////////////////////////////////////
203 198

  
204 199
   boolean canRotate()
......
307 302
       mCanDrag      = false;
308 303
       mCanRotate    = false;
309 304
       mCanUI        = false;
310
       createObjectNow(mNextObject, mNextSize);
311
       doEffectNow( BaseEffect.Type.SIZECHANGE );
305

  
306
       if( mNewObject==null )
307
         {
308
         createObjectNow(mNextObject, mNextSize, mNextMoves);
309
         doEffectNow( BaseEffect.Type.SIZECHANGE );
310
         }
311
       else
312
         {
313
         RubikObjectList list = mNewObject.getObjectList();
314
         int size = mNewObject.getSize();
315

  
316
         if (list!=mNextObject || mNextSize!=size)
317
           {
318
           createObjectNow(mNextObject, mNextSize, mNextMoves);
319
           doEffectNow( BaseEffect.Type.SIZECHANGE );
320
           }
321
         else
322
           {
323
           mNewObject.initializeObject(mNextMoves);
324
           }
325
         }
312 326
       }
313 327

  
314 328
     if( mSolveObject )
src/main/java/org/distorted/object/RubikCube.java
78 78

  
79 79
///////////////////////////////////////////////////////////////////////////////////////////////////
80 80

  
81
  RubikCube(int size, Static4D quatCur, Static4D quatAcc, DistortedTexture texture, MeshRectangles mesh, DistortedEffects effects)
81
  RubikCube(int size, Static4D quatCur, Static4D quatAcc, DistortedTexture texture, MeshRectangles mesh, DistortedEffects effects, String moves)
82 82
    {
83
    super(size, 60, quatCur,quatAcc,texture,mesh,effects);
83
    super(size, 60, quatCur,quatAcc,texture,mesh,effects,moves, RubikObjectList.CUBE);
84 84
    }
85 85

  
86 86
///////////////////////////////////////////////////////////////////////////////////////////////////
src/main/java/org/distorted/object/RubikObject.java
60 60
  private Static4D mQuatAccumulated;
61 61
  private Cubit[] mCubits;
62 62
  private int mSize;
63
  private RubikObjectList mList;
63 64

  
64 65
  float mStart, mStep;
65 66

  
......
73 74

  
74 75
///////////////////////////////////////////////////////////////////////////////////////////////////
75 76

  
76
  RubikObject(int size, int fov, Static4D quatCur, Static4D quatAcc, DistortedTexture nodeTexture, MeshRectangles nodeMesh, DistortedEffects nodeEffects)
77
  RubikObject(int size, int fov, Static4D quatCur, Static4D quatAcc, DistortedTexture nodeTexture,
78
              MeshRectangles nodeMesh, DistortedEffects nodeEffects, String moves, RubikObjectList list)
77 79
    {
78 80
    super(nodeTexture,nodeEffects,nodeMesh);
79 81

  
80 82
    resizeFBO(NODE_FBO_SIZE, NODE_FBO_SIZE);
81 83

  
84
    mList = list;
82 85
    mOrigPos = getCubitPositions(size);
83 86

  
84 87
    LEGAL_QUATS = getLegalQuats();
......
122 125
      attach(mCubits[i].mNode);
123 126
      }
124 127

  
128
    setupPosition(moves);
129

  
125 130
    setProjection(fov, 0.1f);
126 131
    }
127 132

  
......
214 219
    rotationAngle.add(mRotationAngleFinal);
215 220
    }
216 221

  
222
///////////////////////////////////////////////////////////////////////////////////////////////////
223
// TODO
224

  
225
	private boolean scheduleMultiRotation(int rotV, int rotRC, int rotA)
226
	  {
227
	  /*
228
		int index, tmp;
229

  
230
		if( numRotations>0 )
231
		  {
232
			if( rotVector!=rotV ) return false;
233

  
234
			index=0;
235
			tmp=rotRC;
236

  
237
			while( tmp!=0 )
238
			  {
239
				if( (tmp&0x1)==1 && rotAngle[index]!=0 ) return false;
240
				index++;
241
				tmp/=2;
242
			  }
243
		  }
244

  
245
		index=0;
246
		tmp=rotRC;
247
		rotVector = rotV;
248

  
249
		while( tmp!=0 )
250
		  {
251
			if( (tmp&0x1)==1 )
252
			  {
253
				rotAngle[index] = rotA*90;
254
				rotSpeed[index] = (int)(rotS/RubikWorld.hardwareSpeed);
255

  
256
				if( rotSpeed[index]<=0 && rotS>0 ) rotSpeed[index] = 1;
257
				if( rotSpeed[index]>=0 && rotS<0 ) rotSpeed[index] =-1;
258

  
259
				numRotations++;
260
			  }
261

  
262
			index++;
263
			tmp/=2;
264
		  }
265
    */
266
		return true;
267
	  }
268

  
269
///////////////////////////////////////////////////////////////////////////////////////////////////
270
// TODO
271

  
272
  private void setupPosition(String moves)
273
    {
274
    android.util.Log.e("object", "initializing: "+moves);
275
/*
276
    int index,tmp, a1,a2,a3, rv, rc, ra;
277

  
278
		numRotations=0;
279
		initializeVertices(mSize);
280

  
281
		int len=moves.length()/4;
282

  
283
		for(int i=0; i<len; i++)
284
		  {
285
			a1=moves.charAt(4*i+1)-'0';
286
			a2=moves.charAt(4*i+2)-'0';
287
			a3=moves.charAt(4*i+3)-'0';
288

  
289
			rv = (10*a1+a2)/32;
290
			rc = (10*a1+a2)%32;
291
			ra = 2-a3;
292

  
293
			rotVector = rv;
294

  
295
			tmp=rc;
296
			index=0;
297

  
298
			while( tmp!=0 )
299
			  {
300
				if( (tmp&0x1)==1 )
301
				  {
302
					rotAngle[index] = ra*90;
303
					RubikWorld.setIdentity(rotMat[index]);
304

  
305
					switch(rotVector)
306
					  {
307
					  case VECTX: RubikWorld.postRotate( rotMat[index], (float)((ra*90)%360), 1f,0f,0f); break;
308
					  case VECTY: RubikWorld.postRotate( rotMat[index], (float)((ra*90)%360), 0f,1f,0f); break;
309
					  case VECTZ: RubikWorld.postRotate( rotMat[index], (float)((ra*90)%360), 0f,0f,1f); break;
310
					  }
311

  
312
					transposeTiles(index);
313
					rotAngle[index]=0;
314
				  }
315

  
316
				tmp/=2;
317
				index++;
318
			  }
319
	  	}
320
 */
321
    }
322

  
217 323
///////////////////////////////////////////////////////////////////////////////////////////////////
218 324
// Clamp all rotated positions to one of those original ones to avoid accumulating errors.
219 325

  
......
461 567
     mRotationAngleStatic.set0(0);
462 568
     }
463 569

  
570
///////////////////////////////////////////////////////////////////////////////////////////////////
571

  
572
  public boolean makeMove(String move)
573
    {
574
    int a1=move.charAt(1)-'0';
575
		int a2=move.charAt(2)-'0';
576
		int a3=move.charAt(3)-'0';
577

  
578
    int rotVector = (10*a1+a2)/32; // 0 --> VECTX, 1--> VECTY, 2 --> VECTZ
579
    int rotBitmap = (10*a1+a2)%32; // 01010 --> move the 2nd and 4th layer
580
    int rotAngle  = 2-a3;          // counterclockwise by rotAngle*90 degrees
581

  
582
		return scheduleMultiRotation(rotVector, rotBitmap, rotAngle);
583
    }
584

  
585
///////////////////////////////////////////////////////////////////////////////////////////////////
586

  
587
  public boolean backMove(String move)
588
    {
589
    int a1=move.charAt(1)-'0';
590
		int a2=move.charAt(2)-'0';
591
		int a3=move.charAt(3)-'0';
592

  
593
    int rotVector = (10*a1+a2)/32;
594
    int rotBitmap = (10*a1+a2)%32;
595
    int rotAngle  = a3-2;
596

  
597
		return scheduleMultiRotation(rotVector, rotBitmap, rotAngle);
598
    }
599

  
600
///////////////////////////////////////////////////////////////////////////////////////////////////
601

  
602
  public void initializeObject(String moves)
603
    {
604
    solve();
605
    setupPosition(moves);
606
    }
607

  
608
///////////////////////////////////////////////////////////////////////////////////////////////////
609

  
610
  public RubikObjectList getObjectList()
611
    {
612
    return mList;
613
    }
614

  
464 615
///////////////////////////////////////////////////////////////////////////////////////////////////
465 616

  
466 617
  abstract float getScreenRatio();
src/main/java/org/distorted/object/RubikObjectList.java
245 245

  
246 246
///////////////////////////////////////////////////////////////////////////////////////////////////
247 247

  
248
  public RubikObject create(int size, Static4D quatCur, Static4D quatAcc)
248
  public RubikObject create(int size, Static4D quatCur, Static4D quatAcc, String moves)
249 249
    {
250 250
    DistortedTexture texture = new DistortedTexture();
251 251
    DistortedEffects effects = new DistortedEffects();
......
253 253

  
254 254
    switch(ordinal())
255 255
      {
256
      case 0: return new RubikCube    (size, quatCur, quatAcc, texture, mesh, effects);
257
      case 1: return new RubikPyraminx(size, quatCur, quatAcc, texture, mesh, effects);
256
      case 0: return new RubikCube    (size, quatCur, quatAcc, texture, mesh, effects, moves);
257
      case 1: return new RubikPyraminx(size, quatCur, quatAcc, texture, mesh, effects, moves);
258 258
      }
259 259

  
260 260
    return null;
src/main/java/org/distorted/object/RubikPyraminx.java
83 83

  
84 84
///////////////////////////////////////////////////////////////////////////////////////////////////
85 85

  
86
  RubikPyraminx(int size, Static4D quatCur, Static4D quatAcc, DistortedTexture texture, MeshRectangles mesh, DistortedEffects effects)
86
  RubikPyraminx(int size, Static4D quatCur, Static4D quatAcc, DistortedTexture texture, MeshRectangles mesh, DistortedEffects effects, String moves)
87 87
    {
88
    super(size, 30, quatCur,quatAcc,texture,mesh,effects);
88
    super(size, 30, quatCur,quatAcc,texture,mesh,effects,moves, RubikObjectList.PYRA);
89 89
    }
90 90

  
91 91
///////////////////////////////////////////////////////////////////////////////////////////////////
src/main/java/org/distorted/patterns/RubikPattern.java
19 19

  
20 20
package org.distorted.patterns;
21 21

  
22
import org.distorted.object.RubikObject;
23

  
22 24
import java.util.Vector;
23 25

  
24 26
///////////////////////////////////////////////////////////////////////////////////////////////////
......
111 113

  
112 114
  /////////////////////////////////////////////////////////////
113 115

  
114
    String retInitializationString(int pattern)
116
    void makeMove(RubikObject object, int pattern)
115 117
      {
116 118
      if( pattern>=0 && pattern<numPatterns )
117 119
        {
118 120
        Pattern p = patterns.elementAt(pattern);
119
        if( p!=null ) return p.retInitializationString();
121
        if( p!=null ) p.makeMove(object);
120 122
        }
121

  
122
      return "";
123 123
      }
124 124

  
125 125
  /////////////////////////////////////////////////////////////
126 126

  
127
    String retNextMove(int pattern)
127
    void backMove(RubikObject object, int pattern)
128 128
      {
129 129
      if( pattern>=0 && pattern<numPatterns )
130 130
        {
131 131
        Pattern p = patterns.elementAt(pattern);
132
        if( p!=null ) return p.retNextMove();
132
        if( p!=null ) p.backMove(object);
133 133
        }
134

  
135
      return "";
136 134
      }
137 135

  
138 136
  /////////////////////////////////////////////////////////////
139 137

  
140
    String retPrevMove(int pattern)
138
    String getMoves(int pattern)
141 139
      {
142 140
      if( pattern>=0 && pattern<numPatterns )
143 141
        {
144 142
        Pattern p = patterns.elementAt(pattern);
145
        if( p!=null ) return p.retPrevMove();
143
        if( p!=null ) return p.getMoves();
146 144
        }
147 145

  
148 146
      return "";
......
191 189

  
192 190
  /////////////////////////////////////////////////////////////
193 191

  
194
    String retNextMove()
192
    void makeMove(RubikObject object)
195 193
      {
196 194
      curMove++;
197 195

  
198 196
      if( curMove>numMove)
199 197
        {
200 198
        curMove= 0;
201
        return retInitializationString();
199
        object.initializeObject(moves.substring(0,4*curMove));
202 200
        }
203 201
      else
204 202
        {
205
        curMove--;
206
        return moves.substring(4*curMove-4,4*curMove);
203
        if( !object.makeMove(moves.substring(4*curMove-4,4*curMove)) )
204
          {
205
          curMove--;
206
          }
207 207
        }
208 208
      }
209 209

  
210 210
  /////////////////////////////////////////////////////////////
211 211

  
212
    String retPrevMove()
212
    void backMove(RubikObject object)
213 213
      {
214 214
      curMove--;
215 215

  
216 216
      if( curMove<0)
217 217
        {
218 218
        curMove=numMove;
219
        return retInitializationString();
219
        object.initializeObject(moves.substring(0,4*curMove));
220 220
        }
221 221
      else
222 222
        {
223
        curMove++;
224
        return moves.substring(4*curMove,4*curMove+4);
223
        if( !object.backMove(moves.substring(4*curMove,4*curMove+4)) )
224
          {
225
          curMove++;
226
          }
225 227
        }
226 228
      }
227 229

  
228 230
  /////////////////////////////////////////////////////////////
229 231

  
230
    String retInitializationString()
232
    String getMoves()
231 233
      {
232 234
      return moves.substring(0,4*curMove);
233 235
      }
......
382 384

  
383 385
///////////////////////////////////////////////////////////////////////////////////////////////////
384 386

  
385
  public String retNextMove(int size, int cat, int pat)
387
  public void makeMove(RubikObject object, int size, int cat, int pat)
386 388
    {
387 389
    if( size>=0 && size<NUM_CUBES && cat>=0 && cat< numCategories[size] )
388 390
      {
389 391
      Category c = mCategories[size].elementAt(cat);
390
      if( c!=null ) return c.retNextMove(pat);
392
      if( c!=null ) c.makeMove(object,pat);
391 393
      }
392

  
393
    return "";
394 394
    }
395 395

  
396 396
///////////////////////////////////////////////////////////////////////////////////////////////////
397 397

  
398
  public String retPrevMove(int size, int cat, int pat)
398
  public void backMove(RubikObject object, int size, int cat, int pat)
399 399
    {
400 400
    if( size>=0 && size<NUM_CUBES && cat>=0 && cat< numCategories[size] )
401 401
      {
402 402
      Category c = mCategories[size].elementAt(cat);
403
      if( c!=null ) return c.retPrevMove(pat);
403
      if( c!=null ) c.backMove(object,pat);
404 404
      }
405

  
406
    return "";
407 405
    }
408 406

  
409 407
///////////////////////////////////////////////////////////////////////////////////////////////////
410 408

  
411
  public String retInitializationString(int size,int cat, int pat)
409
  public String getMoves(int size, int cat, int pat)
412 410
    {
413 411
    if( size>=0 && size<NUM_CUBES && cat>=0 && cat< numCategories[size] )
414 412
      {
415 413
      Category c = mCategories[size].elementAt(cat);
416
      if( c!=null ) return c.retInitializationString(pat);
414
      if( c!=null ) return c.getMoves(pat);
417 415
      }
418 416

  
419 417
    return "";
src/main/java/org/distorted/uistate/RubikStatePattern.java
34 34
import org.distorted.dialog.RubikDialogPattern;
35 35
import org.distorted.magic.R;
36 36
import org.distorted.magic.RubikActivity;
37
import org.distorted.object.RubikObject;
37 38
import org.distorted.object.RubikObjectList;
38 39
import org.distorted.patterns.RubikPattern;
39 40

  
......
48 49
  private Button mBackButton;
49 50
  private ImageButton mPrevButton, mNextButton;
50 51
  private TextView mMovesText;
51
  private int mSize;
52
  private int mNumMoves, mCurrMove;
53
  private int mSizeIndex, mCategory, mPattern;
52 54

  
53 55
///////////////////////////////////////////////////////////////////////////////////////////////////
54 56

  
......
62 64
  void leaveState(RubikActivity act)
63 65
    {
64 66
    RubikStatePlay play = (RubikStatePlay)RubikState.PLAY.getStateClass();
67
    int s = RubikObjectList.CUBE.getSizes()[mSizeIndex];
65 68

  
66
    if( !play.setObjectAndSize(RubikObjectList.CUBE, mSize) )
69
    if( !play.setObjectAndSize(RubikObjectList.CUBE, s) )
67 70
      {
68 71
      int object= play.getObject();
69 72
      int size  = play.getSize();
70 73

  
71
      act.changeObject(RubikObjectList.getObject(object),size);
74
      act.changeObject(RubikObjectList.getObject(object),size,null);
72 75
      }
73 76
    }
74 77

  
......
82 85

  
83 86
    if( size>=RubikPattern.MIN_CUBE && size<=RubikPattern.MAX_CUBE && obj==RubikObjectList.CUBE.ordinal() )
84 87
      {
85
      mSize = size;
88
      mSizeIndex = RubikObjectList.getSizeIndex(obj,size);
86 89
      }
87 90
    else
88 91
      {
89
      mSize = RubikStatePlay.DEF_SIZE;
90
      act.changeObject(RubikObjectList.CUBE,mSize);
92
      mSizeIndex = RubikObjectList.getSizeIndex(RubikObjectList.CUBE.ordinal(),RubikStatePlay.DEF_SIZE);
93
      act.changeObject(RubikObjectList.CUBE,RubikStatePlay.DEF_SIZE,null);
91 94
      }
92 95

  
93 96
    FragmentManager mana = act.getSupportFragmentManager();
......
131 134
    {
132 135
    Bundle bundle = new Bundle();
133 136
    int object = RubikObjectList.CUBE.ordinal();
134
    int sizeIndex = RubikObjectList.getSizeIndex(object,mSize);
135
    bundle.putInt("tab", RubikObjectList.pack(object,sizeIndex) );
137
    bundle.putInt("tab", RubikObjectList.pack(object,mSizeIndex) );
136 138

  
137 139
    RubikDialogPattern diag = new RubikDialogPattern();
138 140
    diag.setArguments(bundle);
......
190 192
      @Override
191 193
      public void onClick(View v)
192 194
        {
193
        android.util.Log.e("patt", "prev button clicked!");
195
        if( --mCurrMove< 0 ) mCurrMove=mNumMoves;
196

  
197
        mMovesText.setText(act.getString(R.string.mo_placeholder,mCurrMove,mNumMoves));
198
        RubikObject object = act.getObject();
199
        RubikPattern.getInstance().backMove( object, mSizeIndex, mCategory, mPattern);
194 200
        }
195 201
      });
196 202
    }
......
211 217
      @Override
212 218
      public void onClick(View v)
213 219
        {
214
        android.util.Log.e("patt", "next button clicked!");
220
        if( ++mCurrMove> mNumMoves ) mCurrMove=0;
221

  
222
        mMovesText.setText(act.getString(R.string.mo_placeholder,mCurrMove,mNumMoves));
223
        RubikObject object = act.getObject();
224
        RubikPattern.getInstance().makeMove( object, mSizeIndex, mCategory, mPattern);
215 225
        }
216 226
      });
217 227
    }
......
224 234
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(0,LinearLayout.LayoutParams.MATCH_PARENT,2.0f);
225 235

  
226 236
    mMovesText = new TextView(act);
237
    mMovesText.setTextSize(20);
227 238
    mMovesText.setLayoutParams(params);
228 239
    mMovesText.setPadding(padding,0,padding,0);
229 240
    mMovesText.setGravity(Gravity.CENTER);
230 241

  
231
    mMovesText.setText("aaa");
242
    mMovesText.setText(act.getString(R.string.mo_placeholder,mCurrMove,mNumMoves));
232 243
    }
233 244

  
234 245
///////////////////////////////////////////////////////////////////////////////////////////////////
235 246

  
236
  public void setPattern(int sizeIndex, int category, int pattern)
247
  public void setPattern(final RubikActivity act, int sizeIndex, int category, int pattern)
237 248
    {
238
    mSize = RubikObjectList.CUBE.getSizes()[sizeIndex];
249
    mSizeIndex = sizeIndex;
250
    mCategory  = category;
251
    mPattern   = pattern;
239 252

  
240 253
    RubikPattern patt = RubikPattern.getInstance();
241 254
    String patternName = patt.getPatternName(sizeIndex,category,pattern);
242 255
    mText.setText(patternName);
256

  
257
    mNumMoves = patt.getNumMoves(sizeIndex,category,pattern);
258
    mCurrMove = patt.getCurMove(sizeIndex,category,pattern);
259

  
260
    mMovesText.setText(act.getString(R.string.mo_placeholder,mCurrMove,mNumMoves));
243 261
    }
244 262

  
245 263
///////////////////////////////////////////////////////////////////////////////////////////////////
src/main/java/org/distorted/uistate/RubikStatePlay.java
197 197
            {
198 198
            mObject = obj;
199 199
            mSize   = sizes[size];
200
            act.changeObject(list,sizes[size]);
200
            act.changeObject(list,sizes[size],null);
201 201
            mPopup.dismiss();
202 202
            }
203 203
          });
src/main/res/values/strings.xml
41 41
    <string name="tm_placeholder">%1$02d:%2$02d</string>
42 42
    <string name="ap_placeholder">%1$s %2$s</string>
43 43
    <string name="ti_placeholder">%1$.1f seconds</string>
44
    <string name="mo_placeholder">%1$d/%2$d</string>
44 45
</resources>

Also available in: Unified diff