exemplo de como imprimir uma string e definindo fonte e o tamanho para a fonte …
public class imprimir implements Printable {
public static String textoCupom;
//Se obtienen las lineas de texto del JTextArea, la linea de texto finaliza cuando se encuentra el caracter de nueva linea \n
StringTokenizer lineasdetexto = new StringTokenizer(textoCupom, "\n", true);
//Se obtiene el total de lineas de texto
int totallineas = lineasdetexto.countTokens();
int[] paginas; // Arreglo de número de paginas que se necesitaran para imprimir todo el texto
String[] textoLineas; //Lineas de texto que se imprimiran en cada hoja
//Metodo que se crea por default cuando una clase implementa a Printable
public int print(Graphics g, PageFormat pf, int pageIndex)
throws PrinterException {
//Se establece la fuente, el tipo, el tamaño, la metrica según la fuente asignada,
//obtiene la altura de cada linea de texto para que todas queden iguales
Font font = new Font("Serif", Font.PLAIN, 8);
FontMetrics metrics = g.getFontMetrics(font);
int altodelinea = metrics.getHeight();
//Calcula el número de lineas por pagina y el total de paginas
if (paginas == null) {
initTextoLineas();
//Calcula las lineas que le caben a cada página dividiendo la altura imprimible entre la altura de la linea de texto
int lineasPorPagina = (int)(pf.getImageableHeight()/altodelinea);
//Calcula el numero de páginas dividiendo el total de lineas entre el numero de lineas por página
int numeroPaginas = (textoLineas.length-1)/lineasPorPagina;
paginas = new int[numeroPaginas];
for (int b=0; b<numeroPaginas; b++) {
paginas[b] = (b+1)*lineasPorPagina;
}
}
//Si se recibe un indice de página mayor que el total de páginas calculadas entonces
//retorna NO_SUCH_PAGE para indicar que tal pagina no existe
if (pageIndex > paginas.length) {
return NO_SUCH_PAGE;
}
/*Por lo regular cuando dibujamos algun objeto lo coloca en la coordenada (0,0), esta coordenada
* se encuentra fuera del área imprimible, por tal motivo se debe trasladar la posicion de las lineas de texto
* según el área imprimible del eje X y el eje Y
*/
Graphics2D g2d = (Graphics2D)g;
g2d.translate(pf.getImageableX(), pf.getImageableY());
/*Dibujamos cada línea de texto en cada página,
* se aumenta a la posición 'y' la altura de la línea a cada línea de texto para evitar la saturación de texto
*/
int y = 0;
int start = (pageIndex == 0) ? 0 : paginas[pageIndex-1];
int end = (pageIndex == paginas.length) ? textoLineas.length : paginas[pageIndex];
for (int line=start; line<end; line++) {
y += altodelinea;
g.drawString(textoLineas[line], 0, y);
}
/* Retorna PAGE_EXISTS para indicar al invocador que esta página es parte del documento impreso
*/
return PAGE_EXISTS;
}
/* Agrega las lineas de texto al arreglo */
public void initTextoLineas() {
if (textoLineas == null) {
int numLineas=totallineas;
textoLineas = new String[numLineas];
//Se llena el arreglo que contiene todas las lineas de texto
while(lineasdetexto.hasMoreTokens()){
for (int i=0;i<numLineas;i++) {
textoLineas[i] = lineasdetexto.nextToken();
}
}
}
}
//Este metodo crea un objeto Printerjob el cual es inicializado y asociado con la impresora por default
public boolean imprimirnomina() {
PrinterJob job = PrinterJob.getPrinterJob();
job.setPrintable(this);
//Si el usuario presiona imprimir en el dialogo de impresión,
//entonces intenta imprimir todas las lineas de texto
boolean ok = job.printDialog();
if (ok) {
try {
job.print();
return true;
} catch (PrinterException ex) {
/* The job did not successfully complete */
return false;
}
}
return true;
}
}