fromcompas.geometryimportBoxfromcompas.geometryimportPolyhedronfromcompas.geometryimportSpherefromcompas_cgal.booleansimportboolean_union_mesh_meshfromcompas_cgal.meshingimportmesh_remeshfromcompas_viewerimportViewer# ==============================================================================# Make a box and a sphere# ==============================================================================box=Box(2)A=box.to_vertices_and_faces(triangulated=True)sphere=Sphere(1,point=[1,1,1])B=sphere.to_vertices_and_faces(u=64,v=64,triangulated=True)# ==============================================================================# Remesh the sphere# ==============================================================================B=mesh_remesh(B,0.3,50)# ==============================================================================# Compute the boolean mesh# ==============================================================================V,F=boolean_union_mesh_mesh(A,B)shape=Polyhedron(V.tolist(),F.tolist())# revise the Shape API# temp solution until viewer supports polyhedronsshape=shape.to_mesh()# ==============================================================================# Visualize# ==============================================================================viewer=Viewer()viewer.renderer.camera.target=[0,0,0]viewer.renderer.camera.position=[4,-6,3]viewer.scene.add(shape,lineswidth=1,show_points=False)viewer.show()