You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
208 lines
5.9 KiB
208 lines
5.9 KiB
/*=========================================================================
|
|
|
|
Program: Visualization Toolkit
|
|
Module: $RCSfile: vtkPostScriptWriter.cxx,v $
|
|
|
|
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
|
|
All rights reserved.
|
|
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even
|
|
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
PURPOSE. See the above copyright notice for more information.
|
|
|
|
=========================================================================*/
|
|
#include "vtkPostScriptWriter.h"
|
|
|
|
#include "vtkImageData.h"
|
|
#include "vtkObjectFactory.h"
|
|
#include "vtkPointData.h"
|
|
|
|
vtkCxxRevisionMacro(vtkPostScriptWriter, "$Revision: 1.20 $");
|
|
vtkStandardNewMacro(vtkPostScriptWriter);
|
|
|
|
#define VTK_MARGIN 0.95
|
|
|
|
void vtkPostScriptWriter::WriteFileTrailer(ofstream *file,
|
|
vtkImageData *vtkNotUsed(cache))
|
|
{
|
|
*file << "\ngrestore\nshowpage\n%%%%Trailer\n";
|
|
}
|
|
|
|
void vtkPostScriptWriter::WriteFileHeader(ofstream *file,
|
|
vtkImageData *cache)
|
|
{
|
|
int min1, max1, min2, max2, min3, max3;
|
|
int bpp;
|
|
int cols, rows, scols, srows;
|
|
float scale = 1;
|
|
int pagewid = (int) (8.5*72);
|
|
int pagehgt = 11*72;
|
|
|
|
// Find the length of the rows to write.
|
|
cache->GetWholeExtent(min1, max1, min2, max2, min3, max3);
|
|
bpp = cache->GetNumberOfScalarComponents();
|
|
|
|
cols = max1 - min1 + 1;
|
|
rows = max2 - min2 + 1;
|
|
|
|
float pixfac = 0.96; /* 1, approx. */
|
|
scols = (int)(cols * pixfac);
|
|
srows = (int)(rows * pixfac);
|
|
if ( scols > pagewid * VTK_MARGIN || srows > pagehgt * VTK_MARGIN )
|
|
{
|
|
if ( scols > pagewid * VTK_MARGIN )
|
|
{
|
|
scale = scale*(pagewid * VTK_MARGIN / scols);
|
|
scols = (int)(scale * cols * pixfac);
|
|
srows = (int)(scale * rows * pixfac);
|
|
}
|
|
if ( srows > pagehgt * VTK_MARGIN )
|
|
{
|
|
scale = scale * (pagehgt * VTK_MARGIN / srows);
|
|
scols = (int)(scale * cols * pixfac);
|
|
srows = (int)(scale * rows * pixfac);
|
|
}
|
|
}
|
|
float llx = ( pagewid - scols ) / 2;
|
|
float lly = ( pagehgt - srows ) / 2;
|
|
|
|
// spit out the PostScript header
|
|
*file << "%!PS-Adobe-2.0 EPSF-2.0\n";
|
|
*file << "%%Creator: Visualization Toolkit\n";
|
|
*file << "%%Title: " << this->InternalFileName << endl;
|
|
*file << "%%Pages: 1\n";
|
|
*file << "%%BoundingBox: " << (int) llx << " " << (int) lly
|
|
<< " " << (int) ( llx + scols + 0.5 ) << " " <<
|
|
(int) ( lly + srows + 0.5 ) << endl;
|
|
*file << "%%EndComments\n";
|
|
*file << "/readstring {\n";
|
|
*file << " currentfile exch readhexstring pop\n";
|
|
*file << "} bind def\n";
|
|
|
|
if ( bpp == 3)
|
|
{
|
|
*file << "/rpicstr " << cols << " string def\n";
|
|
*file << "/gpicstr " << cols << " string def\n";
|
|
*file << "/bpicstr " << cols << " string def\n";
|
|
}
|
|
else if (bpp == 1)
|
|
{
|
|
*file << "/picstr " << cols << " string def\n";
|
|
}
|
|
else
|
|
{
|
|
vtkWarningMacro( " vtkPostScriptWriter only supports 1 and 3 component images");
|
|
}
|
|
|
|
*file << "%%EndProlog\n";
|
|
*file << "%%Page: 1 1\n";
|
|
*file << "gsave\n";
|
|
*file << llx << " " << lly << " translate\n";
|
|
*file << scols << " " << srows << " scale\n";
|
|
*file << cols << " " << rows << " 8\n";
|
|
*file << "[ " << cols << " 0 0 " << -rows << " 0 " << rows << " ]\n";
|
|
if (bpp == 3)
|
|
{
|
|
*file << "{ rpicstr readstring }\n";
|
|
*file << "{ gpicstr readstring }\n";
|
|
*file << "{ bpicstr readstring }\n";
|
|
*file << "true 3\n";
|
|
*file << "colorimage\n";
|
|
}
|
|
else
|
|
{
|
|
*file << "{ picstr readstring }\n";
|
|
*file << "image\n";
|
|
}
|
|
}
|
|
|
|
|
|
void vtkPostScriptWriter::WriteFile(ofstream *file, vtkImageData *data,
|
|
int extent[6])
|
|
{
|
|
int idxC, idx0, idx1, idx2;
|
|
unsigned char *ptr;
|
|
unsigned long count = 0;
|
|
unsigned long target;
|
|
float progress = this->Progress;
|
|
float area;
|
|
int *wExtent;
|
|
static int itemsperline = 0;
|
|
char* hexits = (char *) "0123456789abcdef";
|
|
|
|
// Make sure we actually have data.
|
|
if ( !data->GetPointData()->GetScalars())
|
|
{
|
|
vtkErrorMacro(<< "Could not get data from input.");
|
|
return;
|
|
}
|
|
|
|
// take into consideration the scalar type
|
|
switch (data->GetScalarType())
|
|
{
|
|
case VTK_UNSIGNED_CHAR:
|
|
break;
|
|
default:
|
|
vtkErrorMacro("PostScriptWriter only accepts unsigned char scalars!");
|
|
return;
|
|
}
|
|
|
|
wExtent = this->GetInput()->GetWholeExtent();
|
|
area = ((extent[5] - extent[4] + 1)*(extent[3] - extent[2] + 1)*
|
|
(extent[1] - extent[0] + 1)) /
|
|
((wExtent[5] -wExtent[4] + 1)*(wExtent[3] -wExtent[2] + 1)*
|
|
(wExtent[1] -wExtent[0] + 1));
|
|
|
|
|
|
int numComponents = data->GetNumberOfScalarComponents();
|
|
// ignore alpha
|
|
int maxComponent = numComponents;
|
|
if (numComponents == 2)
|
|
{
|
|
maxComponent = 1;
|
|
}
|
|
if (numComponents == 4)
|
|
{
|
|
maxComponent = 3;
|
|
}
|
|
target = (unsigned long)((extent[5]-extent[4]+1)*
|
|
(extent[3]-extent[2]+1)/(50.0*area));
|
|
target++;
|
|
|
|
for (idx2 = extent[4]; idx2 <= extent[5]; ++idx2)
|
|
{
|
|
for (idx1 = extent[3]; idx1 >= extent[2]; idx1--)
|
|
{
|
|
if (!(count%target))
|
|
{
|
|
this->UpdateProgress(progress + count/(50.0*target));
|
|
}
|
|
count++;
|
|
// write out components one at a time because
|
|
for (idxC = 0; idxC < maxComponent; idxC++)
|
|
{
|
|
ptr = (unsigned char*)data->GetScalarPointer(extent[0],idx1, idx2);
|
|
ptr += idxC;
|
|
for ( idx0 = extent[0]; idx0 <= extent[1]; idx0++ )
|
|
{
|
|
if ( itemsperline == 30 )
|
|
{
|
|
*file << endl;
|
|
itemsperline = 0;
|
|
}
|
|
*file << hexits[*ptr >> 4] << hexits[*ptr & 15];
|
|
++itemsperline;
|
|
ptr += numComponents;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void vtkPostScriptWriter::PrintSelf(ostream& os, vtkIndent indent)
|
|
{
|
|
this->Superclass::PrintSelf(os,indent);
|
|
}
|
|
|