polar_simple.py 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. # Copyright 2021-2025 Avaiga Private Limited
  2. #
  3. # Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
  4. # the License. You may obtain a copy of the License at
  5. #
  6. # http://www.apache.org/licenses/LICENSE-2.0
  7. #
  8. # Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
  9. # an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
  10. # specific language governing permissions and limitations under the License.
  11. # -----------------------------------------------------------------------------------------
  12. # To execute this script, make sure that the taipy-gui package is installed in your
  13. # Python environment and run:
  14. # python <script>
  15. # -----------------------------------------------------------------------------------------
  16. import math
  17. from taipy.gui import Gui
  18. # Parametric equation that draws a shape (source Wolfram Mathworld)
  19. def draw_heart(angle):
  20. a = math.radians(angle)
  21. sa = math.sin(a)
  22. return 2 - 2 * sa + sa * (math.sqrt(math.fabs(math.cos(a))) / (sa + 1.4))
  23. # One data point for each degree
  24. theta = range(0, 360)
  25. data = {
  26. # Create the heart shape
  27. "r": [draw_heart(angle) for angle in theta],
  28. "theta": theta,
  29. }
  30. page = """
  31. <|{data}|chart|type=scatterpolar|mode=lines|>
  32. """
  33. if __name__ == "__main__":
  34. Gui(page).run(title="Chart - Polar - Simple")