/
polar-area.py
56 lines (45 loc) · 1.68 KB
/
polar-area.py
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
# Copyright 2021-2024 Avaiga Private Limited
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
# an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
# specific language governing permissions and limitations under the License.
# -----------------------------------------------------------------------------------------
# To execute this script, make sure that the taipy-gui package is installed in your
# Python environment and run:
# python <script>
# -----------------------------------------------------------------------------------------
import math
from taipy.gui import Gui
# One data point for each degree
theta = range(0, 360)
# Parametric equation that draws a shape (source Wolfram Mathworld)
def draw_heart(angle):
a = math.radians(angle)
sa = math.sin(a)
return 2 - 2 * sa + sa * (math.sqrt(math.fabs(math.cos(a))) / (sa + 1.4))
data = {
# Create the heart shape
"r": [draw_heart(angle) for angle in theta],
"theta": theta,
}
options = {"fill": "toself"}
layout = {
# Hide the legend
"showlegend": False,
"polar": {
# Hide the angular axis
"angularaxis": {"visible": False},
# Hide the radial axis
"radialaxis": {"visible": False},
},
}
page = """
# Polar - Area
<|{data}|chart|type=scatterpolar|mode=none|layout={layout}|options={options}|>
"""
Gui(page).run()