VtkImageData数据的创建与使用

该代码段展示了如何利用已知的图像维度、空间原点、间距和数据类型,从一个unsignedchar向量中创建并填充一个vtkImageData对象。首先,设置图像的范围、尺寸、原点和间距,然后指定数据类型和组件数,最后进行内存分配并使用memcpy复制数据到vtkImageData对象中。
摘要由CSDN通过智能技术生成

已知信息:图像的维度DimSpaceOrigin,数据类型等信息

目标:用数组作为初始值,创建一个vtkImageData对象。

数据值来源:vector<unsigned char> Data;//经过前期计算,已经有值

vtkImageData* GenerateVTKImageData()

{

    vtkInformation* pInfo = vtkInformation::New();

    vtkImageData* pImageData = vtkImageData::New();

    int extent[6] = { 0,Dim[0]- 1,0,Dim[1] - 1,0,Dim[2]-1 };

    pImageData->SetExtent(extent);

    pImageData->SetDimensions(Dim[0], Dim[1], Dim[2]);

    pImageData->SetOrigin(Origin[0], Origin[1], Origin[2]);

    pImageData->SetSpacing(Space[0], Space[1], Space[2]);

    pImageData->SetScalarType(VTK_UNSIGNED_CHAR, pInfo);//类型可修改

    pImageData->SetNumberOfScalarComponents(1, pInfo);//可修改,如234         pImageData->AllocateScalars(pInfo);

    memcpy(pImageData->GetScalarPointer(), &Data[0], Data.size() * sizeof(unsigned char));

    pInfo->Delete();

    return pImageData;

}

附:SliceImageDataPtr对象的创建

已知信息:vtkImageData类型的数据

目标:创建SliceImageDataPtr对象

SliceImageDataPtr img(new SliceImageData);

img->SetImageData(pImageData);

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值