|
@ -1,5 +1,4 @@ |
|
|
from functools import partial |
|
|
from functools import partial |
|
|
import traceback |
|
|
|
|
|
import zlib |
|
|
import zlib |
|
|
import json |
|
|
import json |
|
|
from io import BytesIO |
|
|
from io import BytesIO |
|
@ -75,24 +74,20 @@ class Plugin(BasePlugin): |
|
|
|
|
|
|
|
|
def handler(): |
|
|
def handler(): |
|
|
blob = json.dumps(dialog.tx.as_dict()) |
|
|
blob = json.dumps(dialog.tx.as_dict()) |
|
|
self.sender = self._send(parent=dialog, blob=blob) |
|
|
self._send(parent=dialog, blob=blob) |
|
|
self.sender.start() |
|
|
|
|
|
b.clicked.connect(handler) |
|
|
b.clicked.connect(handler) |
|
|
dialog.sharing_buttons.insert(-1, b) |
|
|
dialog.sharing_buttons.insert(-1, b) |
|
|
|
|
|
|
|
|
@hook |
|
|
@hook |
|
|
def scan_text_edit(self, parent): |
|
|
def scan_text_edit(self, parent): |
|
|
def handler(): |
|
|
parent.addButton(':icons/microphone.png', partial(self._recv, parent), |
|
|
self.receiver = self._recv(parent=parent) |
|
|
_("Read from microphone")) |
|
|
self.receiver.start() |
|
|
|
|
|
parent.addButton(':icons/microphone.png', handler, _("Read from microphone")) |
|
|
|
|
|
|
|
|
|
|
|
@hook |
|
|
@hook |
|
|
def show_text_edit(self, parent): |
|
|
def show_text_edit(self, parent): |
|
|
def handler(): |
|
|
def handler(): |
|
|
blob = str(parent.toPlainText()) |
|
|
blob = str(parent.toPlainText()) |
|
|
self.sender = self._send(parent=parent, blob=blob) |
|
|
self._send(parent=parent, blob=blob) |
|
|
self.sender.start() |
|
|
|
|
|
parent.addButton(':icons/speaker.png', handler, _("Send to speaker")) |
|
|
parent.addButton(':icons/speaker.png', handler, _("Send to speaker")) |
|
|
|
|
|
|
|
|
def _audio_interface(self): |
|
|
def _audio_interface(self): |
|
@ -101,31 +96,25 @@ class Plugin(BasePlugin): |
|
|
|
|
|
|
|
|
def _send(self, parent, blob): |
|
|
def _send(self, parent, blob): |
|
|
def sender_thread(): |
|
|
def sender_thread(): |
|
|
try: |
|
|
with self._audio_interface() as interface: |
|
|
with self._audio_interface() as interface: |
|
|
src = BytesIO(blob) |
|
|
src = BytesIO(blob) |
|
|
dst = interface.player() |
|
|
dst = interface.player() |
|
|
amodem.main.send(config=self.modem_config, src=src, dst=dst) |
|
|
amodem.main.send(config=self.modem_config, src=src, dst=dst) |
|
|
|
|
|
except Exception: |
|
|
|
|
|
traceback.print_exc() |
|
|
|
|
|
|
|
|
|
|
|
print_msg('Sending:', repr(blob)) |
|
|
print_msg('Sending:', repr(blob)) |
|
|
blob = zlib.compress(blob) |
|
|
blob = zlib.compress(blob) |
|
|
|
|
|
|
|
|
kbps = self.modem_config.modem_bps / 1e3 |
|
|
kbps = self.modem_config.modem_bps / 1e3 |
|
|
msg = 'Sending to Audio MODEM ({0:.1f} kbps)...'.format(kbps) |
|
|
msg = 'Sending to Audio MODEM ({0:.1f} kbps)...'.format(kbps) |
|
|
return WaitingDialog(parent=parent, message=msg, run_task=sender_thread) |
|
|
WaitingDialog(parent, msg, sender_thread) |
|
|
|
|
|
|
|
|
def _recv(self, parent): |
|
|
def _recv(self, parent): |
|
|
def receiver_thread(): |
|
|
def receiver_thread(): |
|
|
try: |
|
|
with self._audio_interface() as interface: |
|
|
with self._audio_interface() as interface: |
|
|
src = interface.recorder() |
|
|
src = interface.recorder() |
|
|
dst = BytesIO() |
|
|
dst = BytesIO() |
|
|
amodem.main.recv(config=self.modem_config, src=src, dst=dst) |
|
|
amodem.main.recv(config=self.modem_config, src=src, dst=dst) |
|
|
return dst.getvalue() |
|
|
return dst.getvalue() |
|
|
|
|
|
except Exception: |
|
|
|
|
|
traceback.print_exc() |
|
|
|
|
|
|
|
|
|
|
|
def on_success(blob): |
|
|
def on_success(blob): |
|
|
if blob: |
|
|
if blob: |
|
@ -135,5 +124,4 @@ class Plugin(BasePlugin): |
|
|
|
|
|
|
|
|
kbps = self.modem_config.modem_bps / 1e3 |
|
|
kbps = self.modem_config.modem_bps / 1e3 |
|
|
msg = 'Receiving from Audio MODEM ({0:.1f} kbps)...'.format(kbps) |
|
|
msg = 'Receiving from Audio MODEM ({0:.1f} kbps)...'.format(kbps) |
|
|
return WaitingDialog(parent=parent, message=msg, |
|
|
WaitingDialog(parent, msg, receiver_thread, on_success=on_success) |
|
|
run_task=receiver_thread, on_success=on_success) |
|
|
|
|
|