summaryrefslogtreecommitdiffstats
path: root/AutoVisual/IGPHexagon.pde
blob: bc90a4d53e5d6087f1679469d1674d5214cf049c (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
class IGPHexagon extends IGPFamily{

  ArrayList <PVector> baseVectorsOnInnerHexagon;
  ArrayList <PVector> baseVectorsOnConstructionCircles;
  ArrayList <PVector> vectorsOnInnerHexagon;

  IGPHexagon(float x, float y, float d){
    super(x, y, d);
    setBaseVectorsOnInnerHexagon();
    setConstructionCircleCenters();
    setBaseVectorsOnConstructionCircles();
  }

  void setBaseVectorsOnInnerHexagon(){
    baseVectorsOnInnerHexagon = new ArrayList <PVector> (12);
    baseVectorsOnInnerHexagon.add(getLineIntersection(alphaCircleVectors.get(11), alphaCircleVectors.get(1), mid, alphaCircleVectors.get(0)));
    baseVectorsOnInnerHexagon.add(alphaCircleVectors.get(1));
    baseVectorsOnInnerHexagon.add(getLineIntersection(alphaCircleVectors.get(1), alphaCircleVectors.get(3), mid, alphaCircleVectors.get(2)));
    baseVectorsOnInnerHexagon.add(alphaCircleVectors.get(3));
    baseVectorsOnInnerHexagon.add(getLineIntersection(alphaCircleVectors.get(3), alphaCircleVectors.get(5), mid, alphaCircleVectors.get(4)));
    baseVectorsOnInnerHexagon.add(alphaCircleVectors.get(5));
    baseVectorsOnInnerHexagon.add(getLineIntersection(alphaCircleVectors.get(5), alphaCircleVectors.get(7), mid, alphaCircleVectors.get(6)));
    baseVectorsOnInnerHexagon.add(alphaCircleVectors.get(7));
    baseVectorsOnInnerHexagon.add(getLineIntersection(alphaCircleVectors.get(7), alphaCircleVectors.get(9), mid, alphaCircleVectors.get(8)));
    baseVectorsOnInnerHexagon.add(alphaCircleVectors.get(9));
    baseVectorsOnInnerHexagon.add(getLineIntersection(alphaCircleVectors.get(9), alphaCircleVectors.get(11), mid, alphaCircleVectors.get(10)));
    baseVectorsOnInnerHexagon.add(alphaCircleVectors.get(11));
  }

  void setConstructionCircleCenters(){
    constructionCircleCenters = new ArrayList <PVector> (4);
    constructionCircleCenters.add(alphaCircleVectors.get(0));
    constructionCircleCenters.add(alphaCircleVectors.get(2));
    constructionCircleCenters.add(alphaCircleVectors.get(4));
    constructionCircleCenters.add(alphaCircleVectors.get(6));
    constructionCircleCenters.add(alphaCircleVectors.get(8));
    constructionCircleCenters.add(alphaCircleVectors.get(10));
  }

  void setBaseVectorsOnConstructionCircles(){
    baseVectorsOnConstructionCircles = new ArrayList <PVector>(12);
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(0), 0));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(1), 0));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(1), 60));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(1), 120));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(2), 120));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(3), 120));  
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(3), 180));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(4), 180));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(4), 240));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(4), 300));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(5), 300));
    baseVectorsOnConstructionCircles.add(getVectorOnCircle(constructionCircleCenters.get(5), 0));
  }

  void createDividingLinesOnConstructionCircles(){
    useStrokeColor();
    useFillColor();
    createLine(baseVectorsOnConstructionCircles.get(0), baseVectorsOnConstructionCircles.get(6));
    createLine(baseVectorsOnConstructionCircles.get(1), baseVectorsOnConstructionCircles.get(7));
    createLine(baseVectorsOnConstructionCircles.get(2), baseVectorsOnConstructionCircles.get(8));
    createLine(baseVectorsOnConstructionCircles.get(3), baseVectorsOnConstructionCircles.get(9));
    createLine(baseVectorsOnConstructionCircles.get(4), baseVectorsOnConstructionCircles.get(10));
    createLine(baseVectorsOnConstructionCircles.get(5), baseVectorsOnConstructionCircles.get(11));
  }

  void createDividingLinesOnInnerHexagon(){
    useStrokeColor();
    useFillColor();
    createLine(baseVectorsOnInnerHexagon.get(0), baseVectorsOnInnerHexagon.get(6));
    createLine(baseVectorsOnInnerHexagon.get(1), baseVectorsOnInnerHexagon.get(7));
    createLine(baseVectorsOnInnerHexagon.get(2), baseVectorsOnInnerHexagon.get(8));
    createLine(baseVectorsOnInnerHexagon.get(3), baseVectorsOnInnerHexagon.get(9));
    createLine(baseVectorsOnInnerHexagon.get(4), baseVectorsOnInnerHexagon.get(10));
    createLine(baseVectorsOnInnerHexagon.get(5), baseVectorsOnInnerHexagon.get(11));
  }

  void createVectorIndicatorOnInnerHexagon(float diameter){
    useStrokeColor();
    useFillColor();
    for (PVector vector: vectorsOnInnerHexagon){
      createCircle(vector, diameter);
    }
  }

  void displayConstructionLines(){
    super.displayConstructionLines();
    createDividingLinesOnConstructionCircles();
    setStrokeColor(new Float[] {0.4, 0.8, 0.4, 1.0});
    setFillColor(new Float[] {0.0, 0.0, 0.0, 0.0});
    createDividingLinesOnInnerHexagon();
    createInnerHexagon();
  }
}