Project

General

Profile

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

magiccube / src / main / java / org / distorted / objects / TwistyBandagedFused.java @ bbc6471c

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2021 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

    
24
import org.distorted.library.main.DistortedEffects;
25
import org.distorted.library.main.DistortedTexture;
26
import org.distorted.library.mesh.MeshSquare;
27
import org.distorted.library.type.Static4D;
28
import org.distorted.main.R;
29

    
30
import java.util.Random;
31

    
32
import static org.distorted.effects.scramble.ScrambleEffect.START_AXIS;
33

    
34
///////////////////////////////////////////////////////////////////////////////////////////////////
35

    
36
class TwistyBandagedFused extends TwistyBandagedAbstract
37
{
38
  TwistyBandagedFused(int size, Static4D quat, DistortedTexture texture, MeshSquare mesh,
39
                      DistortedEffects effects, int[][] moves, Resources res, int scrWidth)
40
    {
41
    super(size, quat, texture, mesh, effects, moves, ObjectList.BAN1, res, scrWidth);
42
    }
43

    
44
///////////////////////////////////////////////////////////////////////////////////////////////////
45

    
46
  int getCubitVariant(int cubit)
47
    {
48
    return cubit==0 ? 4:0;
49
    }
50

    
51
///////////////////////////////////////////////////////////////////////////////////////////////////
52

    
53
  int getNumCubits()
54
    {
55
    return 20;
56
    }
57

    
58
///////////////////////////////////////////////////////////////////////////////////////////////////
59

    
60
  float[] getCubitPosition(int cubit)
61
    {
62
    switch(cubit)
63
      {
64
      case  0: return new float[] {-1.0f, -1.0f, +0.0f,
65
                                   -1.0f, -1.0f, +1.0f,
66
                                   -1.0f,  0.0f, +0.0f,
67
                                   -1.0f,  0.0f, +1.0f,
68
                                    0.0f, -1.0f, +0.0f,
69
                                    0.0f, -1.0f, +1.0f,
70
                                    0.0f,  0.0f, +0.0f,
71
                                    0.0f,  0.0f, +1.0f};
72
      case  1: return new float[] {-1.0f, +1.0f, +1.0f};
73
      case  2: return new float[] {-1.0f, +1.0f, +0.0f};
74
      case  3: return new float[] {-1.0f, +1.0f, -1.0f};
75
      case  4: return new float[] { 0.0f, +1.0f, +1.0f};
76
      case  5: return new float[] { 0.0f, +1.0f, +0.0f};
77
      case  6: return new float[] { 0.0f, +1.0f, -1.0f};
78
      case  7: return new float[] { 1.0f, +1.0f, +1.0f};
79
      case  8: return new float[] { 1.0f, +1.0f, +0.0f};
80
      case  9: return new float[] { 1.0f, +1.0f, -1.0f};
81
      case 10: return new float[] { 1.0f,  0.0f, +1.0f};
82
      case 11: return new float[] { 1.0f,  0.0f, +0.0f};
83
      case 12: return new float[] { 1.0f,  0.0f, -1.0f};
84
      case 13: return new float[] { 1.0f, -1.0f, +1.0f};
85
      case 14: return new float[] { 1.0f, -1.0f, +0.0f};
86
      case 15: return new float[] { 1.0f, -1.0f, -1.0f};
87
      case 16: return new float[] {-1.0f, -1.0f, -1.0f};
88
      case 17: return new float[] {-1.0f,  0.0f, -1.0f};
89
      case 18: return new float[] { 0.0f, -1.0f, -1.0f};
90
      case 19: return new float[] { 0.0f,  0.0f, -1.0f};
91
      }
92

    
93
    return null;
94
    }
95

    
96
///////////////////////////////////////////////////////////////////////////////////////////////////
97

    
98
  int getQuatIndex(int cubit)
99
    {
100
    return 0;
101
    }
102

    
103
///////////////////////////////////////////////////////////////////////////////////////////////////
104

    
105
  public void randomizeNewScramble(int[] scramble, Random rnd, int oldRotAxis, int oldRow,
106
                                   int numScramble, int remScrambles, int remDoubleScrambles)
107
    {
108
    if( numScramble==1 )
109
      {
110
      scramble[0] = rnd.nextInt(ROTATION_AXIS.length);
111
      }
112
    else
113
      {
114
      int newVector = rnd.nextInt(ROTATION_AXIS.length-1);
115
      scramble[0] = (newVector>=oldRotAxis ? newVector+1 : newVector);
116
      }
117

    
118
    float rowFloat = rnd.nextFloat();
119

    
120
    for(int row=0; row<mRowChances.length; row++)
121
      {
122
      if( rowFloat<=mRowChances[row] )
123
        {
124
        scramble[1] = row;
125
        break;
126
        }
127
      }
128

    
129
    int random = rnd.nextInt(remScrambles);
130
    int result = random<remDoubleScrambles ? 2:1;
131
    int sign   = rnd.nextInt(2);
132

    
133
    scramble[2] = sign==0 ? result : -result;
134
    }
135

    
136
///////////////////////////////////////////////////////////////////////////////////////////////////
137

    
138
  public int getObjectName(int numLayers)
139
    {
140
    return R.string.bandaged_fused;
141
    }
142

    
143
///////////////////////////////////////////////////////////////////////////////////////////////////
144

    
145
  public int getInventor(int numLayers)
146
    {
147
    return R.string.bandaged_fused_inventor;
148
    }
149

    
150
///////////////////////////////////////////////////////////////////////////////////////////////////
151

    
152
  public int getComplexity(int numLayers)
153
    {
154
    return 8;
155
    }
156
}
(20-20/35)