main.py 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. #!/usr/bin/env python3
  2. from datetime import datetime
  3. from nicegui import ui
  4. def build_svg() -> str:
  5. """Returns an SVG showing the current time.
  6. Original was borrowed from https://de.m.wikipedia.org/wiki/Datei:Station_Clock.svg.
  7. """
  8. now = datetime.now()
  9. return f'''
  10. <svg width="800" height="800" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
  11. <circle cx="400" cy="400" r="400" fill="#fff"/>
  12. <use transform="matrix(-1,0,0,1,800,0)" xlink:href="#c"/>
  13. <g id="c">
  14. <g id="d">
  15. <path d="m400 40v107" stroke="#000" stroke-width="26.7"/>
  16. <g id="a">
  17. <path d="m580 88.233-42.5 73.612" stroke="#000" stroke-width="26.7"/>
  18. <g id="e">
  19. <path id="b" d="m437.63 41.974-3.6585 34.808" stroke="#000" stroke-width="13.6"/>
  20. <use transform="rotate(6 400 400)" xlink:href="#b"/>
  21. </g>
  22. <use transform="rotate(12 400 400)" xlink:href="#e"/>
  23. </g>
  24. <use transform="rotate(30 400 400)" xlink:href="#a"/>
  25. <use transform="rotate(60 400 400)" xlink:href="#a"/>
  26. </g>
  27. <use transform="rotate(90 400 400)" xlink:href="#d"/>
  28. </g>
  29. <g transform="rotate({250 + now.hour / 12 * 360} 400 400)">
  30. <path d="m334.31 357.65-12.068 33.669 283.94 100.8 23.565-10.394-13.332-24.325z"/>
  31. </g>
  32. <g transform="rotate({117 + now.minute / 60 * 360} 400 400)">
  33. <path d="m480.73 344.98 11.019 21.459-382.37 199.37-18.243-7.2122 4.768-19.029z"/>
  34. </g>
  35. <g transform="rotate({169 + now.second / 60 * 360} 400 400)">
  36. <path d="m410.21 301.98-43.314 242.68a41.963 41.963 0 0 0-2.8605-0.091 41.963 41.963 0 0 0-41.865 42.059 41.963 41.963 0 0 0 30.073 40.144l-18.417 103.18 1.9709 3.9629 3.2997-2.9496 21.156-102.65a41.963 41.963 0 0 0 3.9771 0.1799 41.963 41.963 0 0 0 41.865-42.059 41.963 41.963 0 0 0-29.003-39.815l49.762-241.44zm-42.448 265.56a19.336 19.336 0 0 1 15.703 18.948 19.336 19.336 0 0 1-19.291 19.38 19.336 19.336 0 0 1-19.38-19.291 19.336 19.336 0 0 1 19.291-19.38 19.336 19.336 0 0 1 3.6752 0.3426z" fill="#a40000"/>
  37. </g>
  38. </svg>
  39. '''
  40. clock = ui.html().classes('self-center')
  41. ui.timer(1, lambda: clock.set_content(build_svg()))
  42. ui.run()