Ticket impreso con impresora Xprinter usando plugin - Soporta imágenes, códigos QR, de barras y acentos

Plugin para impresoras térmicas versión 3

Me complace anunciar la versión 3 (y final) de mi plugin que permite imprimir en impresoras térmicas de manera gratuita.

Este plugin combina lo mejor de las otras versiones en una sola. A continuación veamos sus principales características:

  1. Impresión de texto
  2. Impresión de texto con acentos, definiendo la página de códigos de caracteres o code page. Podrás imprimir texto con ñ, vocales con tilde, diéresis, etcétera.
  3. Soporte para imágenes de una URL de internet (puede ser incluso localhost), en base64 o del almacenamiento local
  4. Códigos de barras
  5. Códigos QR
  6. Cambio de tamaño de texto
  7. Subrayado
  8. Enfatizado
  9. Alineación
  10. Apertura de cajón
  11. Corte de papel
  12. Rotación al imprimir
  13. Impresión inversa
  14. Impresión blanco y negro inversa
  15. No necesita internet. Trabaja completamente fuera de línea
  16. No tiene restricción de cantidad de tickets, dominios ni lenguajes de programación.
  17. Definición de caracteres personalizados de 24×12, con esto podrás definir un propio carácter usando una cuadrícula. Ya podrás imprimir el símbolo del euro, yen, bitcoin, centavo y cualquier cosa que se pueda representar con 24×12 puntos
  18. Compatible con Windows, Linux y Raspberry Pi (técnicamente compatible con Raspbian en procesadores ARM)

Además, existirá una versión con licencia en caso de que quieras adquirirla. a continuación explicaré todos los detalles del plugin.

Diseñador para impresoras térmicas

Acabo de crear un diseñador de recibos para impresoras térmicas en donde podrás diseñar tickets ESC POS, importar, exportar, generar el código para varios lenguajes de programación y revisar una guía paso a paso para descargar, instalar y usar el plugin. Pruébalo en: https://parzibyte.me/apps/ticket-designer/#/first-steps

Configurando impresora

Antes de usar el plugin debes asegurarte de que tu impresora funciona. Te recomiendo ver el siguiente enlace para instalar y compartir tu impresora: https://parzibyte.me/blog/2017/12/11/instalar-impresora-termica-generica/

Para la Raspberry Pi ya existe un tutorial completo: https://parzibyte.me/blog/2022/10/02/conectar-raspberry-pi-impresora-termica/

Y para Linux solo debes instalar la impresora como se indica en este post, ejecutar el plugin y seguir los mismos pasos.

El plugin es compatible únicamente con impresoras térmicas. No puedo garantizar el funcionamiento en otros tipos de dispositivos.

Descargar plugin

El plugin realmente es gratuito y no tiene ningún tipo de virus. Incluso así, lo descargas bajo tu responsabilidad. Además, si tan inseguro eres puedes descargarlo en una máquina virtual o desarrollar tu propia versión, lo que te parezca más fácil.

Puedes descargarlo del siguiente enlace: https://github.com/parzibyte/plugin-impresora-termica-v3/releases/latest debes descargar el plugin según tu plataforma (Windows, Linux o Raspberry Pi) y luego extraerlo, te dará un archivo ejecutable y un archivo DLL en el caso de Windows.

Si Chrome o tu navegador te dice algo como Este archivo no se descarga habitualmente y puede ser peligroso haz clic en Descargar. Puede que te salgan varios avisos de esos, pero debes dar todos los permisos necesarios, incluyendo el Firewall.

Nota: se maneja el mismo plugin para todos los lenguajes de programación. Es decir, solo es un plugin y varios conectores según el lenguaje de programación.

Ejecutar plugin

Ahora ejecuta el archivo llamado plugin_impresoras_termicas_v3.1_prod_64.exe. Te repito que si te pide permiso debes dárselo. No se abrirá ninguna ventana, pero el plugin ya estará corriendo en segundo plano (Puedes comprobarlo en el administrador de tareas, dentro de detalles)

