網站首頁 編程語言 正文
主要函數介紹:
vtk.vtkPoints()?在VTK中用于定義點的類,使用points.InsertPoint(index, x, y, z)?即可插入點集。函數中,第一個參數是點的序號,后面是三個參數是點的坐標。
vtk.vtkLineSource()?在VTK中定義直線的類,通過SetPoints(points),輸入直線經過的點。
vtk.vtkParametricSpline()?在VTK中定義曲線的類,通過SetPoints(points),輸入曲線經過的點。
vtk.vtkParametricFunctionSource()?曲線插值擬合函數,可以將輸入的點集擬合成一條曲線。有很多生成方法。我們可以簡單的看一下VTK官方文檔介紹
S\CALAR_NONE - Scalars are not generated (default).
SCALAR_U - The scalar is set to the u-value.
SCALAR_V - The scalar is set to the v-value.
SCALAR_U0 - The scalar is set to 1 if u = (u_max - u_min)/2 = u_avg, 0 otherwise.
SCALAR_V0 - The scalar is set to 1 if v = (v_max - v_min)/2 = v_avg, 0 otherwise.
SCALAR_U0V0 - The scalar is set to 1 if u == u_avg, 2 if v == v_avg, 3 if u = u_avg && v = v_avg, 0 otherwise.
SCALAR_MODULUS - The scalar is set to (sqrt(uu+vv)), this is measured relative to (u_avg,v_avg).
SCALAR_PHASE - The scalar is set to (atan2(v,u)) (in degrees, 0 to 360), this is measured relative to (u_avg,v_avg).
SCALAR_QUADRANT - The scalar is set to 1, 2, 3 or 4. depending upon the quadrant of the point (u,v).
SCALAR_X - The scalar is set to the x-value.
SCALAR_Y - The scalar is set to the y-value.
SCALAR_Z - The scalar is set to the z-value.
SCALAR_DISTANCE - The scalar is set to (sqrt(xx+yy+z*z)). I.e. distance from the origin.
SCALAR_USER_DEFINED - The scalar is set to the value returned from EvaluateScalar().
actor.GetProperty().SetColor() 線條顏色配置
actor.GetProperty().SetLineWidth() 線條寬度配置
擬合曲線代碼:
import vtk
points = vtk.vtkPoints() # 定義一個點工具
points.InsertPoint(0, 329, 338, 45) # 使用InsertPoint可以插入點
# 注意:points.InsertPoint(a, b, c, d)
# 其中a表示點的序號,(b,c,d)表示點的三維坐標
points.InsertPoint(1, 328, 319, 46)
points.InsertPoint(2, 300, 329, 96)
# 定義曲線工具
# 將前面的幾個點插值擬合成一條曲線
spline = vtk.vtkParametricSpline()
spline.SetPoints(points)
splineSource = vtk.vtkParametricFunctionSource()
splineSource.SetParametricFunction(spline)
splineSource.Update()
splineMapper = vtk.vtkPolyDataMapper()
splineMapper.SetInputConnection(splineSource.GetOutputPort())
splineActor = vtk.vtkActor()
splineActor.SetMapper(splineMapper)
# 設置線條顏色
splineActor.GetProperty().SetColor(0.3800, 0.7000, 0.1600)
# 設置線條寬度
splineActor.GetProperty().SetLineWidth(5)
ren1 = vtk.vtkRenderer()
renWin = vtk.vtkRenderWindow()
renWin.AddRenderer(ren1)
iren = vtk.vtkRenderWindowInteractor()
iren.SetRenderWindow(renWin)
ren1.AddActor(splineActor)
ren1.SetBackground(1, 1, 1)
renWin.SetSize(250, 250)
renWin.Render()
iren.Start()
繪制直線代碼
import vtk
points = vtk.vtkPoints() # 定義一個點工具
points.InsertPoint(0, 329, 338, 45) # 使用InsertPoint可以插入點
# 注意:points.InsertPoint(a, b, c, d)
# 其中a表示點的序號,(b,c,d)表示點的三維坐標
points.InsertPoint(1, 328, 319, 46)
points.InsertPoint(2, 300, 329, 96)
# 定義直線工具
lineSource = vtk.vtkLineSource()
lineSource.SetPoints(points)
lineSource.Update()
lineMapper = vtk.vtkPolyDataMapper()
lineMapper.SetInputConnection(lineSource.GetOutputPort())
splineActor = vtk.vtkActor()
splineActor.SetMapper(lineMapper)
# 設置線條顏色
splineActor.GetProperty().SetColor(0.3800, 0.7000, 0.1600)
# 設置線條寬度
splineActor.GetProperty().SetLineWidth(5)
ren1 = vtk.vtkRenderer()
renWin = vtk.vtkRenderWindow()
renWin.AddRenderer(ren1)
iren = vtk.vtkRenderWindowInteractor()
iren.SetRenderWindow(renWin)
ren1.AddActor(splineActor)
ren1.SetBackground(1, 1, 1)
renWin.SetSize(250, 250)
renWin.Render()
iren.Start()
原文鏈接:https://juejin.cn/post/7028480115742867470
相關推薦
- 2023-04-20 navicat 連接 mongodb 報錯[13][Unauthorized] command li
- 2022-12-12 用C語言如何打印一個等腰三角形_C 語言
- 2022-02-04 防止點擊量頁面刷新增加的簡單處理方法
- 2022-10-02 react如何獲取state的值并更新使用_React
- 2022-05-12 Natapp(Ngrok) Windows下注冊為服務,開機啟動&后臺運行
- 2022-04-08 從頭學習C語言之switch語句和分支嵌套_C 語言
- 2022-09-19 Redis緩存穿透/擊穿工具類的封裝_Redis
- 2022-09-14 Go語言中序列化與反序列化示例詳解_Golang
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支