Project

General

Profile

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

magiccube / src / main / java / org / distorted / objects / MovementDiamond.java @ eaf87d1d

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 org.distorted.library.type.Static3D;
23

    
24
///////////////////////////////////////////////////////////////////////////////////////////////////
25

    
26
class MovementDiamond extends Movement
27
{
28
  static final float DIST3D = SQ6/6;
29
  static final float DIST2D = SQ3/6;
30

    
31
  static final Static3D[] FACE_AXIS = new Static3D[]
32
         {
33
           new Static3D(+SQ6/3,+SQ3/3,     0), new Static3D(-SQ6/3,-SQ3/3,     0),
34
           new Static3D(-SQ6/3,+SQ3/3,     0), new Static3D(+SQ6/3,-SQ3/3,     0),
35
           new Static3D(     0,+SQ3/3,+SQ6/3), new Static3D(     0,-SQ3/3,-SQ6/3),
36
           new Static3D(     0,+SQ3/3,-SQ6/3), new Static3D(     0,-SQ3/3,+SQ6/3)
37
         };
38

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

    
41
  MovementDiamond()
42
    {
43
    super(TwistyDiamond.ROT_AXIS, FACE_AXIS, DIST3D, DIST2D);
44
    }
45

    
46
///////////////////////////////////////////////////////////////////////////////////////////////////
47
// We have either one of the four faces (1,3,4,6) which, when the retAxis are cast onto it, they
48
// point the right way (and so the triangle then spans from offset=-SQ3/6 to offset=+SQ3/3 with
49
// midpoint at SQ3/12) or one of the other face when the cast rotAxis are the wrong way round (and
50
// the triangle spans then from 0 to SQ3/2 with midpoint at SQ3/4).
51

    
52
  int computeRowFromOffset(int face, int size, float offset)
53
    {
54
    float off = ( face==1 || face==3 || face==4 || face==6 ) ? offset/SQ3 + 1.0f/6 : offset/SQ3;
55
    return (int)(2*size*off);
56
    }
57

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

    
60
  public float returnRotationFactor(int size, int row)
61
    {
62
    return 1.0f;
63
    }
64

    
65
///////////////////////////////////////////////////////////////////////////////////////////////////
66

    
67
  boolean isInsideFace(int face, float[] p)
68
    {
69
    float y = (face%2 == 0 ? p[1] : -p[1]);
70
    float x = p[0];
71

    
72
    return (y >= -DIST2D) && (y <= DIST2D*(2-6*x)) && (y <= DIST2D*(2+6*x));
73
    }
74

    
75
///////////////////////////////////////////////////////////////////////////////////////////////////
76

    
77
  void computeEnabledAxis(int face, float[] touchPoint, int[] enabled)
78
    {
79
    enabled[0] = 3;
80

    
81
    switch(face/2)
82
      {
83
      case 0: enabled[1]=1; enabled[2]=2; enabled[3]=3; break;
84
      case 1: enabled[1]=0; enabled[2]=2; enabled[3]=3; break;
85
      case 2: enabled[1]=0; enabled[2]=1; enabled[3]=3; break;
86
      case 3: enabled[1]=0; enabled[2]=1; enabled[3]=2; break;
87
      }
88
    }
89
}
(6-6/35)