annotate game/Piece.java @ 91:cc96bc955db6

Cleanups.
author Matti Hamalainen <ccr@tnsp.org>
date Thu, 03 Mar 2011 18:02:23 +0200
parents e9fab3c96043
children d5f51370617b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
1 /*
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
2 * Ristipolku
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
3 * (C) Copyright 2011 Matti 'ccr' Hämäläinen <ccr@tnsp.org>
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
4 */
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
5 package game;
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
6
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
7 import java.awt.*;
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
8 import java.awt.geom.*;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
9 import java.util.*;
6
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
10 import java.math.*;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
11
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
12
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
13 public class Piece
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
14 {
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
15 public enum RotateDir { LEFT, RIGHT }
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
16
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
17 static final int numConnections = 8;
85
e9fab3c96043 Make piece rotation animation a bit faster.
Matti Hamalainen <ccr@tnsp.org>
parents: 58
diff changeset
18 static final float maxTime = 35.0f;
9
a7751971c2a3 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 7
diff changeset
19
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
20 int currRotation;
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
21 int[] connections;
40
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
22 boolean[] states;
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
23 PieceType type, prevType;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
24
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
25 boolean rotationChanged, rotationActive,
9
a7751971c2a3 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 7
diff changeset
26 typeChanged, typeActive,
40
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
27 stateChanged, stateActive;
6
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
28
91
cc96bc955db6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 85
diff changeset
29 float currAngle, newAngle,
cc96bc955db6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 85
diff changeset
30 rotationTime, rotationSpeed,
cc96bc955db6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 85
diff changeset
31 typeTime, throbTime;
cc96bc955db6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 85
diff changeset
32
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
33 Interpolate lerpRotation;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
34
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
35
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
36 public Piece(PieceType ptype)
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
37 {
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
38 // Initialize
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
39 connections = new int[numConnections];
40
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
40 states = new boolean[numConnections];
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
41 type = ptype;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
42
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
43 rotationChanged = false;
6
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
44 rotationActive = false;
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
45 currRotation = 0;
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
46 currAngle = 0;
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
47
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
48 typeChanged = false;
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
49 typeActive = false;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
50
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
51 throbTime = 0;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
52
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
53
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
54 // Initialize connections between endpoints of the paths inside the piece
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
55 for (int i = 0; i < numConnections; i++)
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
56 connections[i] = -1;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
57
26
3d4cc47df31a Cleanups, fix piece rendering and rotation.
Matti Hamalainen <ccr@tnsp.org>
parents: 21
diff changeset
58
6
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
59 // Randomize connections in the piece
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
60 Random rnd = new Random();
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
61 for (int i = 0; i < numConnections; i++)
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
62 {
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
63 while (connections[i] < 0)
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
64 {
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
65 int tmp = rnd.nextInt(numConnections);
26
3d4cc47df31a Cleanups, fix piece rendering and rotation.
Matti Hamalainen <ccr@tnsp.org>
parents: 21
diff changeset
66 if (tmp != i && connections[tmp] < 0)
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
67 {
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
68 connections[i] = tmp;
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
69 connections[tmp] = i;
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
70 }
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
71 }
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
72 }
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
73 }
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
74
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
75 public Piece()
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
76 {
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
77 this(PieceType.NONE);
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
78 }
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
79
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
80 public void setType(PieceType ptype)
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
81 {
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
82 typeChanged = (prevType != ptype);
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
83 prevType = type;
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
84 type = ptype;
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
85 }
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
86
40
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
87 public void clearStates()
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
88 {
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
89 for (int i = 0; i < numConnections; i++)
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
90 states[i] = false;
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
91 stateChanged = true;
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
92 }
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
93
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
94 public int getRotatedPoint(int in)
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
95 {
42
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
96 int point = (in - (currRotation * 2)) % 8;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
97 if (point < 0) point = 8 + point;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
98 return point;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
99 }
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
100
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
101 public int getAntiRotatedPoint(int in)
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
102 {
40
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
103 int point = (in + (currRotation * 2)) % 8;
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
104 if (point < 0) point = 8 + point;
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
105 return point;
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
106 }
42
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
107
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
108 public int getMatchingPoint(int point)
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
109 {
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
110 switch (point)
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
111 {
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
112 case 0: return 5;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
113 case 1: return 4;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
114
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
115 case 2: return 7;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
116 case 3: return 6;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
117
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
118 case 4: return 1;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
119 case 5: return 0;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
120
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
121 case 6: return 3;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
122 case 7: return 2;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
123 }
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
124 return -1;
951a4d669af0 Initially working path solving algorithm.
Matti Hamalainen <ccr@tnsp.org>
parents: 40
diff changeset
125 }
37
3dc5ae9f1c80 Work on game logic.
Matti Hamalainen <ccr@tnsp.org>
parents: 34
diff changeset
126
40
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
127 public void setConnectionState(int point, boolean state)
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
128 {
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
129 states[point] = state;
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
130 states[connections[point]] = state;
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
131 stateChanged = true;
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
132 }
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
133
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
134 public int getConnection(int point)
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
135 {
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
136 return connections[point];
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
137 }
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
138
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
139 public void rotate(RotateDir dir)
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
140 {
6
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
141 // Only normal
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
142 if (type != PieceType.LOCKED && type != PieceType.ACTIVE)
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
143 return;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
144
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
145 currRotation = (currRotation + (dir == RotateDir.RIGHT ? 1 : -1)) % 4;
11
b89ecc8d5557 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
146 newAngle = (float) ((currRotation * Math.PI) / 2.0f);
26
3d4cc47df31a Cleanups, fix piece rendering and rotation.
Matti Hamalainen <ccr@tnsp.org>
parents: 21
diff changeset
147 lerpRotation = new Interpolate(newAngle, currAngle, maxTime);
3
b8fd19e2d879 Indentation.
Matti Hamalainen <ccr@tnsp.org>
parents: 2
diff changeset
148 rotationChanged = true;
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
149 }
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
150
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
151 public Point2D getPointCoords(float x, float y, float dim, int index)
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
152 {
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
153 float ox = 0, oy = 0;
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
154 float step = dim / 10;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
155
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
156 switch (index) {
34
6f6c551cc14c Fix piece connections rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 32
diff changeset
157 // Normal line starting and ending points
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
158 case 0: ox = 3.0f; oy = 0.4f; break;
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
159 case 1: ox = 7.0f; oy = 0.4f; break;
39
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
160
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
161 case 2: ox = 9.6f; oy = 3.0f; break;
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
162 case 3: ox = 9.6f; oy = 7.0f; break;
39
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
163
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
164 case 4: ox = 7.0f; oy = 9.6f; break;
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
165 case 5: ox = 3.0f; oy = 9.6f; break;
39
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
166
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
167 case 6: ox = 0.4f; oy = 7.0f; break;
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
168 case 7: ox = 0.4f; oy = 3.0f; break;
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
169
39
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
170
34
6f6c551cc14c Fix piece connections rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 32
diff changeset
171 // Matching control points for each point above (+8)
39
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
172 case 8: ox = 3.0f; oy = 2.5f; break;
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
173 case 9: ox = 7.0f; oy = 2.5f; break;
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
174
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
175 case 10: ox = 7.5f; oy = 3.0f; break;
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
176 case 11: ox = 7.5f; oy = 7.0f; break;
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
177
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
178 case 12: ox = 7.0f; oy = 7.5f; break;
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
179 case 13: ox = 3.0f; oy = 7.5f; break;
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
180
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
181 case 14: ox = 2.5f; oy = 7.0f; break;
e682b623aea9 Cosmetics.
Matti Hamalainen <ccr@tnsp.org>
parents: 37
diff changeset
182 case 15: ox = 2.5f; oy = 3.0f; break;
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
183 }
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
184
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
185 return new Point2D.Float(x + ox * step, y + oy * step);
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
186 }
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
187
27
26adc2827983 More work on the internals.
Matti Hamalainen <ccr@tnsp.org>
parents: 26
diff changeset
188 public PieceType getType()
26adc2827983 More work on the internals.
Matti Hamalainen <ccr@tnsp.org>
parents: 26
diff changeset
189 {
26adc2827983 More work on the internals.
Matti Hamalainen <ccr@tnsp.org>
parents: 26
diff changeset
190 return type;
26adc2827983 More work on the internals.
Matti Hamalainen <ccr@tnsp.org>
parents: 26
diff changeset
191 }
9
a7751971c2a3 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 7
diff changeset
192
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
193 public void animate(float time)
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
194 {
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
195 if (rotationChanged)
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
196 {
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
197 rotationTime = time;
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
198 rotationActive = true;
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
199 rotationChanged = false;
54
cc7943cd7f2d Moar work.
Matti Hamalainen <ccr@tnsp.org>
parents: 45
diff changeset
200 rotationSpeed = 0.5f;
cc7943cd7f2d Moar work.
Matti Hamalainen <ccr@tnsp.org>
parents: 45
diff changeset
201 }
cc7943cd7f2d Moar work.
Matti Hamalainen <ccr@tnsp.org>
parents: 45
diff changeset
202
cc7943cd7f2d Moar work.
Matti Hamalainen <ccr@tnsp.org>
parents: 45
diff changeset
203 if (typeChanged && type == PieceType.LOCKED)
cc7943cd7f2d Moar work.
Matti Hamalainen <ccr@tnsp.org>
parents: 45
diff changeset
204 {
cc7943cd7f2d Moar work.
Matti Hamalainen <ccr@tnsp.org>
parents: 45
diff changeset
205 rotationSpeed = 1.0f;
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
206 }
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
207
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
208 if (rotationActive)
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
209 {
54
cc7943cd7f2d Moar work.
Matti Hamalainen <ccr@tnsp.org>
parents: 45
diff changeset
210 float t = (time - rotationTime) * rotationSpeed;
11
b89ecc8d5557 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
211
9
a7751971c2a3 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 7
diff changeset
212 if (t < maxTime)
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
213 currAngle = lerpRotation.getValue(t);
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
214 else
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
215 {
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
216 currAngle = newAngle;
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
217 rotationActive = false;
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
218 }
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
219 }
54
cc7943cd7f2d Moar work.
Matti Hamalainen <ccr@tnsp.org>
parents: 45
diff changeset
220
6
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
221 if (typeChanged)
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
222 {
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
223 typeTime = time;
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
224 typeActive = true;
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
225 typeChanged = false;
6
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
226 }
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
227
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
228 if (typeActive)
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
229 {
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
230 }
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
231
40
a69103644bf6 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 39
diff changeset
232 if (stateChanged)
9
a7751971c2a3 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 7
diff changeset
233 {
a7751971c2a3 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 7
diff changeset
234 }
a7751971c2a3 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 7
diff changeset
235
32
e480579cc460 More work on debugging the path resolving.
Matti Hamalainen <ccr@tnsp.org>
parents: 30
diff changeset
236 throbTime = (time % 100) / 100.0f;
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
237 }
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
238
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
239 public void paint(Graphics2D g, float x, float y, float dim)
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
240 {
58
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
241 AffineTransform save = g.getTransform();
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
242
45
79185dababf2 Add comments.
Matti Hamalainen <ccr@tnsp.org>
parents: 43
diff changeset
243 // Transform drawing by current angle
11
b89ecc8d5557 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
244 g.rotate(currAngle, x + dim / 2.0f, y + dim / 2.0f);
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
245
45
79185dababf2 Add comments.
Matti Hamalainen <ccr@tnsp.org>
parents: 43
diff changeset
246 // Color piece by type
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
247 switch (type) {
58
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
248 case LOCKED: g.setPaint(new Color(0.3f, 0.8f, 0.3f, 0.35f)); break;
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
249 case ACTIVE: g.setPaint(new Color(0.9f, 0.3f, 0.3f, 0.35f)); break;
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
250 case START: g.setPaint(new Color(1.0f, 0.8f, 0.0f, 0.95f)); break;
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
251 }
6
be0bf7544069 Cleanups.
Matti Hamalainen <ccr@tnsp.org>
parents: 5
diff changeset
252
7
70714c229e23 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
253 g.fill(new RoundRectangle2D.Float(x, y, dim, dim, dim / 10, dim / 10));
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
254
45
79185dababf2 Add comments.
Matti Hamalainen <ccr@tnsp.org>
parents: 43
diff changeset
255 // Start pieces (center piece) do not have border, etc.
58
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
256 if (type != PieceType.START)
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
257 {
58
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
258 // Active piece has a throbbing "ghost" border
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
259 if (type == PieceType.ACTIVE)
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
260 {
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
261 float offs1 = throbTime * 10.0f,
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
262 offs2 = throbTime * 20.0f;
27
26adc2827983 More work on the internals.
Matti Hamalainen <ccr@tnsp.org>
parents: 26
diff changeset
263
58
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
264 g.setPaint(new Color(0.0f, 0.0f, 0.0f, (float) (1.0f - throbTime) ));
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
265 g.setStroke(new BasicStroke(2.0f + throbTime * 2.0f));
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
266 g.draw(new RoundRectangle2D.Float(
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
267 x - offs1, y - offs1,
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
268 dim + offs2, dim + offs2,
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
269 dim / 10, dim / 10));
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
270 }
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
271
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
272 // Draw piece border
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
273 g.setPaint(new Color(0.0f, 0.0f, 0.0f, 0.6f));
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
274 g.setStroke(new BasicStroke(5.0f));
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
275 g.draw(new RoundRectangle2D.Float(x, y, dim, dim, dim / 10, dim / 10));
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
276
58
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
277 // Draw the connections
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
278 g.setStroke(new BasicStroke(5.5f));
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
279 CubicCurve2D curve = new CubicCurve2D.Float();
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
280 boolean[] drawn = new boolean[numConnections];
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
281 for (int i = 0; i < numConnections; i++)
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
282 if (!drawn[i])
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
283 {
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
284 Point2D start, cp1, cp2, end;
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
285 boolean isActive = states[i] || states[connections[i]];
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
286
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
287 g.setPaint(isActive ? Color.white : Color.black);
9
a7751971c2a3 More work.
Matti Hamalainen <ccr@tnsp.org>
parents: 7
diff changeset
288
58
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
289 start = getPointCoords(x, y, dim, i);
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
290 end = getPointCoords(x, y, dim, connections[i]);
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
291 cp1 = getPointCoords(x, y, dim, i + 8);
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
292 cp2 = getPointCoords(x, y, dim, connections[i] + 8);
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
293
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
294 curve.setCurve(start, cp1, cp2, end);
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
295 g.draw(curve);
34
6f6c551cc14c Fix piece connections rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 32
diff changeset
296
58
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
297 // Mark connection drawn, so we don't overdraw
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
298 drawn[i] = true;
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
299 drawn[connections[i]] = true;
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
300 }
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
301
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
302 } // !PieceType.START
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
303
cde170f2f980 Clean up the piece rendering.
Matti Hamalainen <ccr@tnsp.org>
parents: 54
diff changeset
304 g.setTransform(save);
5
4890020bf856 Cleanups, etc.
Matti Hamalainen <ccr@tnsp.org>
parents: 3
diff changeset
305 }
1
44f1e7b47fcf Preliminary work ... puuh.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
306 }