VTK学习笔记(六)ImageReslice

** Code **

#include <vtkActor.h>
#include <vtkImageData.h>
#include <vtkImageReslice.h>
#include <vtkIntArray.h>
#include <vtkNew.h>
#include <vtkProperty2D.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>

int main(int, char*[])
{
  vtkNew<vtkImageData> image;
  image->SetExtent(0, 9, 0, 9, 0, 0);
  image->AllocateScalars(VTK_INT, 1);

  int* pixel = static_cast<int*>(image->GetScalarPointer(0, 9, 0));
  std::cout << "pixel: " << *pixel << std::endl;

  vtkNew<vtkImageReslice> reslice;
  reslice->SetOutputExtent(0, 9, 0, 100, 0, 0);
  reslice->SetInputData(image);
  reslice->Update();

  int* pixel2 =
      static_cast<int*>(reslice->GetOutput()->GetScalarPointer(0, 11, 0));
  std::cout << "pixel2: " << *pixel2 << std::endl;

  return EXIT_SUCCESS;
}

CMakeLists.txt

cmake_minimum_required(VERSION 3.3 FATAL_ERROR)

project(ImageReslice)

find_package(VTK COMPONENTS 
  vtkCommonCore
  vtkCommonDataModel
  vtkImagingCore
  vtkInteractionStyle
  vtkRenderingContextOpenGL2
  vtkRenderingCore
  vtkRenderingFreeType
  vtkRenderingGL2PSOpenGL2
  vtkRenderingOpenGL2
  QUIET
)

if (NOT VTK_FOUND)
  message("Skipping ImageReslice: ${VTK_NOT_FOUND_MESSAGE}")
  return ()
endif()
message (STATUS "VTK_VERSION: ${VTK_VERSION}")
if (VTK_VERSION VERSION_LESS "8.90.0")
  # old system
  include(${VTK_USE_FILE})
  add_executable(ImageReslice MACOSX_BUNDLE ImageReslice.cxx )
  target_link_libraries(ImageReslice PRIVATE ${VTK_LIBRARIES})
else ()
  # include all components
  add_executable(ImageReslice MACOSX_BUNDLE ImageReslice.cxx )
  target_link_libraries(ImageReslice PRIVATE ${VTK_LIBRARIES})
  # vtk_module_autoinit is needed
  vtk_module_autoinit(
    TARGETS ImageReslice
    MODULES ${VTK_LIBRARIES}
    )
endif ()

参考:vtk-examples/ImageReslice

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

落花逐流水

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值