int
main(int argc, char * argv[])
{
if (argc < 3)
{
std::cerr << "Usage: " << std::endl;
std::cerr << argv[0] << " inputImageFile outputImageFile" << std::endl;
std::cerr << " [scalingFactor] [translationX translationY translationZ]"
<< std::endl;
std::cerr << " [rotationZinDegrees]" << std::endl;
return EXIT_FAILURE;
}
using PixelType = unsigned char;
constexpr unsigned int Dimension = 3;
auto reader = ReaderType::New();
auto writer = WriterType::New();
reader->SetFileName(argv[1]);
writer->SetFileName(argv[2]);
auto filter = FilterType::New();
try
{
reader->Update();
}
{
std::cerr << excp << std::endl;
return EXIT_FAILURE;
}
const ImageType::ConstPointer inputImage = reader->GetOutput();
ImageType::PointType origin = inputImage->GetOrigin();
ImageType::SpacingType spacing = inputImage->GetSpacing();
const ImageType::DirectionType direction = inputImage->GetDirection();
if (argc > 3)
{
const double scale = std::stod(argv[3]);
for (unsigned int i = 0; i < Dimension; ++i)
{
spacing[i] *= scale;
}
filter->SetOutputSpacing(spacing);
filter->ChangeSpacingOn();
}
if (argc > 6)
{
ImageType::PointType::VectorType translation;
translation[0] = std::stod(argv[4]);
translation[1] = std::stod(argv[5]);
translation[2] = std::stod(argv[6]);
origin += translation;
filter->SetOutputOrigin(origin);
filter->ChangeOriginOn();
}
if (argc > 7)
{
const double additionalAngle = std::stod(argv[7]);
const double angleInRadians = additionalAngle *
itk::Math::pi / 180.0;
const ImageType::DirectionType newDirection =
filter->SetOutputDirection(newDirection);
filter->ChangeDirectionOn();
}
filter->SetInput(reader->GetOutput());
writer->SetInput(filter->GetOutput());
try
{
writer->Update();
}
{
std::cerr << excp << std::endl;
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}
Standard exception handling object.
Data source that reads image data from a single file.
Writes image data to a single file.
Templated n-dimensional image class.
A templated class holding a unit quaternion.
MatrixType GetMatrix() const
void SetRotationAroundZ(ValueType angle)
static constexpr double pi