Converts one or several postscript file(s) to other formats using ghostscript
ps2raster psfile(s) [ -A[u|-] ] [ -Cgs_option ] [ -Doutdir ] [ -Eresolution ] [ -Gghost_path ] [ -Llistfile ] [ -P ] [ -Q[g|t][1|2|4] ] [ -S ] [ -Tb|e|f|j|g|G|m|t ] [ -V ] [ -W[+g][+tdocname][+nlayername][+aaltmode[alt]][+lminLOD/maxLOD][+fminfade/maxfade][+uURL] ]
ps2raster converts one or more PostScript files to other formats (BMP, EPS, JPEG, PDF, PNG, PPM, TIFF) using GhostScript. Input file names are read from the command line or from a file that lists them. The size of the resulting images is determined by the BoundingBox (or HiResBoundingBox, if present). As an option, a tight (HiRes)BoundingBox may be computed first. As another option, it can compute ESRI type world files used to reference, for instance, tif files and make them be recognized as geotiff.
psfiles
Names of PostScript files to be converted. The output files will have the same name (unless -F is used) but with the conventional extension name associated to the raster format (e.g., .jpg for the jpeg format). Use -D to redirect the output to a different directory.
-A
Adjust the BoundingBox and HiResBoundingBox to the minimum required by the image content. Append u to first remove any GMT-produced time-stamps. Use -A- to override any automatic setting of -A by -W.
-C
Specify a single, custom option that will be passed on to GhostScript as is. Repeat to add several options [none].
-D
Sets an alternative output directory (which must exist) [Default is the same directory as the PS files]. Use -D. to place the output in the current directory instead.
-E
Set raster resolution in dpi [default = 720 for PDF, 300 for others].
-F
Force the output file name. By default output names are constructed using the input names as base, which are appended with an appropriate extension. Use this option to provide a different name, but without extension. Extension is still determined automatically.
-G
Full path to your GhostScript executable. NOTE: For Unix systems this is generally not necessary. Under Windows, ghostscript path is now fetch from the registry. If this fails you can still add the GS path to system's path or give the full path here. (e.g., -G c:\programs\gs\gs9.02\bin\gswin32c). WARNING: because of the poor decision of embedding the bits on the gs exe name we cannot satisfy both the 32 and 64 bits ghostscript executable names. So in case of 'get from registry' failure the default name (when no -G is used) is the one of the 64 bits version, or gswin32c
-L
The listfile is an ASCII file with the names of the PostScript files to be converted.
-N
This option is obsolete. Use -S to print the GhostScript command, if applicable. Use -Te to save the intermediate EPS file.
-P
Force Portrait mode. All Landscape mode plots will be rotated back so that they show unrotated in Portrait mode. This is practical when converting to image formats or preparing EPS or PDF plots for inclusion in documents.
-Q
Set the anti-aliasing options for graphics or text. Append the size of the subsample box (1, 2, or 4) [4]. Default is no anti-aliasing (same as bits = 1).
-S
Print to standard output the GhostScript command after it has been executed.
-T
Sets the output format, where b means BMP, e means EPS, f means PDF, j means JPEG, g means PNG, G means transparent PNG (untouched regions are transparent), m means PPM, and t means TIFF [default is JPEG]. For bjgt you can append - to get a grayscale image only. The EPS format can be combined with any of the other formats. For example, -Tef creates both an EPS and a PDF file.
-V
Selects verbose mode, which will send progress reports to stderr [Default runs "silently"].
-W
Write a ESRI type world file suitable to make (e.g) .tif files be recognized as geotiff by softwares that know how to do it. Be aware, however, that different results are obtained depending on the image contents and if the -B option has been used or not. The trouble with the -B option is that it creates a frame and very likely its annotations. That introduces pixels outside the map data extent, and therefore the map extents estimation will be wrong. To avoid this problem use --BASEMAP_TYPE=inside option which plots all annotations and ticks inside the image and therefore does not compromise the coordinate computations. Pay attention also to the cases when the plot has any of the sides with whites only because than the algorithm will fail miserably as those whites will be eaten by the GhostScript. In that case you really must use -B or use a slightly off-white color.
Together with -V it prints on screen the gdal_translate (gdal_translate is a command line tool from the GDAL package) command that reads the raster + world file and creates a true geotiff file. Use -W+g to do a system call to gdal_translate and create a geoTIFF image right away. The output file will have a .tiff extension.
The world file naming follows the convention of jamming a 'w' in the file extension. So, if output is tif -Tt the world file is a .tfw, for jpeg we have a .jgw and so on. This option automatically sets -A -P.
Use -W+k to create a minimalist KML file that allows loading the image in GoogleEarth. Note that for this option the image must be in geographical coordinates. If not, a warning is issued but the KML file is created anyway. Several modifier options are available to customize the KML file in the form of +opt strings. Append +ttitle to set the document title [GMT KML Document], +nlayername to set the layer name, and +a/altmode[altitude] to select one of 5 altitude modes recognized by Google Earth that determines the altitude (in m) of the image: G clamped to the ground, g append altitude relative to ground, a append absolute altitude, s append altitude relative to seafloor, and S clamp it to the seafloor. Control visibility of the layer with the +lminLOD/maxLOD and +fminfade/maxfade options. FInally, if you plan to leave the image itself on a server and only distribute the KML, use +uURL to prepend the URL to the image reference. See the KML documentation for further explanation (http://code.google.com/apis/kml/documentation/).
Further notes on the creation of georeferenced rasters. ps2raster can create a georeferenced raster image with a world file OR uses GDAL to convert the GMT PostScript file to geotiff. GDAL uses Proj.4 for it's projection library. To provide with the information it needs to do the georeferencing, GMT 4.5 embeds a comment near the start of the PostScript file defining the projection using Proj.4 syntax. Users with pre-GMT v4.5 PostScript files, or even non-GMT ps files, can provide the information ps2raster requires by manually editing a line into the PostScript file, prefixed with %%PROJ.
For example the command pscoast -JM0/12c -R-10/-4/37/43 -W1 -Di -Bg30m --BASEMAP_TYPE=inside > cara.ps
adds this comment line
%%PROJ: merc -10.0 -4.0 37.0 43.0 -1113194.908 -445277.963 4413389.889 5282821.824 +proj=merc +lon_0=0 +k=-1 +x_0=0 +y_0=0 +a=6378137.0 +b=6356752.314245
where 'merc' is the keyword for the coordinate conversion; the 2 to 5th elements contain the map limits, 6 to 9th the map limits in projected coordinates and the rest of the line has the regular proj4 string for this projection.
The conversion to raster images (BMP, JPEG, PNG, PPM or TIFF) inherently results in loss of details that are available in the original PostScript file. Choose a resolution that is large enough for the application that the image will be used for. For web pages, smaller dpi values suffice, for Word documents and PowerPoint presentations a higher dpi value is recommended. ps2raster uses the loss-less Flate compression technique when creating JPEG, PNG and TIFF images.
EPS is a vector, not a raster format. Therefore, the -E option has no effect on the creation of EPS files. Using the option -Te will remove PageSize commands from the PostScript file and will adjust the BoundingBox when the -A option is used. Note the original and required BoundingBox is limited to integer points, hence Adobe added the optional HiResBoundingBox to add more precision in sizing. The -A option calculates both and writes both to the EPS file used in the rasterization (and output if -Te is set).
Although PDF is also a vector format, the -E option has an effect on the resolution of pattern fills and fonts that are stored as bitmaps in the document. ps2raster therefore uses a larger default resolution when creating PDF files. In order to obtain high-quality PDF files, the /prepress options are in effect, allowing only loss-less Flate compression of raster images embedded in the PostScript file.
Although ps2raster was developed as part of the GMT, it can be used to convert PostScript files created by nearly any graphics program. However, -Au is GMT-specific.
See Appendix C of the GMT Technical Reference and Cookbook for more information on how ps2raster is used to produce graphics that can be inserted into other documents (articles, presentations, posters, etc.).
To convert the file psfile.ps to PNG using a tight BoundingBox and rotating it back to normal orientation in case it was in Landscape mode:
ps2raster psfile.ps -A -P -Tg
To create a simple linear map with pscoast and convert it to tif with a .tfw the tight BoundingBox computation.
pscoast -JX12cd -R-10/-4/37/43 -W1 -Di -Bg30m -P -G200 --BASEMAP_TYPE=inside > cara.ps
ps2raster cara -Tt -W
To create a Mercator version of the above example and use GDAL to produce a true geotiff file.
pscoast -JM0/12c -R-10/-4/37/43 -W1 -Di -Bg30m -P -G200 --BASEMAP_TYPE=inside > cara.ps
gdalwarp -s_srs +proj=merc cara.tif carageo.tiff
To create a Polar Stereographic geotiff file of Patagonia
pscoast -JS-55/-60/15c -R-77/-55/-57.5/-48r -Di -Gred -P -Bg2 --BASEMAP_TYPE=inside > patagonia.ps
ps2raster patagonia.ps -Tt -W+g -V
To create a simple KMZ file for use in Google Earth, try
grdimage lonlatgrid.nc -Jx1 -Ccolors.cpt -P -B0g2 --BASEMAP_TYPE=inside > tile.ps
ps2raster tile.ps -Tg -W+k+t"my title"+l256/-1 -V
(These commands assume that GhostScript can be found in your system's path.)
GMT programs can produce binary PostScript image data and this is determined by the default setting PS_IMAGE_FORMAT. Because ps2raster needs to process the input files on a line-by-line basis you need to make sure the image format is set to ascii and not bin.
Most of the conversions done in ps2raster are handled by GhostScript. On most Unixes this program is available as gs; for Windows there is a version called gswin32c. GhostScript accepts a rich selection of command-line options that modify its behavior. Many of these are set indirectly by the options available above. However, hard-core usage may require some users to add additional options to fine-tune the result. Use -S to examine the actual command used, and add custom options via one or more instances of the -C option. For instance, to turn on image interpolation for all images, improving image quality for scaled images at the expense of speed, use -C-dDOINTERPOLATE. See www.ghostscript.com for complete documentation.
GMT(1), gs(1)