test_viz_simple.py 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439
  1. import os
  2. import numpy as np
  3. import cv2 as cv
  4. from tests_common import NewOpenCVTests
  5. def generate_test_trajectory():
  6. result = []
  7. angle_i = np.arange(0, 271, 3)
  8. angle_j = np.arange(0, 1200, 10)
  9. for i, j in zip(angle_i, angle_j):
  10. x = 2 * np.cos(i * 3 * np.pi/180.0) * (1.0 + 0.5 * np.cos(1.2 + i * 1.2 * np.pi/180.0))
  11. y = 0.25 + i/270.0 + np.sin(j * np.pi/180.0) * 0.2 * np.sin(0.6 + j * 1.5 * np.pi/180.0)
  12. z = 2 * np.sin(i * 3 * np.pi/180.0) * (1.0 + 0.5 * np.cos(1.2 + i * np.pi/180.0))
  13. result.append(cv.viz.makeCameraPose((x, y, z), (0.0, 0, 0), (0.0, 1.0, 0.0)))
  14. x = np.zeros(shape=(len(result), 1, 16 ), dtype= np.float64)
  15. for idx, m in enumerate(result):
  16. x[idx, 0, :] = m.mat().reshape(16)
  17. return x, result
  18. def tutorial3(camera_pov, filename):
  19. myWindow = cv.viz_Viz3d("Coordinate Frame")
  20. myWindow.showWidget("axe",cv.viz_WCoordinateSystem())
  21. cam_origin = (3.0, 3.0, 3.0)
  22. cam_focal_point = (3.0,3.0,2.0)
  23. cam_y_dir = (-1.0,0.0,0.0)
  24. camera_pose = cv.viz.makeCameraPose(cam_origin, cam_focal_point, cam_y_dir)
  25. transform = cv.viz.makeTransformToGlobal((0.0,-1.0,0.0), (-1.0,0.0,0.0), (0.0,0.0,-1.0), cam_origin)
  26. dragon_cloud,_,_ = cv.viz.readCloud(filename)
  27. cloud_widget = cv.viz_WCloud(dragon_cloud, cv.viz_Color().green())
  28. cloud_pose = cv.viz_Affine3d()
  29. cloud_pose = cv.viz_Affine3d().rotate((0, np.pi / 2, 0)).translate((0, 0, 3))
  30. cloud_pose_global = transform.product(cloud_pose)
  31. myWindow.showWidget("CPW_FRUSTUM", cv.viz_WCameraPosition((0.889484, 0.523599)), camera_pose)
  32. if not camera_pov:
  33. myWindow.showWidget("CPW", cv.viz_WCameraPosition(0.5), camera_pose)
  34. myWindow.showWidget("dragon", cloud_widget, cloud_pose_global)
  35. if camera_pov:
  36. myWindow.setViewerPose(camera_pose)
  37. class viz_test(NewOpenCVTests):
  38. def setUp(self):
  39. super(viz_test, self).setUp()
  40. if not bool(os.environ.get('OPENCV_PYTEST_RUN_VIZ', False)):
  41. self.skipTest("Use OPENCV_PYTEST_RUN_VIZ=1 to enable VIZ UI tests")
  42. def test_viz_tutorial3_global_view(self):
  43. tutorial3(False, self.find_file("viz/dragon.ply"))
  44. def test_viz_tutorial3_camera_view(self):
  45. tutorial3(True, self.find_file("viz/dragon.ply"))
  46. def test_viz(self):
  47. dragon_cloud,_,_ = cv.viz.readCloud(self.find_file("viz/dragon.ply"))
  48. myWindow = cv.viz_Viz3d("abc")
  49. myWindow.showWidget("coo", cv.viz_WCoordinateSystem(1))
  50. myWindow.showWidget("cloud", cv.viz_WPaintedCloud(dragon_cloud))
  51. myWindow.spinOnce(500, True)
  52. def test_viz_show_simple_widgets(self):
  53. viz = cv.viz_Viz3d("show_simple_widgets")
  54. viz.setBackgroundMeshLab()
  55. viz.showWidget("coos", cv.viz_WCoordinateSystem())
  56. viz.showWidget("cube", cv.viz_WCube())
  57. viz.showWidget("cub0", cv.viz_WCube((-1.0, -1, -1), (-0.5, -0.5, -0.5), False, cv.viz_Color().indigo()))
  58. viz.showWidget("arro", cv.viz_WArrow((-0.5, -0.5, -0.5), (0.5, 0.5, 0.5), 0.009, cv.viz_Color().raspberry()))
  59. viz.showWidget("cir1", cv.viz_WCircle(0.5, 0.01, cv.viz_Color.bluberry()))
  60. viz.showWidget("cir2", cv.viz_WCircle(0.5, (0.5, 0.0, 0.0), (1.0, 0.0, 0.0), 0.01, cv.viz_Color().apricot()))
  61. viz.showWidget("cyl0", cv.viz_WCylinder((-0.5, 0.5, -0.5), (0.5, 0.5, -0.5), 0.125, 30, cv.viz_Color().brown()))
  62. viz.showWidget("con0", cv.viz_WCone(0.25, 0.125, 6, cv.viz_Color().azure()))
  63. viz.showWidget("con1", cv.viz_WCone(0.125, (0.5, -0.5, 0.5), (0.5, -1.0, 0.5), 6, cv.viz_Color().turquoise()))
  64. text2d = cv.viz_WText("Different simple widgets", (20, 20), 20, cv.viz_Color().green())
  65. viz.showWidget("text2d", text2d)
  66. text3d = cv.viz_WText3D("Simple 3D text", ( 0.5, 0.5, 0.5), 0.125, False, cv.viz_Color().green())
  67. viz.showWidget("text3d", text3d)
  68. viz.showWidget("plane1", cv.viz_WPlane((0.25, 0.75)))
  69. viz.showWidget("plane2", cv.viz_WPlane((0.5, -0.5, -0.5), (0.0, 1.0, 1.0), (1.0, 1.0, 0.0), (1.0, 0.5), cv.viz_Color().gold()))
  70. viz.showWidget("grid1", cv.viz_WGrid((7,7), (0.75,0.75), cv.viz_Color().gray()), cv.viz_Affine3d().translate((0.0, 0.0, -1.0)))
  71. viz.spinOnce(500, True)
  72. text2d.setText("Different simple widgets (updated)")
  73. text3d.setText("Updated text 3D")
  74. viz.spinOnce(500, True)
  75. def test_viz_show_overlay_image(self):
  76. lena = cv.imread(self.find_file("viz/lena.png"))
  77. gray = cv.cvtColor(lena, cv.COLOR_BGR2GRAY)
  78. rows = lena.shape[0]
  79. cols = lena.shape[1]
  80. half_lsize = (lena.shape[1] // 2, lena.shape[0] // 2)
  81. viz = cv.viz_Viz3d("show_overlay_image")
  82. viz.setBackgroundMeshLab();
  83. vsz = viz.getWindowSize()
  84. viz.showWidget("coos", cv.viz_WCoordinateSystem())
  85. viz.showWidget("cube", cv.viz_WCube())
  86. x = cv.viz_WImageOverlay(lena, (10, 10, half_lsize[1], half_lsize[0]))
  87. viz.showWidget("img1", x)
  88. viz.showWidget("img2", cv.viz_WImageOverlay(gray, (vsz[0] - 10 - cols // 2, 10, half_lsize[1], half_lsize[0])))
  89. viz.showWidget("img3", cv.viz_WImageOverlay(gray, (10, vsz[1] - 10 - rows // 2, half_lsize[1], half_lsize[0])))
  90. viz.showWidget("img5", cv.viz_WImageOverlay(lena, (vsz[0] - 10 - cols // 2, vsz[1] - 10 - rows // 2, half_lsize[1], half_lsize[0])))
  91. viz.showWidget("text2d", cv.viz_WText("Overlay images", (20, 20), 20, cv.viz_Color().green()))
  92. i = 0
  93. for num in range(50):
  94. i = i + 1
  95. a = i % 360
  96. pose = (3 * np.sin(a * np.pi/180), 2.1, 3 * np.cos(a * np.pi/180));
  97. viz.setViewerPose(cv.viz.makeCameraPose(pose , (0.0, 0.5, 0.0), (0.0, 0.1, 0.0)))
  98. img = lena * (np.sin(i * 10 * np.pi/180) * 0.5 + 0.5)
  99. x.setImage(img.astype(np.uint8))
  100. viz.spinOnce(100, True)
  101. viz.showWidget("text2d", cv.viz_WText("Overlay images (stopped)", (20, 20), 20, cv.viz_Color().green()))
  102. viz.spinOnce(500, True)
  103. def test_viz_show_image_3d(self):
  104. lena = cv.imread(self.find_file("viz/lena.png"))
  105. lena_gray = cv.cvtColor(lena, cv.COLOR_BGR2GRAY)
  106. viz = cv.viz_Viz3d("show_image_3d")
  107. viz.setBackgroundMeshLab()
  108. viz.showWidget("coos", cv.viz_WCoordinateSystem())
  109. viz.showWidget("cube", cv.viz_WCube());
  110. viz.showWidget("arr0", cv.viz_WArrow((0.5, 0.0, 0.0), (1.5, 0.0, 0.0), 0.009, cv.viz_Color().raspberry()))
  111. x = cv.viz_WImage3D(lena, (1.0, 1.0))
  112. viz.showWidget("img0", x, cv.viz_Affine3d((0.0, np.pi/2, 0.0), (.5, 0.0, 0.0)))
  113. viz.showWidget("arr1", cv.viz_WArrow((-0.5, -0.5, 0.0), (0.2, 0.2, 0.0), 0.009, cv.viz_Color().raspberry()))
  114. viz.showWidget("img1", cv.viz_WImage3D(lena_gray, (1.0, 1.0), (-0.5, -0.5, 0.0), (1.0, 1.0, 0.0), (0.0, 1.0, 0.0)))
  115. viz.showWidget("arr3", cv.viz_WArrow((-0.5, -0.5, -0.5), (0.5, 0.5, 0.5), 0.009, cv.viz_Color().raspberry()))
  116. viz.showWidget("text2d", cv.viz_WText("Images in 3D", (20, 20), 20, cv.viz_Color().green()))
  117. i = 0
  118. for num in range(50):
  119. img = lena * (np.sin(i*7.5*np.pi/180) * 0.5 + 0.5)
  120. x.setImage(img.astype(np.uint8))
  121. i = i + 1
  122. viz.spinOnce(100, True);
  123. viz.showWidget("text2d", cv.viz_WText("Images in 3D (stopped)", (20, 20), 20, cv.viz_Color().green()))
  124. viz.spinOnce(500, True)
  125. def test_viz_show_cloud_bluberry(self):
  126. dragon_cloud,_,_ = cv.viz.readCloud(self.find_file("viz/dragon.ply"))
  127. pose = cv.viz_Affine3d()
  128. pose = pose.rotate((0, 0.8, 0));
  129. viz = cv.viz_Viz3d("show_cloud_bluberry")
  130. viz.setBackgroundColor(cv.viz_Color().black())
  131. viz.showWidget("coosys", cv.viz_WCoordinateSystem())
  132. viz.showWidget("dragon", cv.viz_WCloud(dragon_cloud, cv.viz_Color().bluberry()), pose)
  133. viz.showWidget("text2d", cv.viz_WText("Bluberry cloud", (20, 20), 20, cv.viz_Color().green()))
  134. viz.spinOnce(500, True)
  135. def test_viz_show_cloud_random_color(self):
  136. dragon_cloud,_,_ = cv.viz.readCloud(self.find_file("viz/dragon.ply"))
  137. colors = np.random.randint(0, 255, size=(dragon_cloud.shape[0],dragon_cloud.shape[1],3), dtype=np.uint8)
  138. pose = cv.viz_Affine3d()
  139. pose = pose.rotate((0, 0.8, 0));
  140. viz = cv.viz_Viz3d("show_cloud_random_color")
  141. viz.setBackgroundMeshLab()
  142. viz.showWidget("coosys", cv.viz_WCoordinateSystem())
  143. viz.showWidget("dragon", cv.viz_WCloud(dragon_cloud, colors), pose)
  144. viz.showWidget("text2d", cv.viz_WText("Random color cloud", (20, 20), 20, cv.viz_Color().green()))
  145. viz.spinOnce(500, True)
  146. def test_viz_show_cloud_masked(self):
  147. dragon_cloud,_,_ = cv.viz.readCloud(self.find_file("viz/dragon.ply"))
  148. qnan = np.NAN
  149. for idx in range(dragon_cloud.shape[0]):
  150. if idx % 15 != 0:
  151. dragon_cloud[idx,:] = qnan
  152. pose = cv.viz_Affine3d()
  153. pose = pose.rotate((0, 0.8, 0))
  154. viz = cv.viz_Viz3d("show_cloud_masked");
  155. viz.showWidget("coosys", cv.viz_WCoordinateSystem())
  156. viz.showWidget("dragon", cv.viz_WCloud(dragon_cloud), pose)
  157. viz.showWidget("text2d", cv.viz_WText("Nan masked cloud", (20, 20), 20, cv.viz_Color().green()))
  158. viz.spinOnce(500, True)
  159. def test_viz_show_cloud_collection(self):
  160. cloud,_,_ = cv.viz.readCloud(self.find_file("viz/dragon.ply"))
  161. ccol = cv.viz_WCloudCollection()
  162. pose = cv.viz_Affine3d()
  163. pose1 = cv.viz_Affine3d().translate((0, 0, 0)).rotate((np.pi/2, 0, 0))
  164. ccol.addCloud(cloud, cv.viz_Color().white(), cv.viz_Affine3d().translate((0, 0, 0)).rotate((np.pi/2, 0, 0)))
  165. ccol.addCloud(cloud, cv.viz_Color().blue(), cv.viz_Affine3d().translate((1, 0, 0)))
  166. ccol.addCloud(cloud, cv.viz_Color().red(), cv.viz_Affine3d().translate((2, 0, 0)))
  167. ccol.finalize();
  168. viz = cv.viz_Viz3d("show_cloud_collection")
  169. viz.setBackgroundColor(cv.viz_Color().mlab())
  170. viz.showWidget("coosys", cv.viz_WCoordinateSystem());
  171. viz.showWidget("ccol", ccol);
  172. viz.showWidget("text2d", cv.viz_WText("Cloud collection", (20, 20), 20, cv.viz_Color(0, 255,0 )))
  173. viz.spinOnce(500, True)
  174. def test_viz_show_painted_clouds(self):
  175. cloud,_,_ = cv.viz.readCloud(self.find_file("viz/dragon.ply"))
  176. viz = cv.viz_Viz3d("show_painted_clouds")
  177. viz.setBackgroundMeshLab()
  178. viz.showWidget("coosys", cv.viz_WCoordinateSystem())
  179. pose1 = cv.viz_Affine3d((0.0, -np.pi/2, 0.0), (-1.5, 0.0, 0.0))
  180. pose2 = cv.viz_Affine3d((0.0, np.pi/2, 0.0), (1.5, 0.0, 0.0))
  181. viz.showWidget("cloud1", cv.viz_WPaintedCloud(cloud), pose1)
  182. viz.showWidget("cloud2", cv.viz_WPaintedCloud(cloud, (0.0, -0.75, -1.0), (0.0, 0.75, 0.0)), pose2);
  183. viz.showWidget("cloud3", cv.viz_WPaintedCloud(cloud, (0.0, 0.0, -1.0), (0.0, 0.0, 1.0), cv.viz_Color().blue(), cv.viz_Color().red()))
  184. viz.showWidget("arrow", cv.viz_WArrow((0.0, 1.0, -1.0), (0.0, 1.0, 1.0), 0.009, cv.viz_Color()))
  185. viz.showWidget("text2d", cv.viz_WText("Painted clouds", (20, 20), 20, cv.viz_Color(0, 255, 0)))
  186. viz.spinOnce(500, True)
  187. def test_viz_show_mesh(self):
  188. mesh = cv.viz.readMesh(self.find_file("viz/dragon.ply"))
  189. viz = cv.viz_Viz3d("show_mesh")
  190. viz.showWidget("coosys", cv.viz_WCoordinateSystem());
  191. viz.showWidget("mesh", cv.viz_WMesh(mesh), cv.viz_Affine3d().rotate((0, 0.8, 0)));
  192. viz.showWidget("text2d", cv.viz_WText("Just mesh", (20, 20), 20, cv.viz_Color().green()))
  193. viz.spinOnce(500, True)
  194. def test_viz_show_mesh_random_colors(self):
  195. mesh = cv.viz.readMesh(self.find_file("viz/dragon.ply"))
  196. mesh.colors = np.random.randint(0, 255, size=mesh.colors.shape, dtype=np.uint8)
  197. viz = cv.viz_Viz3d("show_mesh")
  198. viz.showWidget("coosys", cv.viz_WCoordinateSystem());
  199. viz.showWidget("mesh", cv.viz_WMesh(mesh), cv.viz_Affine3d().rotate((0, 0.8, 0)))
  200. viz.setRenderingProperty("mesh", cv.viz.SHADING, cv.viz.SHADING_PHONG)
  201. viz.showWidget("text2d", cv.viz_WText("Random color mesh", (20, 20), 20, cv.viz_Color().green()))
  202. viz.spinOnce(500, True)
  203. def test_viz_show_textured_mesh(self):
  204. lena = cv.imread(self.find_file("viz/lena.png"))
  205. angle = np.arange(0,64)
  206. points0 = np.vstack((np.zeros(shape=angle.shape, dtype=np.float32), np.cos(angle * np.pi /128), np.sin(angle* np.pi /128)))
  207. points1 = np.vstack((1.57 * np.ones(shape=angle.shape, dtype=np.float32),np.cos(angle* np.pi /128), np.sin(angle* np.pi /128)))
  208. tcoords0 = np.vstack((np.zeros(shape=angle.shape, dtype=np.float32), angle / 64))
  209. tcoords1 = np.vstack((np.ones(shape=angle.shape, dtype=np.float32), angle / 64))
  210. points = np.zeros(shape=(points0.shape[0], points0.shape[1] * 2 ),dtype=np.float32)
  211. tcoords = np.zeros(shape=(tcoords0.shape[0], tcoords0.shape[1] * 2),dtype=np.float32)
  212. tcoords[:,0::2] = tcoords0
  213. tcoords[:,1::2] = tcoords1
  214. points[:,0::2] = points0 * 0.75
  215. points[:,1::2] = points1 * 0.75
  216. polygons = np.zeros(shape=(4 * (points.shape[1]-2)+1),dtype=np.int32)
  217. for idx in range(points.shape[1] // 2 - 1):
  218. polygons[8 * idx: 8 * (idx + 1)] = [3, 2*idx, 2*idx+1, 2*idx+2, 3, 2*idx+1, 2*idx+2, 2*idx+3]
  219. mesh = cv.viz_Mesh()
  220. mesh.cloud = points.transpose().reshape(1,points.shape[1],points.shape[0])
  221. mesh.tcoords = tcoords.transpose().reshape(1,tcoords.shape[1],tcoords.shape[0])
  222. mesh.polygons = polygons.reshape(1, 4 * (points.shape[1]-2)+1)
  223. mesh.texture = lena
  224. viz = cv.viz_Viz3d("show_textured_mesh")
  225. viz.setBackgroundMeshLab();
  226. viz.showWidget("coosys", cv.viz_WCoordinateSystem());
  227. viz.showWidget("mesh", cv.viz_WMesh(mesh))
  228. viz.setRenderingProperty("mesh", cv.viz.SHADING, cv.viz.SHADING_PHONG)
  229. viz.showWidget("text2d", cv.viz_WText("Textured mesh", (20, 20), 20, cv.viz_Color().green()));
  230. viz.spinOnce(500, True)
  231. def test_viz_show_polyline(self):
  232. palette = [ cv.viz_Color().red(),
  233. cv.viz_Color().green(),
  234. cv.viz_Color().blue(),
  235. cv.viz_Color().gold(),
  236. cv.viz_Color().raspberry(),
  237. cv.viz_Color().bluberry(),
  238. cv.viz_Color().lime()]
  239. palette_size = len(palette)
  240. polyline = np.zeros(shape=(1, 32, 3), dtype=np.float32)
  241. colors = np.zeros(shape=(1, 32, 3), dtype=np.uint8)
  242. for i in range(polyline.shape[1]):
  243. polyline[0,i,0] = i / 16.0
  244. polyline[0,i,1] = np.cos(i * np.pi/6)
  245. polyline[0,i,2] = np.sin(i * np.pi/6)
  246. colors[0,i,0] = palette[i % palette_size].get_blue()
  247. colors[0,i,1] = palette[i % palette_size].get_green()
  248. colors[0,i,2] = palette[i % palette_size].get_red()
  249. viz = cv.viz_Viz3d("show_polyline")
  250. viz.showWidget("polyline", cv.viz_WPolyLine(polyline, colors))
  251. viz.showWidget("coosys", cv.viz_WCoordinateSystem())
  252. viz.showWidget("text2d", cv.viz_WText("Polyline", (20, 20), 20, cv.viz_Color().green()))
  253. viz.spinOnce(500, True)
  254. def test_viz_show_sampled_normals(self):
  255. mesh = cv.viz.readMesh(self.find_file("viz/dragon.ply"))
  256. mesh.normals = cv.viz.computeNormals(mesh)
  257. pose = cv.viz_Affine3d().rotate((0, 0.8, 0))
  258. viz = cv.viz_Viz3d("show_sampled_normals")
  259. viz.showWidget("mesh", cv.viz_WMesh(mesh), pose)
  260. viz.showWidget("normals", cv.viz_WCloudNormals(mesh.cloud, mesh.normals, 30, 0.1, cv.viz_Color().green()), pose)
  261. viz.setRenderingProperty("normals", cv.viz.LINE_WIDTH, 2.0)
  262. viz.showWidget("text2d", cv.viz_WText("Cloud or mesh normals", (20, 20), 20, cv.viz_Color().green()))
  263. viz.spinOnce(500, True);
  264. def test_viz_show_cloud_shaded_by_normals(self):
  265. mesh = cv.viz.readMesh(self.find_file("viz/dragon.ply"))
  266. mesh.normals = cv.viz.computeNormals(mesh)
  267. pose = cv.viz_Affine3d().rotate((0, 0.8, 0))
  268. cloud = cv.viz_WCloud(mesh.cloud, cv.viz_Color().white(), mesh.normals)
  269. cloud.setRenderingProperty(cv.viz.SHADING, cv.viz.SHADING_GOURAUD)
  270. viz = cv.viz_Viz3d("show_cloud_shaded_by_normals")
  271. viz.showWidget("cloud", cloud, pose)
  272. viz.showWidget("text2d", cv.viz_WText("Cloud shaded by normals", (20, 20), 20, cv.viz_Color().green()))
  273. viz.spinOnce(500, True)
  274. def test_viz_show_image_method(self):
  275. lena = cv.imread(self.find_file("viz/lena.png"))
  276. lena_gray = cv.cvtColor(lena, cv.COLOR_BGR2GRAY)
  277. viz = cv.viz_Viz3d("show_image_method")
  278. viz.showImage(lena)
  279. viz.spinOnce(1500, True)
  280. viz.showImage(lena, (lena.shape[1], lena.shape[0]))
  281. viz.spinOnce(1500, True)
  282. #cv.viz.imshow("show_image_method", lena_gray).spinOnce(500, True) BUG
  283. def test_viz_show_follower(self):
  284. viz = cv.viz_Viz3d("show_follower")
  285. viz.showWidget("coos", cv.viz_WCoordinateSystem())
  286. viz.showWidget("cube", cv.viz_WCube())
  287. text_3d = cv.viz_WText3D("Simple 3D follower", (-0.5, -0.5, 0.5), 0.125, True, cv.viz_Color().green())
  288. viz.showWidget("t3d_2", text_3d)
  289. viz.showWidget("text2d", cv.viz_WText("Follower: text always facing camera", (20, 20), 20, cv.viz_Color().green()))
  290. viz.setBackgroundMeshLab()
  291. viz.spinOnce(500, True)
  292. text_3d.setText("Updated follower 3D")
  293. viz.spinOnce(500, True)
  294. def test_viz_show_trajectory_reposition(self):
  295. mat, path = generate_test_trajectory()
  296. viz = cv.viz_Viz3d("show_trajectory_reposition_to_origin")
  297. viz.showWidget("coos", cv.viz_WCoordinateSystem())
  298. viz.showWidget("sub3", cv.viz_WTrajectory(mat[0: len(path) // 3,:,:], cv.viz.PyWTrajectory_BOTH, 0.2, cv.viz_Color().brown()), path[0].inv())
  299. viz.showWidget("text2d", cv.viz_WText("Trajectory resposition to origin", (20, 20), 20, cv.viz_Color().green()))
  300. viz.spinOnce(500, True)
  301. def test_viz_show_trajectories(self):
  302. mat, path = generate_test_trajectory()
  303. size =len(path)
  304. sub0 = np.copy(mat[0: size//10+1,::])
  305. sub1 = np.copy(mat[size//10: size//5+1,::])
  306. sub2 = np.copy(mat[size//5: 11*size//12,::])
  307. sub3 = np.copy(mat[11 * size // 12 : size,::])
  308. sub4 = np.copy(mat[3 * size//4: 33*size//40,::])
  309. sub5 = np.copy(mat[11*size//12: size,::])
  310. K = np.array([[1024.0, 0.0, 320.0], [0.0, 1024.0, 240.0], [0.0, 0.0, 1.0]],dtype=np.float64)
  311. viz = cv.viz_Viz3d("show_trajectories")
  312. viz.showWidget("coos", cv.viz_WCoordinateSystem())
  313. viz.showWidget("sub0", cv.viz_WTrajectorySpheres(sub0, 0.25, 0.07))
  314. viz.showWidget("sub1", cv.viz_WTrajectory(sub1, cv.viz.PyWTrajectory_PATH, 0.2, cv.viz_Color().brown()))
  315. viz.showWidget("sub2", cv.viz_WTrajectory(sub2, cv.viz.PyWTrajectory_FRAMES, 0.2))
  316. viz.showWidget("sub3", cv.viz_WTrajectory(sub3, cv.viz.PyWTrajectory_BOTH, 0.2, cv.viz_Color().green()))
  317. viz.showWidget("sub4", cv.viz_WTrajectoryFrustums(sub4, K, 0.3, cv.viz_Color().yellow()))
  318. viz.showWidget("sub5", cv.viz_WTrajectoryFrustums(sub5, (0.78, 0.78), 0.15, cv.viz_Color().magenta())) #BUG
  319. viz.showWidget("text2d", cv.viz_WText("Different kinds of supported trajectories", (20, 20), 20, cv.viz_Color().green()))
  320. i = 0
  321. for num in range(50):
  322. i = i - 1
  323. a = i % 360
  324. pose = (np.sin(a * np.pi/180)* 7.5, 0.7, np.cos(a * np.pi/180)* 7.5)
  325. viz.setViewerPose(cv.viz.makeCameraPose(pose , (0.0, 0.5, 0.0), (0.0, 0.1, 0.0)));
  326. viz.spinOnce(100, True)
  327. viz.resetCamera()
  328. viz.spinOnce(500, True)
  329. def test_viz_show_camera_positions(self):
  330. K = np.array([[1024.0, 0.0, 320.0], [0.0, 1024.0, 240.0], [0.0, 0.0, 1.0]],dtype=np.float64)
  331. lena = cv.imread(self.find_file("viz/lena.png"))
  332. lena_gray = cv.cvtColor(lena, cv.COLOR_BGR2GRAY)
  333. poses = []
  334. for i in range(2):
  335. pose = (5 * np.sin(3.14 + 2.7 + i*60 * np.pi/180), 2 - i*1.5, 5 * np.cos(3.14 + 2.7 + i*60 * np.pi/180))
  336. poses.append(cv.viz.makeCameraPose(pose, (0.0, 0.0, 0.0), (0.0, -0.1, 0.0)))
  337. viz = cv.viz_Viz3d("show_camera_positions")
  338. viz.showWidget("sphe", cv.viz_WSphere((0,0,0), 1.0, 10, cv.viz_Color().orange_red()))
  339. viz.showWidget("coos", cv.viz_WCoordinateSystem(1.5))
  340. viz.showWidget("pos1", cv.viz_WCameraPosition(0.75), poses[0])
  341. viz.showWidget("pos2", cv.viz_WCameraPosition((0.78, 0.78), lena, 2.2, cv.viz_Color().green()), poses[0])
  342. viz.showWidget("pos3", cv.viz_WCameraPosition(0.75), poses[0])
  343. viz.showWidget("pos4", cv.viz_WCameraPosition(K, lena_gray, 3, cv.viz_Color().indigo()), poses[1])
  344. viz.showWidget("text2d", cv.viz_WText("Camera positions with images", (20, 20), 20, cv.viz_Color().green()))
  345. viz.spinOnce(500, True)
  346. """
  347. TEST(Viz, show_widget_merger)
  348. {
  349. WWidgetMerger merger;
  350. merger.addWidget(WCube(Vec3d::all(0.0), Vec3d::all(1.0), true, Color::gold()));
  351. RNG& rng = theRNG();
  352. for(int i = 0; i < 77; ++i)
  353. {
  354. Vec3b c;
  355. rng.fill(c, RNG::NORMAL, Scalar::all(128), Scalar::all(48), true);
  356. merger.addWidget(WSphere(Vec3d(c)*(1.0/255.0), 7.0/255.0, 10, Color(c[2], c[1], c[0])));
  357. }
  358. merger.finalize();
  359. Viz3d viz("show_mesh_random_color");
  360. viz.showWidget("coo", WCoordinateSystem());
  361. viz.showWidget("merger", merger);
  362. viz.showWidget("text2d", WText("Widget merger", Point(20, 20), 20, Color::green()));
  363. viz.spinOnce(500, true);
  364. }
  365. """
  366. if __name__ == '__main__':
  367. NewOpenCVTests.bootstrap()