funziona con la versione nuova delle librerie

master
Emanuele Trabattoni 2019-12-17 11:30:07 +01:00
parent cc2e801ec6
commit e9a4a6089f
3 changed files with 68 additions and 23 deletions

View File

@ -4,22 +4,24 @@ Created on 8 apr 2019
@author: Emanuele Trabattoni @author: Emanuele Trabattoni
''' '''
import sys import sys, logging, os
import datetime import datetime
import PyQt5.QtWidgets import PyQt5.QtWidgets
from MKPrint_GUI import Ui_MainWindow from MKPrint_GUI import Ui_MainWindow
from printer import MarkoPrinter from printer import MarkoPrinter
import protocol
class MainWindow(PyQt5.QtWidgets.QMainWindow): class MainWindow(PyQt5.QtWidgets.QMainWindow):
def __init__(self, configFilePath): def __init__(self, configFilePath, LOGGER):
try: try:
self.printer = MarkoPrinter(configFilePath) self.printer = MarkoPrinter(configFilePath, LOGGER)
except FileNotFoundError as e: except FileNotFoundError as e:
print("Configuration file error: {}".format(e)) print("Configuration file error: {}".format(e))
sys.exit(1) sys.exit(1)
PyQt5.QtWidgets.QMainWindow.__init__(self) PyQt5.QtWidgets.QMainWindow.__init__(self)
self.log = LOGGER
self.ui = Ui_MainWindow() self.ui = Ui_MainWindow()
self.ui.setupUi(self) self.ui.setupUi(self)
self.setFixedSize(self.maximumSize()) self.setFixedSize(self.maximumSize())
@ -31,27 +33,18 @@ class MainWindow(PyQt5.QtWidgets.QMainWindow):
self.ui.rad_dataOn.setChecked(True) self.ui.rad_dataOn.setChecked(True)
self.ui.prg_inkLevel.setTextVisible(True) self.ui.prg_inkLevel.setTextVisible(True)
def updateStatusView(self):
connessa = self.printer.connected
self.ui.btn_upload.setEnabled(connessa)
if connessa:
self.ui.prg_inkLevel.setValue(self.printer.headStatus["iuse"])
self.ui.lcd_printCount.display(
str(self.printer.headStatus["labelCnt"]))
else:
self.ui.prg_inkLevel.setValue(0)
self.ui.lcd_printCount.display('0')
def toggla_connessione(self): def toggla_connessione(self):
connessa = self.printer.connected connessa = self.printer.connected
if connessa: if connessa:
connessa = self.printer.disconnetti() connessa = self.printer.disconnetti()
else: else:
connessa = self.printer.connetti() connessa = self.printer.connetti()
if connessa: if connessa:
self.ui.btn_connect.setText("DISCONNETTI") self.ui.btn_connect.setText("DISCONNETTI")
self.ui.lbl_stat.setText("Connesso") self.ui.lbl_stat.setText("Connesso")
self.timer.start(self.printer.settings["keepalive"]) self.printer.sendCommand(protocol.deleteMemory())
self.timer.start(5000)
self.timer.timeout.connect(self.keepalive) self.timer.timeout.connect(self.keepalive)
else: else:
self.timer.stop() self.timer.stop()
@ -59,11 +52,23 @@ class MainWindow(PyQt5.QtWidgets.QMainWindow):
self.ui.btn_connect.setText("CONNETTI") self.ui.btn_connect.setText("CONNETTI")
self.updateStatusView() self.updateStatusView()
def updateStatusView(self):
connessa = self.printer.connected
self.ui.btn_upload.setEnabled(connessa)
if connessa:
self.ui.lbl_stat.setText("Ready")
self.ui.prg_inkLevel.setValue(self.printer.headStatus["iuse"])
self.ui.lcd_printCount.display(str(self.printer.headStatus["labelCnt"]))
else:
self.ui.prg_inkLevel.setValue(0)
self.ui.lcd_printCount.display('0')
def keepalive(self): def keepalive(self):
# TODO: usare il primo argomento di keepalive (stato connessione) per aggiornare la ui # TODO: usare il primo argomento di keepalive (stato connessione) per aggiornare la ui
_, statusUpdated = self.printer.keepalive() _, statusUpdated = self.printer.keepalive()
if statusUpdated: if statusUpdated:
self.updateStatusView() self.updateStatusView()
pass
def upload(self): def upload(self):
if self.ui.rad_dataOn.isChecked(): if self.ui.rad_dataOn.isChecked():
@ -72,20 +77,54 @@ class MainWindow(PyQt5.QtWidgets.QMainWindow):
else: else:
date = "" date = ""
descr = str(self.ui.txt_descr.toPlainText()).capitalize() descr = str(self.ui.txt_descr.toPlainText()).capitalize()
datastr = str(self.ui.txt_model.text()).upper() + "\r" + \ self.printer.sendCommand(protocol.callPrintImage(imageName='TM1.00I',
date + descr + "\r" printMode='11',
response, statusUpdated = self.printer.upload(descr, datastr) fieldContent = '{0}\r{1}'.format(self.ui.txt_model.text().upper(),date + descr)))
if statusUpdated: r=self.printer.readResponse('callPrintImage')
self.updateStatusView() if protocol.checkResponse('callPrintImage', r):
self.ui.lbl_stat.setText(response) self.log.info("Caricamento Riuscito")
self.ui.lbl_stat.setText(self.subChars(r))
else:
self.log.error("Caricamento Fallito")
def quit(self): def quit(self):
pass pass
def subChars(self, s):
subDict = {'\x02': "#STX ",
'\x03': "#ETX ",
'\x1B': "#ESC ",
'\r': "#CR ",
'\f': "#LF ",
'\t': "#TAB ",
'\x06': "#ACK ",
'\x15': "#NACK "
}
out = ""
for c in s:
if c in subDict.keys():
out += subDict[c]
else:
out += c
return out
if __name__ == '__main__': if __name__ == '__main__':
app = PyQt5.QtWidgets.QApplication(sys.argv) app = PyQt5.QtWidgets.QApplication(sys.argv)
configFilePath = "MkpWIFI/conf.json" configFilePath = "conf.json"
window = MainWindow(configFilePath) print(os.getcwd())
# Setup Logger
LOGGER = logging.getLogger(__name__)
LOGGER.setLevel(logging.DEBUG)
LOGGER.propagate = False
FORMATTER = logging.Formatter(("%(asctime)s|%(levelname)-7s|%(funcName)-10s|%(lineno)-3d: %(message)-50s"),\
("%m-%d %H:%M:%S"))
# Console Logging
cl= logging.StreamHandler(sys.stdout)
cl.setLevel(logging.DEBUG)
cl.setFormatter(FORMATTER)
LOGGER.addHandler(cl)
window = MainWindow(configFilePath, LOGGER)
window.show() window.show()
sys.exit(app.exec_()) sys.exit(app.exec_())

View File

@ -150,6 +150,8 @@ class MarkoPrinter:
c = self.printSock.recv(1) c = self.printSock.recv(1)
# disattivo lettura bloccante # disattivo lettura bloccante
self.printSock.settimeout(0.5) self.printSock.settimeout(0.5)
# VERIFICARE SE VA BENE
self.reading = False
return str(buf, 'ascii') return str(buf, 'ascii')
except socket.timeout as t: except socket.timeout as t:
self.reading = False self.reading = False

View File

@ -0,0 +1,4 @@
X;#=51;g=1;h=MODELLO:P1-0-000000000;A9mmB;~xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx~
X;#=52;g=1;h=Descrizione:P1-0-014800000;A4mm;~xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx~
P1r0-035430000;;
P1-0-000000000:h=24