本文整理汇总了C++中VolumeCollection::GetDataType方法的典型用法代码示例。如果您正苦于以下问题:C++ VolumeCollection::GetDataType方法的具体用法?C++ VolumeCollection::GetDataType怎么用?C++ VolumeCollection::GetDataType使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类VolumeCollection
的用法示例。
在下文中一共展示了VolumeCollection::GetDataType方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: fnSave
//.........这里部分代码省略.........
world.Set( -1000, 0, 0 );
VolumeLocation loc2( vol->MakeVolumeLocationFromRAS( world.xyz() ) );
if ( vol->IsInBounds( loc2 ) ) {
stringstream ssError;
ssError << "IsInBounds failed. world " << world;
throw( runtime_error( ssError.str() ) );
}
dataTransform.SetMainTransform( 2, 0, 0, 0,
0, 2, 0, 0,
0, 0, 2, 0,
0, 0, 0, 1 );
vol->SetDataToWorldTransform( dataTransform.GetID() );
world.Set( 0, -1000, -254 );
VolumeLocation loc3( vol->MakeVolumeLocationFromRAS( world.xyz() ) );
if ( vol->IsInBounds( loc3 ) ) {
stringstream ssError;
vol->RASToMRIIndex( world.xyz(), index.xyz() );
ssError << "IsRASInMRIBounds failed. world " << world
<< " index " << index;
throw( runtime_error( ssError.str() ) );
}
{
// Create a new one from template.
VolumeCollection* vol2 = new VolumeCollection();
vol2->MakeUsingTemplate( vol->GetID(), -1 );
Assert( (vol->mVoxelSize[0] == vol2->mVoxelSize[0] &&
vol->mVoxelSize[1] == vol2->mVoxelSize[1] &&
vol->mVoxelSize[2] == vol2->mVoxelSize[2]),
"NewUsingTemplate failed, vol2 didn't match vol's voxelsize" );
Assert( (vol->GetDataType() == vol2->GetDataType()),
"NewUsingTemplate(-1) failed, vol2 didn't match vol's data type" );
delete vol2;
}
{
VolumeCollection* vol2 = new VolumeCollection();
vol2->MakeUsingTemplate( vol->GetID(), MRI_FLOAT );
Assert( (vol->mVoxelSize[0] == vol2->mVoxelSize[0] &&
vol->mVoxelSize[1] == vol2->mVoxelSize[1] &&
vol->mVoxelSize[2] == vol2->mVoxelSize[2]),
"NewUsingTemplate failed, vol2 didn't match vol's voxelsize" );
Assert( (MRI_FLOAT == vol2->GetDataType()),
"NewUsingTemplate(float) failed, vol2 wasn't a float" );
int idx[3] = { 0, 0, 0 };
VolumeLocation loc( vol2->MakeVolumeLocationFromIndex( idx ) );
vol2->SetMRIValue( loc, 0.6789 );
float value = vol2->GetMRINearestValue(loc);
stringstream ssError;
ssError << "NewUsingTemplate(float) failed value comparison, "
<< "was expecting 0.6789 but got " << value;
Assert( (fabs(0.6789 - value) < 0.00001), ssError.str() );
delete vol2;
}
{
VolumeCollection* vol2 = NULL;
try {
vol2 = new VolumeCollection();
vol2->MakeUsingTemplate( vol->GetID(), 10000 );
throw runtime_error( "MakeUsingTemplate(10000) didn't throw an error");