Skip to content

Commit

Permalink
tweak
Browse files Browse the repository at this point in the history
  • Loading branch information
dkallen78 committed Dec 3, 2023
1 parent 074c2be commit 2c5105f
Showing 1 changed file with 2 additions and 2 deletions.
4 changes: 2 additions & 2 deletions ternary-clock/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ This clock was inspired by a conversation I had with someone on Reddit.

The basic idea is a a clock built around base 3 so the fundamental division of the day is into three parts. In my code I call these parts "terns" but if someone has something better, I'll use that instead. Each tern is divided into 9 hours; each hour into 27 minutes, and each minute into 81 seconds. This makes the hour<sub>3</sub> 89% the length of the hour<sub>60</sub>, the minute<sub>3</sub> 97% longer than the minute<sub>60</sub>, and the second<sub>3</sub> 46% longer than the second<sub>60</sub>.

The hardest part was wrapping my head around drawing part of a circle with the path element of SVG and ironing out those kinks. I've made enough clocks that the trigonometry of distributing points on a circle came back to me pretty quickly. The tricky part was finding a way to ensure that all of the gaps between the cells would be the same. The solution to that was in calculating the angle of the gap between each concentric cell based on the distance I wanted between them. Basically I needed to double the arcsine of half the gap divided by the radius to the arc.
The hardest part was wrapping my head around drawing part of a circle with the `<path>` element of SVG and ironing out those kinks. I've made enough clocks that the trigonometry of distributing points on a circle came back to me pretty quickly. The tricky part was finding a way to ensure that all of the gaps between the cells would be the same. The solution to that was in calculating the angle of the gap between each concentric cell based on the distance I wanted between them. Basically I needed to double the arcsine of half the gap divided by the radius to the arc.

`2 * Math.asin((gap / 2) / radius)`

Expand All @@ -16,4 +16,4 @@ After tweaking the original clock I decided that I wanted to have the cells appe

There's some wonky behavior that starts happening if I rotate to 180 or 90 degrees that I don't fully understand but I've got clean animations right now, so I'm not going to stress it much.

That's a lie. I think part of the problem is my method of finding the center is not precise and I need to make it more accurate. I'm basically just finding the center of the box that bounds the <path> element which *mostly* works. What I think I need to do, is store precise information on all of the cells that I can use when I need to change them.
That's a lie. I think part of the problem is my method of finding the center is not precise and I need to make it more accurate. I'm basically just finding the center of the box that bounds the `<path>` element which *mostly* works. What I think I need to do, is store precise information on all of the cells that I can use when I need to change them.

0 comments on commit 2c5105f

Please sign in to comment.