javascript

Imprimir imágenes en impresora térmica usando JavaScript

Al imprimir tickets, recibos y todo tipo de contenido en las impresoras térmicas surge la necesidad de imprimir imágenes.

Imprimiendo imágenes en impresora térmica usando JavaScript

Por ejemplo, a veces es necesario imprimir el logotipo de la empresa o tienda de donde se imprime el ticket, pues le da una presentación agradable.

Hoy te enseñaré cómo usar JavaScript para imprimir imágenes en una impresora térmica. Las imágenes pueden ser locales o de una URL como localhost e incluso de internet.

Requisitos

Lo único que necesitas es descargar y ejecutar el plugin además de compartir tu impresora. Como vamos a usar JavaScript, puede que encuentres información que acompañe al post en el siguiente enlace:

Nota: luego de que aprendas a hacerlo con JavaScript puedes usar otros lenguajes como Python, Java o cualquier otro que hable HTTP.

Imprimiendo imagen según URL

Con este método puedes hacer que el plugin descargue una imagen y la imprima. Esta URL puede ser de internet, por ejemplo:

http://ejemplo.com/imagen.jpg

O también puede ser de tu dominio, por ejemplo:

http://tudominio.com/assets/logo.png

Incluso puede ser de localhost:

http://localhost/proyecto/imagen.jpg

Al final debe ser una URL de internet válida. Para hacerlo invocamos a DescargarImagenDeInternetEImprimir.

Solo recuerda que el plugin va a descargar la imagen y va a dejar un rastro de la conexión, además de asumir que el destino de la URL es una imagen válida. Por ello solo usa imágenes de sitios en los que confíes.

Imagen local

Una imagen local es la que se encuentra en la computadora donde se encuentra el plugin y su ubicación es algo como C:\usuarios\tu_usuario\logo.png.

Para imprimir una imagen local invocamos a CargarImagenLocalEImprimir.

Recuerda que puedes invocar a este método varias veces.

Imagen en base64

El plugin de impresión de imágenes también permite imprimir imágenes en base64, es decir, puedes enviar la imagen como cadena.

Para imprimir una imagen en base64 desde el plugin ya sea con JS, Python, Java o cualquier otro invocamos a ImprimirImagenEnBase64.

Ejemplo completo

Ahora voy a imprimir 3 imágenes para demostrar cómo imprimir imágenes en una impresora térmica desde JavaScript.

En este ejemplo estoy definiendo los valores de las imágenes manualmente, pero pueden venir de cualquier lugar. Para el caso de la imagen local, asegúrate de que exista, ya que mi entorno es distinto al tuyo.

Voy a crear la lista de operaciones que serán ejecutadas en la impresora térmica en el mismo orden, convirtiendo la petición en comandos ESC POS:

const respuesta = await fetch("http://localhost:8000/imprimir",
    {
        method: "POST",
        body: JSON.stringify({
            "serial": "",
            "nombreImpresora": "Termica",
            "operaciones": [
                {
                    "nombre": "DescargarImagenDeInternetEImprimir",
                    "argumentos": [
                        "https://github.com/parzibyte.png",
                        380,
                        0,
                        true
                    ]
                },
                {
                    "nombre": "Feed",
                    "argumentos": [
                        2
                    ]
                },
                {
                    "nombre": "ImprimirImagenEnBase64",
                    "argumentos": [
                        "",
                        380,
                        0,
                        true
                    ]
                },
                {
                    "nombre": "Feed",
                    "argumentos": [
                        2
                    ]
                },
                {
                    "nombre": "CargarImagenLocalEImprimir",
                    "argumentos": [
                        "C:\\Users\\tu_usuario\\Desktop\\Panqué_y_grim.png",
                        380,
                        0,
                        true
                    ]
                },
                {
                    "nombre": "Feed",
                    "argumentos": [
                        2
                    ]
                }
            ]
        }),

    });

La salida es la que se ve al inicio del post, pero la vuelvo a colocar aquí:

Imprimiendo imágenes en impresora térmica usando JavaScript

Si quieres puedes probar la demostración en el siguiente enlace, solo asegúrate de estar ejecutando el plugin: probar ejemplo en área de pruebas.

Sobre los tamaños y formatos de imagen

El plugin soporta solo imágenes JPG y PNG. Recuerda que puedes cambiar el ancho de la imagen.

No olvides que la impresora solo va a imprimir en blanco y negro, y considerará algunos colores como blanco si están en un nivel muy claro. Por ello es que si quieres algo óptimo debes crear la imagen en blanco y negro desde el inicio.

También puedes aplicar dithering para conservar la iluminación, y en caso de que aparezcan caracteres extraños puedes cambiar el algoritmo de impresión.

De cualquier modo, la mejor forma es probando con tus propias imágenes e ir sacando conclusiones. Recuerda que todo lo necesario lo encuentras en la documentación oficial.

Por cierto, también puedes ver el plugin de impresoras térmicas Bluetooth para Android.

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Entradas recientes

Resetear GOOJPRT PT-210 MTP-II (Impresora térmica)

El día de hoy vamos a ver cómo restablecer la impresora térmica GOOJPRT PT-210 a…

1 semana hace

Proxy Android para impresora térmica ESC POS

Hoy voy a enseñarte cómo imprimir en una impresora térmica conectada por USB a una…

1 semana hace

Android – Servidor web con servicio en segundo plano

En este post voy a enseñarte a programar un servidor web en Android asegurándonos de…

1 semana hace

Cancelar trabajo de impresión con C++

En este post te quiero compartir un código de C++ para listar y cancelar trabajos…

1 mes hace

Copiar bytes de Golang a JavaScript con WebAssembly

Gracias a WebAssembly podemos ejecutar código de otros lenguajes de programación desde el navegador web…

2 meses hace

Imprimir PDF con Ghostscript en Windows de manera programada

Revisando y buscando maneras de imprimir un PDF desde la línea de comandos me encontré…

2 meses hace