main.py 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. #!/usr/bin/env python3
  2. import datetime
  3. from nicegui import ui
  4. def build_svg():
  5. '''returns svg showing the current time.
  6. Original was taken from https://de.m.wikipedia.org/wiki/Datei:Station_Clock.svg.'''
  7. now = datetime.datetime.now()
  8. return f'''
  9. <svg width="800" height="800" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
  10. <circle cx="400" cy="400" r="400" fill="#fff"/>
  11. <use transform="matrix(-1,0,0,1,800,0)" xlink:href="#c"/>
  12. <g id="c">
  13. <g id="d">
  14. <path d="m400 40v107" stroke="#000" stroke-width="26.7"/>
  15. <g id="a">
  16. <path d="m580 88.233-42.5 73.612" stroke="#000" stroke-width="26.7"/>
  17. <g id="e">
  18. <path id="b" d="m437.63 41.974-3.6585 34.808" stroke="#000" stroke-width="13.6"/>
  19. <use transform="rotate(6 400 400)" xlink:href="#b"/>
  20. </g>
  21. <use transform="rotate(12 400 400)" xlink:href="#e"/>
  22. </g>
  23. <use transform="rotate(30 400 400)" xlink:href="#a"/>
  24. <use transform="rotate(60 400 400)" xlink:href="#a"/>
  25. </g>
  26. <use transform="rotate(90 400 400)" xlink:href="#d"/>
  27. </g>
  28. <g transform="rotate({(250 + now.hour*6*5)%360} 400 400)">
  29. <path d="m334.31 357.65-12.068 33.669 283.94 100.8 23.565-10.394-13.332-24.325z"/>
  30. </g>
  31. <g transform="rotate({(117.3 + now.minute*6)%360} 400 400)">
  32. <path d="m480.73 344.98 11.019 21.459-382.37 199.37-18.243-7.2122 4.768-19.029z"/>
  33. </g>
  34. <g transform="rotate({(169 + now.second*6)%360} 400 400)">
  35. <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"/>
  36. </g>
  37. </svg>
  38. '''
  39. clock = ui.html().classes('self-center')
  40. ui.timer(1, lambda: clock.set_content(build_svg()))
  41. ui.run()