main.py 3.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. from kivy.app import App
  2. from kivy.uix.widget import Widget
  3. from kivy.uix.button import Button
  4. from kivy.uix.gridlayout import GridLayout
  5. from kivy.uix.label import Label
  6. from kivy.uix.textinput import TextInput
  7. from kivy.lang import Builder
  8. import asyncio
  9. from bleak import BleakClient,BleakScanner
  10. import json
  11. STM32_UUID = "00001101-0000-1000-8000-00805F9B34FB"
  12. class InfoWidget(Widget):
  13. def __init__(self, **kwargs):
  14. super(InfoWidget, self).__init__(**kwargs)
  15. self.size = (800,480)
  16. asyncio.run(self.discover_devices())
  17. async def discover_devices(self):
  18. devices = await BleakScanner.discover()
  19. grid00 = GridLayout(cols=1,rows=2,width=self.width,height=self.height / 4)
  20. grid00.top = self.top
  21. self.add_widget(grid00)
  22. grid01 = GridLayout(cols=2,rows=1,width=grid00.width,height=grid00.height / 2)
  23. grid00.add_widget(grid01)
  24. grid01.add_widget(Label(text="Device Name:",width=grid00.width / 2,height=grid00.height / 2,font_size=50))
  25. deviceName = "HC-06"
  26. grid01.add_widget(TextInput(text=deviceName,width=grid00.width / 2,height=grid00.height / 2,font_size=40))
  27. connect_button = Button(text="Connect",width=grid00.width,height=grid00.height / 2,center_x=grid00.center_x,font_size=40)
  28. Builder.load_string('''
  29. <Button>:
  30. id: connect_button
  31. on_touch_down: root.root.remove_widget(grid00)
  32. ''')
  33. grid00.add_widget(connect_button)
  34. for d in devices:
  35. if d.name == deviceName:
  36. await self.connect_and_receive(d.address)
  37. self.add_widget(Label(text="Connected",width=self.width,height=self.height / 4))
  38. break
  39. # grid1 = GridLayout(cols=2,rows=5,width=self.width,height=self.height)
  40. # self.add_widget(grid1)
  41. # for num,d in enumerate(devices):
  42. # button = Button(text=f"{d.name}")
  43. # button.height = grid1.height / 5
  44. # button.width = grid1.width / 2
  45. # button.on_touch_down = lambda instance, d=d: asyncio.run(self.connect_and_receive(d.address))
  46. # grid1.add_widget(button)
  47. # if num >= 9:
  48. # break
  49. async def connect_and_receive(self, address):
  50. async with BleakClient(address) as client:
  51. if await client.is_connected():
  52. rawdata = await client.read_gatt_char(STM32_UUID)
  53. data = rawdata.decode("utf-8")
  54. if data.startswith("[") and data.endswith("]"):
  55. list = json.loads(data)
  56. info = "基波频率:" + str(list[0]) + "Hz\n" + \
  57. "THD:" + str(list[6]) + "%\n" + \
  58. "基波幅值:" + str(list[1]) + "V\n" + \
  59. "二次谐波:" + str(list[2]) + "V\n" + \
  60. "三次谐波:" + str(list[3]) + "V\n" + \
  61. "四次谐波:" + str(list[4]) + "V\n" + \
  62. "五次谐波:" + str(list[5]) + "V\n"
  63. else:
  64. info = "传输数据出错"
  65. label = Label(text=info)
  66. self.add_widget(label)
  67. return
  68. else:
  69. print("Failed to connect to device.")
  70. def debug(self):
  71. # self.size = (800,480)
  72. grid = GridLayout(cols=2,rows=4,width=self.width,height=self.height)
  73. self.add_widget(grid)
  74. for i in range(8):
  75. button = Button(text=str(i))
  76. button.width = grid.width / 2
  77. button.height = grid.height / 4
  78. grid.add_widget(button)
  79. class STI2021A(App):
  80. def build(self):
  81. info = InfoWidget()
  82. # info.debug()
  83. return info
  84. if __name__ == '__main__':
  85. STI2021A().run()