1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
|
class IGPTheGreatMosqueOfCordoba extends IGPSquare{
PVector[][] cornerPieces;
PVector[][] sidePieces;
PVector[][] starPieces;
PVector[][] verticalVs;
PVector[][] horizontalVs;
ArrayList <PVector> middleStar;
IGPTheGreatMosqueOfCordoba(float x, float y, float d){
super(x, y, d, 12);
setInterlacingVs();
setSidePieces();
setCornerPieces();
setStarPieces();
setMiddleStar();
}
void setInterlacingVs(){
PVector[] vectors = new PVector[2];
verticalVs = new PVector[4][2];
horizontalVs = new PVector[4][2];
vectors[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(315), mid.y-radius, true);
vectors[1] = getVectorOnAlphaCircle(90);
verticalVs[0] = vectors;
vectors = new PVector[2];
vectors[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(225), mid.y-radius, true);
vectors[1] = getVectorOnAlphaCircle(90);
verticalVs[1] = vectors;
vectors = new PVector[2];
vectors[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), mid.y+radius, true);
vectors[1] = getVectorOnAlphaCircle(270);
verticalVs[2] = vectors;
vectors = new PVector[2];
vectors[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135), mid.y+radius, true);
vectors[1] = getVectorOnAlphaCircle(270);
verticalVs[3] = vectors;
vectors = new PVector[2];
vectors[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), mid.x+radius, false);
vectors[1] = getVectorOnAlphaCircle(180);
horizontalVs[0] = vectors;
vectors = new PVector[2];
vectors[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), mid.x+radius, false);
vectors[1] = getVectorOnAlphaCircle(180);
horizontalVs[1] = vectors;
vectors = new PVector[2];
vectors[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(225), mid.x-radius, false);
vectors[1] = getVectorOnAlphaCircle(0);
horizontalVs[2] = vectors;
vectors = new PVector[2];
vectors[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(135), mid.x-radius, false);
vectors[1] = getVectorOnAlphaCircle(0);
horizontalVs[3] = vectors;
}
void setMiddleStar(){
middleStar = new ArrayList <PVector>(16);
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45)));
middleStar.add(getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90)));
}
void setCornerPieces(){
cornerPieces = new PVector[4][4];
PVector[] cornerPiece = new PVector[4];
cornerPiece[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), mid.x+radius, false);
cornerPiece[1] = new PVector(mid.x+radius, mid.y+radius);
cornerPiece[2] = getVectorOnExtendedLine(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), mid.y+radius, true);
cornerPiece[3] = getVectorOnAlphaCircle(45);
cornerPieces[0] = cornerPiece;
cornerPiece = new PVector[4];
cornerPiece[0] = getVectorOnAlphaCircle(135);
cornerPiece[1] = getVectorOnExtendedLine(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135), mid.y+radius, true);
cornerPiece[2] = new PVector(mid.x-radius, mid.y+radius);
cornerPiece[3] = getVectorOnExtendedLine(getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(135), mid.x-radius, false);
cornerPieces[1] = cornerPiece;
cornerPiece = new PVector[4];
cornerPiece[0] = getVectorOnAlphaCircle(225);
cornerPiece[1] = getVectorOnExtendedLine(getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(225), mid.y-radius, true);
cornerPiece[2] = new PVector(mid.x-radius, mid.y-radius);
cornerPiece[3] = getVectorOnExtendedLine(getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(225), mid.x-radius, false);
cornerPieces[2] = cornerPiece;
cornerPiece = new PVector[4];
cornerPiece[0] = new PVector(mid.x+radius, mid.y-radius);
cornerPiece[1] = getVectorOnExtendedLine(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), mid.x+radius, false);
cornerPiece[2] = getVectorOnAlphaCircle(315);
cornerPiece[3] = getVectorOnExtendedLine(getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(315), mid.y-radius, true);
cornerPieces[3] = cornerPiece;
}
void setSidePieces(){
sidePieces = new PVector[8][4];
PVector[] sidePiece = new PVector[4];
sidePiece[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), mid.x+radius, false);
sidePiece[1] = getVectorOnAlphaCircle(0);
sidePiece[2] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90));
sidePiece[3] = getVectorOnAlphaCircle(315);
sidePieces[0] = sidePiece;
sidePiece = new PVector[4];
sidePiece[0] = getVectorOnAlphaCircle(0);
sidePiece[1] = getVectorOnExtendedLine(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), mid.x+radius, false);
sidePiece[2] = getVectorOnAlphaCircle(45);
sidePiece[3] = getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0));
sidePieces[1] = sidePiece;
sidePiece = new PVector[4];
sidePiece[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), mid.y+radius, true);
sidePiece[1] = getVectorOnAlphaCircle(90);
sidePiece[2] = getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0));
sidePiece[3] = getVectorOnAlphaCircle(45);
sidePieces[2] = sidePiece;
sidePiece = new PVector[4];
sidePiece[0] = getVectorOnAlphaCircle(90);
sidePiece[1] = getVectorOnExtendedLine(getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(135), mid.y+radius, true);
sidePiece[2] = getVectorOnAlphaCircle(135);
sidePiece[3] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0));
sidePieces[3] = sidePiece;
sidePiece = new PVector[4];
sidePiece[0] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135));
sidePiece[1] = getVectorOnAlphaCircle(135);
sidePiece[2] = getVectorOnExtendedLine(getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(135), mid.x-radius, false);
sidePiece[3] = getVectorOnAlphaCircle(180);
sidePieces[4] = sidePiece;
sidePiece = new PVector[4];
sidePiece[0] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90));
sidePiece[1] = getVectorOnAlphaCircle(180);
sidePiece[2] = getVectorOnExtendedLine(getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(225), mid.x-radius, false);
sidePiece[3] = getVectorOnAlphaCircle(225);
sidePieces[5] = sidePiece;
sidePiece = new PVector[4];
sidePiece[0] = getVectorOnAlphaCircle(270);
sidePiece[1] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135));
sidePiece[2] = getVectorOnAlphaCircle(225);
sidePiece[3] = getVectorOnExtendedLine(getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(225), mid.y-radius, true);
sidePieces[6] = sidePiece;
sidePiece = new PVector[4];
sidePiece[0] = getVectorOnExtendedLine(getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(315), mid.y-radius, true);
sidePiece[1] = getVectorOnAlphaCircle(315);
sidePiece[2] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45));
sidePiece[3] = getVectorOnAlphaCircle(270);
sidePieces[7] = sidePiece;
}
void setStarPieces(){
starPieces = new PVector[8][4];
PVector[] starPiece = new PVector[4];
starPiece[0] = getVectorOnAlphaCircle(315);
starPiece[1] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90));
starPiece[2] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45));
starPiece[3] = getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315));
starPieces[0] = starPiece;
starPiece = new PVector[4];
starPiece[0] = getVectorOnAlphaCircle(0);
starPiece[1] = getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0));
starPiece[2] = getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90));
starPiece[3] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90));
starPieces[1] = starPiece;
starPiece = new PVector[4];
starPiece[0] = getLineIntersection(getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0));
starPiece[1] = getVectorOnAlphaCircle(45);
starPiece[2] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90));
starPiece[3] = getLineIntersection(getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90));
starPieces[2] = starPiece;
starPiece = new PVector[4];
starPiece[0] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(90));
starPiece[1] = getVectorOnAlphaCircle(90);
starPiece[2] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0));
starPiece[3] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0));
starPieces[3] = starPiece;
starPiece = new PVector[4];
starPiece[0] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(135), getVectorOnAlphaCircle(0));
starPiece[1] = getVectorOnAlphaCircle(135);
starPiece[2] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135));
starPiece[3] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45));
starPieces[4] = starPiece;
starPiece = new PVector[4];
starPiece[0] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135));
starPiece[1] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(45), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135));
starPiece[2] = getVectorOnAlphaCircle(180);
starPiece[3] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90));
starPieces[5] = starPiece;
starPiece = new PVector[4];
starPiece[0] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135));
starPiece[1] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135));
starPiece[2] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(90));
starPiece[3] = getVectorOnAlphaCircle(225);
starPieces[6] = starPiece;
starPiece = new PVector[4];
starPiece[0] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(45));
starPiece[1] = getLineIntersection(getVectorOnAlphaCircle(180), getVectorOnAlphaCircle(315), getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0));
starPiece[2] = getLineIntersection(getVectorOnAlphaCircle(225), getVectorOnAlphaCircle(0), getVectorOnAlphaCircle(270), getVectorOnAlphaCircle(135));
starPiece[3] = getVectorOnAlphaCircle(270);
starPieces[7] = starPiece;
}
void createMiddleStar(){
useStrokeColor();
useFillColor();
beginShape();
for (PVector middleStarVector: middleStar) {
vertex(middleStarVector.x, middleStarVector.y);
}
endShape();
}
void createCornerPieces(){
useStrokeColor();
useFillColor();
for(int i=0; i<cornerPieces.length; i++){
if(cornerPieces[i].length>0){
beginShape();
for(int j=0; j<cornerPieces[i].length; j++){
vertex(cornerPieces[i][j].x, cornerPieces[i][j].y);
}
endShape();
}
}
}
void createSidePieces(){
useStrokeColor();
useFillColor();
for(int i=0; i<sidePieces.length; i++){
if(sidePieces[i].length>0){
beginShape();
for(int j=0; j<sidePieces[i].length; j++){
vertex(sidePieces[i][j].x, sidePieces[i][j].y);
}
endShape();
}
}
}
void createStarPieces(){
useStrokeColor();
useFillColor();
for(int i=0; i<starPieces.length; i++){
if(starPieces[i].length>0){
beginShape();
for(int j=0; j<starPieces[i].length; j++){
vertex(starPieces[i][j].x, starPieces[i][j].y);
}
endShape();
}
}
}
void createInterlacingVs(){
useStrokeColor();
useFillColor();
for(int i=0; i<verticalVs.length; i++){
createLine(verticalVs[i][0], verticalVs[i][1]);
}
for(int i=0; i<horizontalVs.length; i++){
createLine(horizontalVs[i][0], horizontalVs[i][1]);
}
}
void display(){
setStrokeColor(new Float[] {0.66, 0.66, 0.8, 1.0});
setFillColor(new Float[] {0.0, 1.0, 0.0, 1.0});
createSidePieces();
setStrokeColor(new Float[] {0.66, 0.0, 0.0, 1.0});
setFillColor(new Float[] {1.0, 1.0, 1.0, 1.0});
createCornerPieces();
setStrokeColor(new Float[] {0.66, 0.0, 0.0, 1.0});
setFillColor(new Float[] {1.0, 0.0, 0.0, 1.0});
createStarPieces();
setStrokeColor(new Float[] {0.66, 0.66, 0.8, 1.0});
setFillColor(new Float[] {0.0, 0.0, 1.0, 1.0});
createMiddleStar();
}
void displayConstructionLines(){
super.displayConstructionLines();
setStrokeColor(new Float[] {0.66, 0.0, 0.8, 1.0});
createInterlacingVs();
}
}
|