Es momento de visitar https://parzibyte.github.io/ejemplos-javascript-plugin-v3/capacidades.html (por favor, mira bien la URL), debe aparecer algo como lo siguiente en donde podrás imprimir un ticket de prueba:

Plugin para imprimir en impresoras térmicas
Plugin para imprimir en impresoras térmicas

Selecciona tu impresora de la lista y haz clic en Imprimir. Te repito que el plugin solo funciona en impresoras físicas y térmicas. Si tu impresora no aparece, asegúrate de haberla instalado y compartido correctamente.

Debe imprimirse un ticket como el siguiente:

Ticket impreso con impresora Xprinter usando plugin - Soporta imágenes, códigos QR, de barras y acentos
Ticket impreso con impresora Xprinter usando plugin – Soporta imágenes, códigos QR, de barras y acentos

Por favor nota todo lo que el plugin soporta, y fíjate en el carácter personalizado. Con eso puedes definir tus propios caracteres en una cuadrícula de 24×12.

Sin saberlo ya has usado el conector de JavaScript. Puedes ver el código fuente para que veas que es realmente sencillo, aunque más adelante explicaré el conector por separado.

Nota: yo he usado una impresora muy económica y sencilla. Si funciona con la mía, funcionará con la tuya.

Nota 2: si quieres puedes navegar por los ejemplos de la página: https://parzibyte.github.io/ejemplos-javascript-plugin-v3/hola.html

Navegando por los ejemplos

Si quieres puedes navegar por los ejemplos, aquí te explico cómo hacerlo:

Revisando errores del plugin

Se van a crear algunos archivos de registro en la ubicación del plugin. Tienen el nombre del mes y año. Por ejemplo, en octubre de 2022 se llamará 2022_10.log.

Ahí aparecerán todos los errores o avisos. Si el plugin falla, por favor lee los mensajes de error y/o tradúcelos para saber lo que tienes que hacer.

El error open Impresora: the network name cannot be found o La ruta de acceso especificada no es válida es debido a que no has compartido tu impresora, no has especificado la impresora o estás intentando imprimir en una impresora en red local, cosa que no es posible. La impresora debe estar conectada en la computadora donde se ejecuta el plugin y debe estar compartida.

Cambiando el puerto del plugin

Si quieres puedes cambiar el puerto del plugin pasándole la opción en la línea de comandos. En este caso debes ejecutarlo desde la terminal así:

plugin_impresoras_termicas_v3_prod_64.exe --puerto=PUERTO

O puedes crear un acceso directo (aprovechando también para que inicie junto con el sistema, cosa que explico más adelante) y pasarle la opción desde ahí:

Cambiando puerto del plugin
Cambiando puerto del plugin

En este caso estoy indicando que quiero que ocupe el puerto 8484. Tú puedes elegir el puerto que prefieras, siempre y cuando sea válido. Recuerda que el puerto por defecto es el 8000.

Nota: si cambias el puerto de escucha del plugin, también debes cambiar la URL al momento de invocar a los conectores.

Contratar una licencia

Por favor, lee el siguiente post en donde lo explico con detenimiento:

Contratar una licencia para el plugin de impresora térmica V3

Conectores disponibles

Por el momento existe el conector de PHP, C#, Java, Python, Node.js y de JavaScript. Más conectores vienen en camino, e incluso tú mismo puedes escribirlos según tu lenguaje de programación, ya que al final el plugin es un servidor HTTP.

Crear conector para plugin de impresora térmica

Iniciar plugin junto con el sistema

Si quieres puedes hacer que el plugin inicie con Windows, solo debes crear el acceso directo en el Startup folder (recuerda que en el mismo acceso directo puedes configurar el puerto).

Más información en el siguiente enlace: https://parzibyte.me/blog/2019/10/14/ejecutar-programa-inicio-windows/

Usuarios de Linux

No puse instrucciones sobre cómo iniciar automáticamente en Linux o pasar la opción del cambio de puerto, pero si eres de Linux ya debes saber cómo hacerlo, hay muchas maneras ya que ese sistema es más personalizable.

Usuarios de Android

Ya existe un plugin para imprimir en impresoras térmicas Bluetooth desde Android, es uno distinto al presentado en este post pero que cumple con la misma función. Mira los detalles en:

