test.py 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. #===============================================================================
  4. #
  5. # test.py
  6. #
  7. # Test program for the simple GL Viewer.
  8. #
  9. # Copyright (c) 2011, Arne Schmitz <arne.schmitz@gmx.net>
  10. # All rights reserved.
  11. #
  12. # Redistribution and use in source and binary forms, with or without
  13. # modification, are permitted provided that the following conditions are met:
  14. # * Redistributions of source code must retain the above copyright
  15. # notice, this list of conditions and the following disclaimer.
  16. # * Redistributions in binary form must reproduce the above copyright
  17. # notice, this list of conditions and the following disclaimer in the
  18. # documentation and/or other materials provided with the distribution.
  19. # * Neither the name of the <organization> nor the
  20. # names of its contributors may be used to endorse or promote products
  21. # derived from this software without specific prior written permission.
  22. #
  23. # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
  24. # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  25. # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  26. # DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
  27. # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  28. # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  29. # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  30. # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  31. # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  32. # SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  33. #
  34. #===============================================================================
  35. import math
  36. import time
  37. import sys
  38. from PyQt5.QtGui import *
  39. from PyQt5.QtWidgets import *
  40. from PyQt5.QtCore import *
  41. from MapGLWidget import MapGLWidget
  42. import json
  43. import dijkstra.Map as mp
  44. import ControllWidget
  45. import JointContrallerWidget
  46. import RobotData as RD
  47. import message_pb2 as message
  48. import google.protobuf.json_format as jtf
  49. import uuid
  50. #===============================================================================
  51. class MainWindow(QMainWindow):
  52. """docstring for Mainwindow"""
  53. djks_map_=mp.DijikstraMap()
  54. ui_nodes={}
  55. ui_nodes["street_nodes"]=[]
  56. ui_nodes["space_nodes"]=[]
  57. def __init__(self, parent = None):
  58. super(MainWindow,self).__init__(parent)
  59. self.basic()
  60. self.count_frame_=ControllWidget.CountFrame()
  61. self.LoadMap()
  62. config1={"label":"AgvMain",
  63. "street_nodes":self.ui_nodes["street_nodes"],
  64. "space_nodes":self.ui_nodes["space_nodes"],
  65. # "mqtt":["pyui1","192.168.0.224",1883,"admin","zx123456"],
  66. # "mqtt":["pyui1","192.168.225.224",1883,"admin","zx123456"],
  67. "mqtt":["pyui1","192.168.0.70",1883,"admin","zx123456"],
  68. "subTopics":{"agv_main/agv_statu":message.RobotStatu.__name__,
  69. "agv_main/nav_statu":message.NavStatu.__name__},
  70. "cmdTopic":"agv_main/nav_cmd",
  71. "robotColor":[0.7,0.2,0.3]}
  72. config2={"label":"AGV2",
  73. "street_nodes":self.ui_nodes["street_nodes"],
  74. "space_nodes":self.ui_nodes["space_nodes"],
  75. # "mqtt":["pyui2","192.168.0.224",1883,"admin","zx123456"],
  76. # "mqtt":["pyui2","192.168.225.224",1883,"admin","zx123456"],
  77. "mqtt":["pyui1","192.168.0.71",1883,"admin","zx123456"],
  78. "subTopics":{"agv_child/agv_statu":message.RobotStatu.__name__,
  79. "agv_child/nav_statu":message.NavStatu.__name__},
  80. "cmdTopic":"agv_child/nav_cmd",
  81. "robotColor":[0.4,0.2,0.8]}
  82. self.Controller1 = ControllWidget.ControlFrame(config1)
  83. self.Controller2 = ControllWidget.ControlFrame(config2)
  84. self.JointContrallerWidget = \
  85. JointContrallerWidget.JointControlFrame(self.Controller1.robot_, self.Controller2.robot_)
  86. splitter_main = self.split_()
  87. self.setCentralWidget(splitter_main)
  88. self.gl.SetRobot1Instance(self.Controller1.robot_)
  89. self.gl.SetRobot2Instance(self.Controller2.robot_)
  90. self.timer_=QTimer()
  91. self.timer_.timeout.connect(self.Update)
  92. self.timer_.start(100)
  93. def LoadMap(self):
  94. self.gl = MapGLWidget() #将opengl例子嵌入GUI
  95. map=self.load_map("./map.json")
  96. for node in map['street_nodes'].items():
  97. [id,point]=node
  98. street_node=mp.StreetNode(id,point[0],point[1])
  99. self.djks_map_.AddVertex(street_node)
  100. self.gl.AddNode([id,"street_node",point])
  101. self.ui_nodes["street_nodes"].append(id)
  102. for node in map['space_nodes'].items():
  103. [id,point]=node
  104. [x,y,yaw]=point
  105. space_node=mp.SpaceNode(id,point[0],point[1],yaw)
  106. self.djks_map_.AddVertex(space_node)
  107. glNode=[id,"space_node",[x,y]]
  108. self.gl.AddNode(glNode)
  109. self.ui_nodes["space_nodes"].append(id)
  110. for road in map['roads'].items():
  111. self.gl.AddRoad(road)
  112. [_,points]=road
  113. for pt1 in points:
  114. for pt2 in points:
  115. if not pt1==pt2:
  116. self.djks_map_.AddEdge(pt1,pt2)
  117. def load_map(self,file):
  118. with open(file,'r',encoding='utf-8') as fp:
  119. map=json.load(fp)
  120. return map
  121. def Update(self):
  122. self.JointContrallerWidget.SetRobot1_BaTID(self.Controller1.begId_, self.Controller1.targetId_)
  123. self.JointContrallerWidget.SetRobot2_BaTID(self.Controller2.begId_, self.Controller2.targetId_)
  124. self.gl.update()
  125. #窗口基础属性
  126. def basic(self):
  127. #设置标题,大小,图标
  128. self.setWindowTitle("GT")
  129. self.resize(1100,650)
  130. self.setWindowIcon(QIcon("./image/Gt.png"))
  131. #居中显示
  132. screen = QDesktopWidget().geometry()
  133. self_size = self.geometry()
  134. self.move(int((screen.width() - self_size.width())/2),int((screen.height() - self_size.height())/2))
  135. def closeEvent(self, QCloseEvent):
  136. self.gl.close()
  137. #分割窗口
  138. def split_(self):
  139. splitter_main = QSplitter(Qt.Horizontal)
  140. splitter = QSplitter(Qt.Vertical)
  141. splitter.addWidget(self.count_frame_)
  142. splitter.addWidget(self.Controller1)
  143. splitter.addWidget(self.Controller2)
  144. splitter.addWidget(self.JointContrallerWidget)
  145. splitter.setStretchFactor(0,1)
  146. splitter.setStretchFactor(1,3)
  147. splitter.setStretchFactor(2,3)
  148. splitter.setStretchFactor(3,1)
  149. splitter_main.addWidget(splitter)
  150. splitter_main.addWidget(self.gl)
  151. splitter_main.setStretchFactor(0,1)
  152. splitter_main.setStretchFactor(2,4)
  153. return splitter_main
  154. if __name__ == "__main__":
  155. app = QApplication(sys.argv)
  156. win = MainWindow()
  157. win.show()
  158. sys.exit(app.exec_())
  159. #===============================================================================
  160. # Main
  161. #===============================================================================
  162. '''app = QApplication(sys.argv)
  163. mainWindow = MapGLWidget()
  164. mainWindow.show()
  165. mainWindow.raise_() # Need this at least on OS X, otherwise the window ends up in background
  166. sys.exit(app.exec_())'''
  167. #===============================================================================
  168. #
  169. # Local Variables:
  170. # mode: Python
  171. # indent-tabs-mode: nil
  172. # End:
  173. #
  174. #===============================================================================