summaryrefslogtreecommitdiffstats
path: root/AutoVisual/IGPEsrefogluMosque.pde
blob: 20ee77ec6ef05134c3cebbe0d1bfe20482456867 (plain)
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
class IGPEsrefogluMosque extends IGPHexagon{

  PVector[][] cornerPieces;
  PVector[][] sidePieces;
  PVector[] centerStar;
  ArrayList <PVector> vectorsOnInterlockingTriangles;
  IGPEsrefogluMosque(float x, float y, float d){
    super(x, y, d);
    setVectorsOnInterlockingTriangles();
    setVectorsOnInnerHexagon();
    setCornerPieces(6,6);
    setSidePieces(6,3);
    setCenterStar(12);
  }

  void setVectorsOnInnerHexagon(){
    vectorsOnInnerHexagon = new ArrayList <PVector> (18);
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(4), vectorsOnInterlockingTriangles.get(0), baseVectorsOnInnerHexagon.get(0).x, false));
    vectorsOnInnerHexagon.add(baseVectorsOnInnerHexagon.get(1));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(1), vectorsOnInterlockingTriangles.get(3), vectorsOnInterlockingTriangles.get(0).x, false));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(5), vectorsOnInterlockingTriangles.get(1), mid.y+(radius*5/6), true));
    vectorsOnInnerHexagon.add(baseVectorsOnInnerHexagon.get(3));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(4), vectorsOnInterlockingTriangles.get(2), mid.y+(radius*5/6), true));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(0), vectorsOnInterlockingTriangles.get(2), vectorsOnInterlockingTriangles.get(3).x, false));
    vectorsOnInnerHexagon.add(baseVectorsOnInnerHexagon.get(5));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(5), vectorsOnInterlockingTriangles.get(3), baseVectorsOnInnerHexagon.get(6).x, false));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(1), vectorsOnInterlockingTriangles.get(3), baseVectorsOnInnerHexagon.get(6).x, false));
    vectorsOnInnerHexagon.add(baseVectorsOnInnerHexagon.get(7));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(0), vectorsOnInterlockingTriangles.get(4), vectorsOnInterlockingTriangles.get(3).x, false));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(2), vectorsOnInterlockingTriangles.get(4), mid.y-(radius*5/6), true));
    vectorsOnInnerHexagon.add(baseVectorsOnInnerHexagon.get(9));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(1), vectorsOnInterlockingTriangles.get(5), mid.y-(radius*5/6), true));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(3), vectorsOnInterlockingTriangles.get(5), vectorsOnInterlockingTriangles.get(0).x, false));
    vectorsOnInnerHexagon.add(baseVectorsOnInnerHexagon.get(11));
    vectorsOnInnerHexagon.add(getVectorOnExtendedLine(vectorsOnInterlockingTriangles.get(0), vectorsOnInterlockingTriangles.get(2), baseVectorsOnInnerHexagon.get(0).x, false));
  }

  void setVectorsOnInterlockingTriangles(){
    vectorsOnInterlockingTriangles = new ArrayList <PVector> (6);
    vectorsOnInterlockingTriangles.add(getLineIntersection(baseVectorsOnInnerHexagon.get(1), baseVectorsOnInnerHexagon.get(9), baseVectorsOnInnerHexagon.get(11), baseVectorsOnInnerHexagon.get(3)));
    vectorsOnInterlockingTriangles.add(getLineIntersection(baseVectorsOnInnerHexagon.get(1), baseVectorsOnInnerHexagon.get(5), baseVectorsOnInnerHexagon.get(11), baseVectorsOnInnerHexagon.get(3)));
    vectorsOnInterlockingTriangles.add(getLineIntersection(baseVectorsOnInnerHexagon.get(1), baseVectorsOnInnerHexagon.get(5), baseVectorsOnInnerHexagon.get(3), baseVectorsOnInnerHexagon.get(7)));
    vectorsOnInterlockingTriangles.add(getLineIntersection(baseVectorsOnInnerHexagon.get(0), baseVectorsOnInnerHexagon.get(6), baseVectorsOnInnerHexagon.get(3), baseVectorsOnInnerHexagon.get(7)));
    vectorsOnInterlockingTriangles.add(getLineIntersection(baseVectorsOnInnerHexagon.get(2), baseVectorsOnInnerHexagon.get(8), baseVectorsOnInnerHexagon.get(11), baseVectorsOnInnerHexagon.get(7)));
    vectorsOnInterlockingTriangles.add(getLineIntersection(baseVectorsOnInnerHexagon.get(1), baseVectorsOnInnerHexagon.get(9), baseVectorsOnInnerHexagon.get(11), baseVectorsOnInnerHexagon.get(7)));
  }

  void setCornerPieces(int amount, int numberOfVectors){
    cornerPieces = new PVector[amount][numberOfVectors];
    PVector[] cornerPiece = new PVector[numberOfVectors];
    cornerPiece[0] = vectorsOnInnerHexagon.get(0);
    cornerPiece[1] = vectorsOnInnerHexagon.get(1);
    cornerPiece[2] = vectorsOnInnerHexagon.get(2);
    cornerPiece[3] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    cornerPiece[4] = getLineIntersection(vectorsOnInnerHexagon.get(17), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    cornerPiece[5] = getLineIntersection(vectorsOnInnerHexagon.get(17), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
    cornerPieces[0] = cornerPiece;
    cornerPiece = new PVector[numberOfVectors];
    cornerPiece[0] = vectorsOnInnerHexagon.get(3);
    cornerPiece[1] = vectorsOnInnerHexagon.get(4);
    cornerPiece[2] = vectorsOnInnerHexagon.get(5);
    cornerPiece[3] = getLineIntersection(vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(17));
    cornerPiece[4] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(17));
    cornerPiece[5] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    cornerPieces[1] = cornerPiece;
    cornerPiece = new PVector[numberOfVectors];
    cornerPiece[0] = vectorsOnInnerHexagon.get(6);
    cornerPiece[1] = vectorsOnInnerHexagon.get(7);
    cornerPiece[2] = vectorsOnInnerHexagon.get(8);
    cornerPiece[3] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15));
    cornerPiece[4] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    cornerPiece[5] = getLineIntersection(vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(17), vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    cornerPieces[2] = cornerPiece;
    cornerPiece = new PVector[numberOfVectors];
    cornerPiece[0] = vectorsOnInnerHexagon.get(9);
    cornerPiece[1] = vectorsOnInnerHexagon.get(10);
    cornerPiece[2] = vectorsOnInnerHexagon.get(11);
    cornerPiece[3] = getLineIntersection(vectorsOnInnerHexagon.get(11), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    cornerPiece[4] = getLineIntersection(vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15), vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    cornerPiece[5] = getLineIntersection(vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15), vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9));
    cornerPieces[3] = cornerPiece;
    cornerPiece = new PVector[numberOfVectors];
    cornerPiece[0] = vectorsOnInnerHexagon.get(12);
    cornerPiece[1] = vectorsOnInnerHexagon.get(13);
    cornerPiece[2] = vectorsOnInnerHexagon.get(14);
    cornerPiece[3] = getLineIntersection(vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    cornerPiece[4] = getLineIntersection(vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
    cornerPiece[5] = getLineIntersection(vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
    cornerPieces[4] = cornerPiece;
    cornerPiece = new PVector[numberOfVectors];
    cornerPiece[0] = vectorsOnInnerHexagon.get(15);
    cornerPiece[1] = vectorsOnInnerHexagon.get(16);
    cornerPiece[2] = vectorsOnInnerHexagon.get(17);
    cornerPiece[3] = getLineIntersection(vectorsOnInnerHexagon.get(17), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
    cornerPiece[4] = getLineIntersection(vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
    cornerPiece[5] = getLineIntersection(vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14), vectorsOnInnerHexagon.get(15), vectorsOnInnerHexagon.get(8));
    cornerPieces[5] = cornerPiece;
  }

  void setSidePieces(int amount, int numberOfVectors){
    sidePieces = new PVector[amount][numberOfVectors];
    PVector[] sidePiece = new PVector[numberOfVectors];
    sidePiece[0] = vectorsOnInnerHexagon.get(17);
    sidePiece[1] = vectorsOnInnerHexagon.get(0);
    sidePiece[2] = getLineIntersection(vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11), vectorsOnInnerHexagon.get(17), vectorsOnInnerHexagon.get(6));
    sidePieces[0] = sidePiece;
    sidePiece = new PVector[numberOfVectors];
    sidePiece[0] = vectorsOnInnerHexagon.get(2);
    sidePiece[1] = vectorsOnInnerHexagon.get(3);
    sidePiece[2] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    sidePieces[1] = sidePiece;
    sidePiece = new PVector[numberOfVectors];
    sidePiece[0] = vectorsOnInnerHexagon.get(5);
    sidePiece[1] = vectorsOnInnerHexagon.get(6);
    sidePiece[2] = getLineIntersection(vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(17));
    sidePieces[2] = sidePiece;
    sidePiece = new PVector[numberOfVectors];
    sidePiece[0] = vectorsOnInnerHexagon.get(8);
    sidePiece[1] = vectorsOnInnerHexagon.get(9);
    sidePiece[2] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15));
    sidePieces[3] = sidePiece;
    sidePiece = new PVector[numberOfVectors];
    sidePiece[0] = vectorsOnInnerHexagon.get(11);
    sidePiece[1] = vectorsOnInnerHexagon.get(12);
    sidePiece[2] = getLineIntersection(vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11), vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    sidePieces[4] = sidePiece;
    sidePiece = new PVector[numberOfVectors];
    sidePiece[0] = vectorsOnInnerHexagon.get(14);
    sidePiece[1] = vectorsOnInnerHexagon.get(15);
    sidePiece[2] = getLineIntersection(vectorsOnInnerHexagon.get(14), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15));
    sidePieces[5] = sidePiece;
  }

  void setCenterStar(int numberOfVectors){
    centerStar = new PVector[numberOfVectors];
    centerStar[0] = getLineIntersection(vectorsOnInnerHexagon.get(17), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
    centerStar[1] = getLineIntersection(vectorsOnInnerHexagon.get(17), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    centerStar[2] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    centerStar[3] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(17));
    centerStar[4] = getLineIntersection(vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12), vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(17));
    centerStar[5] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    centerStar[6] = getLineIntersection(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9), vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15));
    centerStar[7] = getLineIntersection(vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15), vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    centerStar[8] = getLineIntersection(vectorsOnInnerHexagon.get(11), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    centerStar[9] = getLineIntersection(vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
    centerStar[10] = getLineIntersection(vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15), vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    centerStar[11] = getLineIntersection(vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14), vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
  }

  void createInterlockingTriangles(){
    useStrokeColor();
    useFillColor();
    createInnerTriangle();
    createInnerTriangleTilted(60);
  }

  void createParallelBorderLines(){
    useStrokeColor();
    useFillColor();
    createLine(vectorsOnInnerHexagon.get(0), vectorsOnInnerHexagon.get(11));
    createLine(vectorsOnInnerHexagon.get(2), vectorsOnInnerHexagon.get(9));
    createLine(vectorsOnInnerHexagon.get(3), vectorsOnInnerHexagon.get(14));
    createLine(vectorsOnInnerHexagon.get(5), vectorsOnInnerHexagon.get(12));
    createLine(vectorsOnInnerHexagon.get(6), vectorsOnInnerHexagon.get(17));
    createLine(vectorsOnInnerHexagon.get(8), vectorsOnInnerHexagon.get(15));
  }

  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 createCenterStar(){
    useStrokeColor();
    useFillColor();
    beginShape();
    for(int i=0; i<centerStar.length; i++){
      vertex(centerStar[i].x, centerStar[i].y);
    }
    endShape();
  }

  void display(){
    setStrokeColor(new Float[] {0.0, 0.0, 0.0, 0.0});
    setFillColor(new Float[] {1.0, 1.0, 1.0, 1.0});
    createCornerPieces();
    setStrokeColor(new Float[] {0.66, 0.66, 0.8, 0.0});
    setFillColor(new Float[] {0.0, 1.0, 0.0, 1.0});
    createSidePieces();
    setStrokeColor(new Float[] {0.0, 0.0, 0.0, 0.0});
    setFillColor(new Float[] {0.0, 0.0, 1.0, 1.0});
    createCenterStar();
  }

  void displayConstructionLines(){
    super.displayConstructionLines();
    setStrokeColor(new Float[] {0.4, 0.4, 0.8, 1.0});
    createInterlockingTriangles();
    createParallelBorderLines();
    setStrokeColor(new Float[] {0.8, 0.0, 0.0, 1.0});
    setFillColor(new Float[] {0.8, 0.8, 0.8, 1.0});
    createVectorIndicatorOnInnerHexagon(4);
    setStrokeColor(new Float[] {0.4, 0.4, 0.8, 1.0});
    setFillColor(new Float[] {0.0, 0.0, 0.0, 0.0});
  }

}