Plugin gratuito para impresoras térmicas Bluetooth en Android

Versiones anteriores

Antes de existir esta versión existieron la versión 1 y 2. Esas versiones ya no están disponibles, solo están como código fuente para evitar confusiones con esta versión.

El plugin versión 3 es la única versión disponible para su uso.

Versión 1:

Código fuente de plugin para impresora térmica v1

Versión 2:

Código fuente de plugin para impresoras térmicas v2

Documentación y métodos del plugin

Los conectores disponibles manejan el mismo número de argumentos y funciones. ya que al final solo sirven de puente para comunicarse con el plugin. A continuación dejaré los métodos y la documentación escrita por mí.

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

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.

36 comentarios en “Plugin para impresoras térmicas versión 3”

  1. Hola Parzi, el plugin me funciona super, lo unico es que no he podido imprimir imagen , siempre me sale :Error al imprimir: Error en el servidor: Error invocando a ImprimirImagenEnBase64: El ancho de la imagen debe ser multiplo de 8. Requiero tu asesoria.

  2. Buen dia, tengo problemas para imprimir acentos aun con los botones de los ejemplos.
    En la doc. mencionas que los parametros son num pagina y pagina, de donde saco estos num.
    estoy imprimiendo con una Epson Tm-t88v.
    De antemano Gracias

    1. Buen día. Depende de las páginas de códigos que soporte su impresora, eso cambia dependiendo de cada una. Recomiendo probar con varias combinaciones en caso de no encontrar las páginas de códigos de su impresora.
      Recuerde que si necesita ayuda puede enviarme un mensaje en https://parzibyte.me/#contacto para brindarle una consultoría

    1. Hola. La página de prueba supone que usa el puerto por defecto, en ese caso tendría que dejar el puerto intacto para las pruebas, o ajustar el código de la página de prueba para que envíe la petición al puerto configurado

  3. Hola Parzybite, tengo una pregunta al momento de imprimir cualquier ticket siempre sale ese pie de pagina? y otra duda, estoy trabajando en un proyecto de nextjs, me srive perfectamente la versio de javascript?. Gracias igualmente por el recurso

    1. Hola, gracias por sus comentarios. Claro, el plugin es totalmente gratuito pero usted debe respetar mis créditos o puede optar por obtener una licencia para removerlos: https://parzibyte.me/blog/2022/10/02/contratar-licencia-para-plugin-impresora-termica-v3/
      En cuanto a su pregunta, depende de dónde vaya a servir la app, puede revisar el conector de Node: https://parzibyte.me/blog/2023/06/27/impresora-termica-node-js/ o el conector de JS del lado del cliente: https://parzibyte.me/blog/2022/09/30/comunicar-javascript-impresora-termica-usando-plugin-v3/

  4. hola parzibyte, a mi me funciona perfecto el plugin, solo tengo un problema con la letra ñ y saber como el codigo para detectar las impresoras y dejar guardado el nombre de esa impresora en la base de datos. recien te pague 1 año del plugin. gracias.

  5. Alejandro Lemos

    Amigo yo de nuevo, necesito urgente que me envies la clave a mi e-mail. Al final consegui pagarte por paypal con ayuda de mi hermana, que lo hizo a traves de su cuenta, ya que me presto su tarjeta de crédito. El pago fue emitido por Maria Lemos

  6. que tal? gran plugin, me viene salvando pero tengo problemas.
    imprime todo el contenido anterior en cada ticket. para explicarlo mejor voy a ejemplificar.
    entiendase por A y B contenido de tickets distintos.
    si indico que imprima A, imprime A. luego indico que imprima B, imprime A y B. indico que imprima A nuevamente, imprime A B y A.
    lo que necesito es que imprima A, luego B y luego A. por separado, son tickets individuales.
    es como si la impresora guardase en memoria lo que imprimió y cada vez que imprime lo hace con sus impresiones anteriores nuevamente.
    alguna idea de que puede estar pasando?

    1. Tal vez no está usando el plugin como se debe. Sin código ni pasos para reproducir el error no puedo ayudarle ni diagnosticar si el problema es el plugin o su impresora.
      Recuerde que estoy a sus órdenes en https://parzibyte.me/#contacto, puede solicitar una consultoría y enviarme capturas de pantalla o explicarme cómo reproducir el problema.

  7. Hola, muchas gracias por el plugin, me parece excelente tu labor.
    Quiero compartir lo que me ocurre al usarlo.
    Lo ejecuté el jueves pasado (9/Mar) y lo pude ver en el listado de procesos en segundo plano, aunque aún no tenia la impresora instalada, en la pagina de prueba se mostraban las impresoras virtuales (Microsoft print to PDF, One Note 16, etc).
    Hoy (13/Mar) lo vuelvo a ejecutar pero ya no se muestra en el listado de procesos y en la página ya no se ven las impresoras, aún y cuando ya instalé la impresora térmica y ya la compartí.
    En el archivo de log está el siguiente mensaje: “listen tcp :8000: bind: Solo se permite un uso de cada dirección de socket (protocolo/dirección de red/puerto)”.
    ¿Algo me estará faltando o estaré haciendo algo erróneo?
    Espero me puedas ayudar.

    De antemano muchas gracias por la ayuda que me puedas brindar.

    Saludos!!.

    1. Hola, buen día.

      Ya pude solucionar la situación que se me presentó, en las pruebas que hice ajusté el puerto y ya no lo regresé al valor original (8000).
      Ya se cargan las impresoras que tengo instaladas incluyendo la térmica, sin embargo, al momento de mandar imprimir, en el log se muestra el siguiente error: “Al imprimir: Error en el servidor: json: cannot unmarshal array into Go value of type main.ImpresionConNombre” y no se imprime nada.

      ¿Será que me puedes orientar para poder encontrar algo que esté haciendo mal o me esté faltando?

      De nuevo, muchas gracias por tu apoyo.

    2. Hola. Le recomiendo que lea detenidamente la documentación ya que los errores que ha tenido hasta el momento han sido porque no ha leído detalladamente. El error que se le presenta puede deberse a que está usando el conector de JavaScript de cierta versión pero con el plugin de otra versión.
      Recuerde que la documentación dice todo lo que necesita, pero si quiere puede solicitar ayuda personalizada en https://parzibyte.me/#contacto

    1. Hola. En este post que está comentando. Si quiere el precio por licencia puede leer en “Contratar una licencia”, ahí se indica el precio, detalles y métodos de pago. Si no encuentra algo (por ejemplo, el código fuente) es porque no está disponible.
      Saludos!

  8. Buen dia, primeramente gracias por todos tu aportes, buento me sale el siguiente error : Error. El mensaje es: Error en el servidor: open \\DESKTOP-PORB6EF\: La ruta de acceso especificada no es válida. y no se a que se debe, me serviri mucho si me puedes orientar a solucionarlo. gracias.

    1. open Impresora: the network name cannot be found o La ruta de acceso especificada no es válida es debido a que no has compartido tu impresora, no has especificado la impresora o estás intentando imprimir en una impresora en red local, cosa que no es posible. La impresora debe estar conectada en la computadora donde se ejecuta el plugin y debe estar compartida.

  9. Hola amigo! gracias por tu ayuda, me ha interesado mucho el tema de las impresoras térmicas. Una duda, se puede imprimir en dos columnas? por ejemplo por un lado el nombre del artículo y a la derecha en la misma línea el precio? alguna idea de cómo hacer?

  10. Buen día amigo, antes que nada tu plugin me ha ayudado mucho así que muchas gracias. Implemente una version anterior y estoy actualizando a la version 3 y tengo una pregunta, cual es la funcion para abrir el cajon? en la version anterior el metodo era abrirCajon(). De antemano te agradezco y espero que sigas con tu excelente trabajo

    1. error 0xc00007b Algunos usuarios me informan que tienen el error 0xc00007b o que les pide una DLL de libiconv-2.dll o algo así. Ya he incluido esa DLL en el zip de pluginv3_windows_64.zip y ya no debería dar ningún tipo de problema. Asegúrate de distribuir el plugin junto con esa DLL

Dejar un comentario