100 lines
2.5 KiB
Python
100 lines
2.5 KiB
Python
|
# Import packages
|
|||
|
from dash import Dash, dcc, html, Input, Output
|
|||
|
import feffery_antd_components as fac
|
|||
|
import plotly.graph_objs as go
|
|||
|
from listen import VoltageReceiver
|
|||
|
|
|||
|
|
|||
|
def read_from_file(filename):
|
|||
|
"""
|
|||
|
This function read data from a local .txt file
|
|||
|
|
|||
|
:param filename: str, name of the file
|
|||
|
:return: str, data read from the file
|
|||
|
"""
|
|||
|
with open(filename, 'r') as file:
|
|||
|
data = file.read().replace('\n', '')
|
|||
|
return data
|
|||
|
|
|||
|
|
|||
|
def write_to_file(data, filename):
|
|||
|
"""
|
|||
|
This function write data to a local .txt file
|
|||
|
|
|||
|
:param data: str, data to be written to the file
|
|||
|
:param filename: str, name of the file
|
|||
|
"""
|
|||
|
with open(filename, 'w') as file:
|
|||
|
file.write(data)
|
|||
|
|
|||
|
|
|||
|
def go_figure_set(X, Y, figuremode, width=600, height=400, title=''):
|
|||
|
# 创建折线图
|
|||
|
line_chart = go.Figure(data=go.Scatter(x=X, y=Y, mode=figuremode))
|
|||
|
line_chart.update_layout(
|
|||
|
autosize=False,
|
|||
|
width=width,
|
|||
|
height=height,
|
|||
|
title=title
|
|||
|
)
|
|||
|
return line_chart
|
|||
|
|
|||
|
|
|||
|
# Initialize the app
|
|||
|
app = Dash(__name__)
|
|||
|
|
|||
|
|
|||
|
X = list(range(1, 1001))
|
|||
|
Y = [0] * 1000
|
|||
|
|
|||
|
|
|||
|
# App layout
|
|||
|
app.layout = html.Div(
|
|||
|
[
|
|||
|
html.Div([
|
|||
|
dcc.Graph(
|
|||
|
id='line-chart',
|
|||
|
figure=go_figure_set(X, Y, 'lines'),
|
|||
|
)], style={
|
|||
|
'display': 'inline-block',
|
|||
|
'position': 'absolute', # 使用绝对定位
|
|||
|
'right': '20px', # 距离页面右边20px
|
|||
|
'top': '20px', # 距离页面顶部20px
|
|||
|
'width': '600px' # 设置图表容器的宽度
|
|||
|
}), # 将折线图添加到Dash应用中
|
|||
|
dcc.Interval(
|
|||
|
id='interval-update',
|
|||
|
interval=1*10, # in milliseconds
|
|||
|
),
|
|||
|
],
|
|||
|
style={
|
|||
|
'padding': '50px 100px'
|
|||
|
},
|
|||
|
)
|
|||
|
|
|||
|
# Define callback to update statistic
|
|||
|
|
|||
|
|
|||
|
@app.callback(
|
|||
|
Output('line-chart', 'figure'),
|
|||
|
Input('interval-update', 'n_intervals')
|
|||
|
)
|
|||
|
def update_output(n_intervals):
|
|||
|
data = read_from_file('test.txt')
|
|||
|
if data == '#':
|
|||
|
pass
|
|||
|
else:
|
|||
|
Y.append(float(data))
|
|||
|
Y.pop(0)
|
|||
|
write_to_file('#', "test.txt")
|
|||
|
line_chart = go_figure_set(X, Y, 'lines')
|
|||
|
# 更新图表布局,设置新的X轴范围
|
|||
|
line_chart.update_layout(xaxis=dict(range=[0, 2001]))
|
|||
|
line_chart.add_trace(go.Scatter(x=list(range(1001, 1051)), y=list(range(1, 51)), mode='lines',line=dict(color='red')))
|
|||
|
return line_chart
|
|||
|
|
|||
|
|
|||
|
# Run the app
|
|||
|
if __name__ == '__main__':
|
|||
|
app.run_server(debug=True, port=8050)
|