Mit der jadice document platform un und dem Zusatzmodul TIFFConverter ist es möglich jedes geladene Jadice-Dokument (Instanzen, welche das Interface com.levigo.jadice.document.Document
implementieren) in ein TIFF Dokument zu schreiben.
Das folgende Code-Fragment demonstriert die Verwendung des TIFFConverter. Es wurde als Task]]
Implementiert um über einen {{com.levigo.util.concurrent.tasks.TaskService
ausgeführt zu werden.
Codeblock | ||||||
---|---|---|---|---|---|---|
| ||||||
import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import com.levigo.jadice.document.Document; import com.levigo.jadice.tiffconverter.TiffConvertConfiguration; import com.levigo.jadice.tiffconverter.TiffConvertRenderSettings.Compression; import com.levigo.jadice.tiffconverter.TiffConverter; import com.levigo.util.concurrent.tasks.Task; /** * Convert a given {@link Document} to a TIFF file. */ public class ConvertDocumentTask implements Task<File> { static { // Due to a bug to the jadice document platform versions up to 5.1.0.3 (will be fixed with // 5.1.0.4) this line has to be called to ensure proper initialization. This line must be // removed after upgrading to a release later than 5.1.0.3 com.levigo.jadice.document.internal.codec.tiff.TagGroup.values(); } private final Document document; private final File targetFile; public ConvertDocumentTask(Document document, File targetFile) { super(); if (document == null) throw new IllegalArgumentException("document must not be null"); this.document = document; if (targetFile == null) { try { targetFile = File.createTempFile("jadice-documentplatform-tiffconverter-", ".tif"); } catch (IOException e) { throw new RuntimeException("Failed to generate temporary file. Specify the output file explicitly.", e); } } this.targetFile = targetFile; } @Override public File call() throws Exception { FileOutputStream out = new FileOutputStream(targetFile); TiffConvertConfiguration convertConfiguration = new TiffConvertConfiguration(); // compression AUTO means that the tiff converter will use the most appropriate compression // method. That is CCITT for B/W and JPEG for color. convertConfiguration.setCompression(Compression.AUTO); TiffConverter converter = new TiffConverter(convertConfiguration); // the conversion must be surrounded by at least a read lock, to avoid that concurrent // modifications cause the conversion to fail. document.getPages().getReadWriteLock().readLock().lock(); try { converter.convertToTiff(document, out, false); } finally { document.getPages().getReadWriteLock().readLock().unlock(); } out.flush(); out.close(); return targetFile; } } |