如何使用Python?VTK高亮顯示actor
前言:
VTK,(visualizationtoolkit)是一個開放資源的免費(fèi)軟件系統(tǒng),主要用于三維計算機(jī)圖形學(xué)、圖像處理和可視化。Vtk是在面向?qū)ο笤淼幕A(chǔ)上設(shè)計和實(shí)現(xiàn)的,它的內(nèi)核是用C++構(gòu)建的,包含有大約250,000行代碼,2000多個類,還包含有幾個轉(zhuǎn)換界面,因此也可以自由的通過Java,Tcl/Tk和Python各種語言使用vtk。
主要函數(shù)介紹:
NewPickedActor.GetProperty(): 通過該函數(shù),可以設(shè)置actor的性質(zhì),如顏色、表面樣式等。
vtk.vtkSphereSource(): 創(chuàng)建球體的函數(shù),文中通過一個for循環(huán)創(chuàng)建了10個球體。
vtk.vtkMinimalStandardRandomSequence(): VTK的隨機(jī)數(shù)生成器,用于代碼中的十個球體,隨機(jī)生成球體的大小和位置。
MouseInteractorHighLightActor: 定義actor操作方法,這個是一個鼠標(biāo)操作控件的控制方法。
leftButtonPressEvent(self, obj, event): 這是一個事件觸發(fā)函數(shù),當(dāng)鼠標(biāo)左鍵點(diǎn)擊對應(yīng)的actor時,會觸發(fā)函數(shù),對點(diǎn)的actor高亮顯示。
主要代碼如下:
#!/usr/bin/env python
# noinspection PyUnresolvedReferences
import vtk
colors = vtk.vtkNamedColors()
NUMBER_OF_SPHERES = 10
class MouseInteractorHighLightActor(vtk.vtkInteractorStyleTrackballCamera):
def __init__(self, parent=None):
self.AddObserver("LeftButtonPressEvent", self.leftButtonPressEvent)
self.LastPickedActor = None
self.LastPickedProperty = vtk.vtkProperty()
def leftButtonPressEvent(self, obj, event):
clickPos = self.GetInteractor().GetEventPosition()
picker = vtk.vtkPropPicker()
picker.Pick(clickPos[0], clickPos[1], 0, self.GetDefaultRenderer())
# 創(chuàng)建一個新的actor
self.NewPickedActor = picker.GetActor()
# If something was selected
if self.NewPickedActor:
# If we picked something before, reset its property
if self.LastPickedActor:
self.LastPickedActor.GetProperty().DeepCopy(self.LastPickedProperty)
# Save the property of the picked actor so that we can
# restore it next time
self.LastPickedProperty.DeepCopy(self.NewPickedActor.GetProperty())
# 高亮選中球體,并顯示邊緣
self.NewPickedActor.GetProperty().SetColor(colors.GetColor3d('Red'))
self.NewPickedActor.GetProperty().SetDiffuse(1.0)
self.NewPickedActor.GetProperty().SetSpecular(0.0)
self.NewPickedActor.GetProperty().EdgeVisibilityOn()
# 保存最后一個選中的actor
self.LastPickedActor = self.NewPickedActor
self.OnLeftButtonDown()
return
def main():
# 創(chuàng)建render和window
renderer = vtk.vtkRenderer()
renderer.SetBackground(colors.GetColor3d('SteelBlue'))
renwin = vtk.vtkRenderWindow()
renwin.AddRenderer(renderer)
renwin.SetSize(640, 480)
renwin.SetWindowName('HighlightPickedActor')
# 建立interactor(交互操作)
interactor = vtk.vtkRenderWindowInteractor()
interactor.SetRenderWindow(renwin)
# 交互操作方法
style = MouseInteractorHighLightActor()
style.SetDefaultRenderer(renderer)
interactor.SetInteractorStyle(style)
randomSequence = vtk.vtkMinimalStandardRandomSequence()
# randomSequence.SetSeed(1043618065)
# randomSequence.SetSeed(5170)
randomSequence.SetSeed(8775070)
# 添加球體
for i in range(NUMBER_OF_SPHERES):
source = vtk.vtkSphereSource()
# random position and radius
x = randomSequence.GetRangeValue(-5.0, 5.0)
randomSequence.Next()
y = randomSequence.GetRangeValue(-5.0, 5.0)
randomSequence.Next()
z = randomSequence.GetRangeValue(-5.0, 5.0)
randomSequence.Next()
radius = randomSequence.GetRangeValue(0.5, 1.0)
randomSequence.Next()
source.SetRadius(radius)
source.SetCenter(x, y, z)
source.SetPhiResolution(11)
source.SetThetaResolution(21)
mapper = vtk.vtkPolyDataMapper()
mapper.SetInputConnection(source.GetOutputPort())
actor = vtk.vtkActor()
actor.SetMapper(mapper)
r = randomSequence.GetRangeValue(0.4, 1.0)
randomSequence.Next()
g = randomSequence.GetRangeValue(0.4, 1.0)
randomSequence.Next()
b = randomSequence.GetRangeValue(0.4, 1.0)
randomSequence.Next()
actor.GetProperty().SetDiffuseColor(r, g, b)
actor.GetProperty().SetDiffuse(.8)
actor.GetProperty().SetSpecular(.5)
actor.GetProperty().SetSpecularColor(colors.GetColor3d('White'))
actor.GetProperty().SetSpecularPower(30.0)
renderer.AddActor(actor)
# 運(yùn)行
interactor.Initialize()
renwin.Render()
interactor.Start()
if __name__ == '__main__':
main()
顯示結(jié)果如下: 未選擇球體:

已選取球體后:

到此這篇關(guān)于如何使用Python VTK高亮顯示actor的文章就介紹到這了,更多相關(guān)Python VTK高亮顯示actor內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python3.7 使用pymssql往sqlserver插入數(shù)據(jù)的方法
這篇文章主要介紹了python3.7 使用pymssql往sqlserver插入數(shù)據(jù)的方法,代碼很簡單,感興趣的朋友跟隨小編一起看看吧2019-07-07
Python中Selenium模擬JQuery滑動解鎖實(shí)例
這篇文章主要介紹了Python中Selenium模擬JQuery滑動解鎖實(shí)例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
Python實(shí)現(xiàn)快速將pdf文件剪切成多個圖片
這篇文章主要為大家詳細(xì)介紹了如何使用Python實(shí)現(xiàn)快速將pdf文件剪切成多個圖片,文中的示例代碼講解詳細(xì),有需要的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01
python利用beautifulSoup實(shí)現(xiàn)爬蟲
這篇文章主要介紹了python利用beautifulSoup實(shí)現(xiàn)爬蟲,需要的朋友可以參考下2014-09-09
Python 獲取命令行參數(shù)內(nèi)容及參數(shù)個數(shù)的實(shí)例
今天小編就為大家分享一篇Python 獲取命令行參數(shù)內(nèi)容及參數(shù)個數(shù)的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12

