This is a C++ example on how to use FileDerivation
using System;
public class ReformatFile
{
public static int Main(string[] args)
{
string THERALYS_ORG_ROOT = "1.3.6.1.4.17434";
string filename = args[0];
string outfilename = args[1];
Reader reader = new Reader();
reader.SetFileName( filename );
if( !reader.Read() )
{
System.Console.WriteLine( "Could not read: " + filename );
return 1;
}
UIDGenerator uid = new UIDGenerator();
FileDerivation fd = new FileDerivation();
string ReferencedSOPClassUID = "1.2.840.10008.5.1.4.1.1.7";
fd.AddReference( ReferencedSOPClassUID, uid.Generate() );
fd.AddReference( ReferencedSOPClassUID, uid.Generate() );
fd.SetPurposeOfReferenceCodeSequenceCodeValue( 121322 );
fd.SetDerivationCodeSequenceCodeValue( 113072 );
fd.SetFile( reader.GetFile() );
if( !fd.Derive() )
{
return 1;
}
fmi.Remove(
new gdcm.
Tag(0x0002,0x0013) );
fmi.Remove(
new gdcm.
Tag(0x0002,0x0016) );
Writer writer = new Writer();
writer.SetFileName( outfilename );
writer.SetFile( fd.GetFile() );
if( !writer.Write() )
{
System.Console.WriteLine( "Could not write: " + outfilename );
return 1;
}
return 0;
}
}