Project

General

Profile

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

magiccube / src / main / java / org / distorted / objects / TwistyDino.java @ 2fcfce81

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.objects;
21

    
22
import android.content.res.Resources;
23
import android.graphics.Canvas;
24
import android.graphics.Paint;
25

    
26
import org.distorted.library.effect.MatrixEffectQuaternion;
27
import org.distorted.library.main.DistortedEffects;
28
import org.distorted.library.main.DistortedTexture;
29
import org.distorted.library.mesh.MeshBase;
30
import org.distorted.library.mesh.MeshSquare;
31
import org.distorted.library.type.Static3D;
32
import org.distorted.library.type.Static4D;
33
import org.distorted.main.RubikSurfaceView;
34

    
35
import java.util.Random;
36

    
37
import static org.distorted.effects.scramble.ScrambleEffect.START_AXIS;
38

    
39
///////////////////////////////////////////////////////////////////////////////////////////////////
40

    
41
public abstract class TwistyDino extends TwistyObject
42
{
43
  private static final float SQ3 = (float)Math.sqrt(3);
44

    
45
  // the four rotation axis of a RubikDino. Must be normalized.
46
  static final Static3D[] ROT_AXIS = new Static3D[]
47
         {
48
           new Static3D(+SQ3/3,+SQ3/3,+SQ3/3),
49
           new Static3D(+SQ3/3,+SQ3/3,-SQ3/3),
50
           new Static3D(+SQ3/3,-SQ3/3,+SQ3/3),
51
           new Static3D(+SQ3/3,-SQ3/3,-SQ3/3)
52
         };
53

    
54
  private static final int[] FACE_COLORS = new int[]
55
         {
56
           COLOR_YELLOW, COLOR_WHITE,
57
           COLOR_BLUE  , COLOR_GREEN,
58
           COLOR_RED   , COLOR_BROWN
59
         };
60

    
61
  // All legal rotation quats of a RubikDino
62
  static final Static4D[] QUATS = new Static4D[]
63
         {
64
           new Static4D(  0.0f,  0.0f,  0.0f,  1.0f ),
65
           new Static4D(  0.5f,  0.5f,  0.5f, -0.5f ),
66
           new Static4D(  0.0f,  0.0f,  1.0f,  0.0f ),
67
           new Static4D(  0.5f, -0.5f, -0.5f, -0.5f ),
68
           new Static4D(  0.5f,  0.5f,  0.5f,  0.5f ),
69
           new Static4D(  0.5f,  0.5f, -0.5f, -0.5f ),
70
           new Static4D(  0.5f, -0.5f,  0.5f, -0.5f ),
71
           new Static4D(  0.5f, -0.5f, -0.5f,  0.5f ),
72
           new Static4D(  0.0f,  1.0f,  0.0f,  0.0f ),
73
           new Static4D(  0.5f, -0.5f,  0.5f,  0.5f ),
74
           new Static4D(  1.0f,  0.0f,  0.0f,  0.0f ),
75
           new Static4D(  0.5f,  0.5f, -0.5f,  0.5f )
76
         };
77

    
78
  // centers of the 12 edges. Must be in the same order like QUATs above.
79
  private static final Static3D[] CENTERS = new Static3D[]
80
         {
81
           new Static3D( 0.0f, 1.5f, 1.5f ),
82
           new Static3D( 1.5f, 0.0f, 1.5f ),
83
           new Static3D( 0.0f,-1.5f, 1.5f ),
84
           new Static3D(-1.5f, 0.0f, 1.5f ),
85
           new Static3D( 1.5f, 1.5f, 0.0f ),
86
           new Static3D( 1.5f,-1.5f, 0.0f ),
87
           new Static3D(-1.5f,-1.5f, 0.0f ),
88
           new Static3D(-1.5f, 1.5f, 0.0f ),
89
           new Static3D( 0.0f, 1.5f,-1.5f ),
90
           new Static3D( 1.5f, 0.0f,-1.5f ),
91
           new Static3D( 0.0f,-1.5f,-1.5f ),
92
           new Static3D(-1.5f, 0.0f,-1.5f )
93
         };
94

    
95
  private static MeshBase mMesh;
96

    
97
///////////////////////////////////////////////////////////////////////////////////////////////////
98

    
99
  TwistyDino(int size, Static4D quat, DistortedTexture texture, MeshSquare mesh,
100
             DistortedEffects effects, int[][] moves, ObjectList obj, Resources res, int scrWidth)
101
    {
102
    super(size, 60, quat, texture, mesh, effects, moves, obj, res, scrWidth);
103
    }
104

    
105
///////////////////////////////////////////////////////////////////////////////////////////////////
106

    
107
  int mulQuat(int q1, int q2)
108
    {
109
    Static4D result = RubikSurfaceView.quatMultiply(QUATS[q1],QUATS[q2]);
110

    
111
    float rX = result.get0();
112
    float rY = result.get1();
113
    float rZ = result.get2();
114
    float rW = result.get3();
115

    
116
    final float MAX_ERROR = 0.1f;
117
    float dX,dY,dZ,dW;
118

    
119
    for(int i=0; i<QUATS.length; i++)
120
      {
121
      dX = QUATS[i].get0() - rX;
122
      dY = QUATS[i].get1() - rY;
123
      dZ = QUATS[i].get2() - rZ;
124
      dW = QUATS[i].get3() - rW;
125

    
126
      if( dX<MAX_ERROR && dX>-MAX_ERROR &&
127
          dY<MAX_ERROR && dY>-MAX_ERROR &&
128
          dZ<MAX_ERROR && dZ>-MAX_ERROR &&
129
          dW<MAX_ERROR && dW>-MAX_ERROR  ) return i;
130

    
131
      dX = QUATS[i].get0() + rX;
132
      dY = QUATS[i].get1() + rY;
133
      dZ = QUATS[i].get2() + rZ;
134
      dW = QUATS[i].get3() + rW;
135

    
136
      if( dX<MAX_ERROR && dX>-MAX_ERROR &&
137
          dY<MAX_ERROR && dY>-MAX_ERROR &&
138
          dZ<MAX_ERROR && dZ>-MAX_ERROR &&
139
          dW<MAX_ERROR && dW>-MAX_ERROR  ) return i;
140
      }
141

    
142
    return -1;
143
    }
144

    
145
///////////////////////////////////////////////////////////////////////////////////////////////////
146

    
147
  float getScreenRatio()
148
    {
149
    return 0.5f;
150
    }
151

    
152
///////////////////////////////////////////////////////////////////////////////////////////////////
153

    
154
  Static4D[] getQuats()
155
    {
156
    return QUATS;
157
    }
158

    
159
///////////////////////////////////////////////////////////////////////////////////////////////////
160

    
161
  int getNumFaces()
162
    {
163
    return FACE_COLORS.length;
164
    }
165

    
166
///////////////////////////////////////////////////////////////////////////////////////////////////
167

    
168
  float getBasicStep()
169
    {
170
    return SQ3;
171
    }
172

    
173
///////////////////////////////////////////////////////////////////////////////////////////////////
174

    
175
  int getNumStickerTypes()
176
    {
177
    return 1;
178
    }
179

    
180
///////////////////////////////////////////////////////////////////////////////////////////////////
181

    
182
  int getNumCubitFaces()
183
    {
184
    return 4;
185
    }
186

    
187
///////////////////////////////////////////////////////////////////////////////////////////////////
188

    
189
  Static3D[] getCubitPositions(int size)
190
    {
191
    return CENTERS;
192
    }
193

    
194
///////////////////////////////////////////////////////////////////////////////////////////////////
195

    
196
  MeshBase createCubitMesh(int cubit)
197
    {
198
    if( mMesh==null ) mMesh = CubitFactory.getInstance().createDinoMesh();
199

    
200
    MeshBase mesh = mMesh.copy(true);
201
    MatrixEffectQuaternion quat = new MatrixEffectQuaternion( QUATS[cubit], new Static3D(0,0,0) );
202
    mesh.apply(quat,0xffffffff,0);
203

    
204
    return mesh;
205
    }
206

    
207
///////////////////////////////////////////////////////////////////////////////////////////////////
208

    
209
  void createFaceTexture(Canvas canvas, Paint paint, int face, int left)
210
    {
211
    float F = 0.5f;
212
    float R = 0.025f;
213
    float S = 0.05f;
214
    float[] vertices = { -F,F/3, 0,-2*F/3, +F,F/3 };
215

    
216
    drawRoundedPolygon(canvas, paint, left, vertices, S, FACE_COLORS[face], R);
217
    }
218

    
219
///////////////////////////////////////////////////////////////////////////////////////////////////
220

    
221
  float returnMultiplier()
222
    {
223
    return 2.0f;
224
    }
225

    
226
///////////////////////////////////////////////////////////////////////////////////////////////////
227

    
228
  float[] getRowChances()
229
    {
230
    float[] chances = new float[3];
231

    
232
    chances[0] = 0.5f;
233
    chances[1] = 0.5f;
234
    chances[2] = 1.0f;
235

    
236
    return chances;
237
    }
238

    
239
///////////////////////////////////////////////////////////////////////////////////////////////////
240
// PUBLIC API
241

    
242
  public Static3D[] getRotationAxis()
243
    {
244
    return ROT_AXIS;
245
    }
246

    
247
///////////////////////////////////////////////////////////////////////////////////////////////////
248

    
249
  public int getBasicAngle()
250
    {
251
    return 3;
252
    }
253

    
254
///////////////////////////////////////////////////////////////////////////////////////////////////
255

    
256
  public int randomizeNewRotAxis(Random rnd, int oldRotAxis)
257
    {
258
    int numAxis = ROTATION_AXIS.length;
259

    
260
    if( oldRotAxis == START_AXIS )
261
      {
262
      return rnd.nextInt(numAxis);
263
      }
264
    else
265
      {
266
      int newVector = rnd.nextInt(numAxis-1);
267
      return (newVector>=oldRotAxis ? newVector+1 : newVector);
268
      }
269
    }
270

    
271
///////////////////////////////////////////////////////////////////////////////////////////////////
272
// only needed for solvers - there are no Dino solvers ATM)
273

    
274
  public String retObjectString()
275
    {
276
    return "";
277
    }
278
}
(14-14/21)