File: clsurf_1.py

package info (click to toggle)
opencamlib 2023.01.11-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 29,800 kB
  • sloc: cpp: 8,722; python: 5,530; sh: 604; javascript: 310; makefile: 209
file content (87 lines) | stat: -rw-r--r-- 2,442 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
from opencamlib import ocl, camvtk

def drawVertex(myscreen, p, vertexColor, rad=0.1):
    myscreen.addActor( camvtk.Sphere( center=(p.x,p.y,p.z), radius=rad, color=vertexColor ) )

def drawEdge(myscreen, e, edgeColor=camvtk.yellow):
    p1 = e[0]
    p2 = e[1]
    myscreen.addActor( camvtk.Line( p1=( p1.x,p1.y,p1.z), p2=(p2.x,p2.y,p2.z), color=edgeColor ) )

#def drawFarCircle(myscreen, r, circleColor):
#    myscreen.addActor( camvtk.Circle( center=(0,0,0), radius=r, color=circleColor ) )

def drawDiagram( myscreen, diag ):
    #drawFarCircle(myscreen, vd.getFarRadius(), camvtk.pink)
    for v in diag.getVertices():
        drawVertex(myscreen, v, camvtk.green)
    edges = diag.getEdges()
    for e in edges:
        drawEdge(myscreen,e, camvtk.cyan)

def writeFrame( w2if, lwr, n ):
    w2if.Modified() 
    lwr.SetFileName("frames/vd500_zoomout"+ ('%05d' % n)+".png")
    lwr.Write()
    
if __name__ == "__main__":  
    print(ocl.version())
    myscreen = camvtk.VTKScreen()
    
    
    camvtk.drawOCLtext(myscreen)
    
    #w2if = vtk.vtkWindowToImageFilter()
    #w2if.SetInput(myscreen.renWin)
    #lwr = vtk.vtkPNGWriter()
    #lwr.SetInput( w2if.GetOutput() )
    #w2if.Modified()
    #lwr.SetFileName("tux1.png")

# SURFACE
    
    #stl = camvtk.STLSurf("../../stl/Cylinder_1.stl")
    #stl = camvtk.STLSurf("../../stl/gnu_tux_mod.stl")
    stl = camvtk.STLSurf("../../stl/demo.stl")
    myscreen.addActor(stl)
    stl.SetWireframe()
    stl.SetColor((0.5,0.5,0.5))
    
    polydata = stl.src.GetOutput()
    s = ocl.STLSurf()
    camvtk.vtkPolyData2OCLSTL(polydata, s)
    print("STL surface read,", s.size(), "triangles")
    
    
    far = 20
    # far = 0.000002 generator 52 face_count crash
    # far = 0.000010 crashes at n=192
    
    camPos = 2* far
    myscreen.camera.SetPosition(camPos/1000, camPos/1000, camPos) 
    myscreen.camera.SetClippingRange(-2*camPos,2*camPos)
    myscreen.camera.SetFocalPoint(0.051, 0, 0)
    
    cls = ocl.CutterLocationSurface(10)
    
    cutter = ocl.BallCutter(2,10)
    cls.setCutter(cutter)
    cls.setSampling(1)
    cls.setMinSampling(0.1)
    cls.setSTL(s)
    
    drawDiagram(myscreen, cls)
    #vd = ocl.VoronoiDiagram(far,1200)
    
    #vod = VD(myscreen,vd,scale)
    #vod.setAll(vd)
    #drawFarCircle(myscreen, scale*vd.getFarRadius(), camvtk.orange)
    

        
    print("PYTHON All DONE.")


    
    myscreen.render()    
    myscreen.iren.Start()