Add missing join() in MainScreen.on_edje_numberkey_triggered()
Add phone status callbacks to PyneoControl (gsm_phone_ringing and friends) Change if/if/if structure to if/elif/elif to be more efficient Make PyneoControl able to send parameters to callbacks when they're called Use these parameters to submit values where meaningful (e.g. sim_key_required) Make Dialer class switch screens on call status changes git-svn-id: http://www.neo1973-germany.de/svn@123 46df4e5c-bc4e-4628-a0fc-830ba316316d
This commit is contained in:
parent
02593e9bb2
commit
24fa27ff11
1 changed files with 33 additions and 11 deletions
|
@ -77,9 +77,9 @@ class MainScreen(EdjeGroup):
|
||||||
PyneoController.register_callback("gsm_registered", self.on_gsm_registered)
|
PyneoController.register_callback("gsm_registered", self.on_gsm_registered)
|
||||||
PyneoController.register_callback("gsm_dialing", self.on_gsm_dialing)
|
PyneoController.register_callback("gsm_dialing", self.on_gsm_dialing)
|
||||||
|
|
||||||
def on_sim_key_required(self):
|
def on_sim_key_required(self, key_type):
|
||||||
print '---', 'opening keyring'
|
print '---', 'opening keyring'
|
||||||
self.part_text_set("numberdisplay_text", "Enter " + PyneoController.gsm_keyring_status['code'])
|
self.part_text_set("numberdisplay_text", "Enter " + key_type)
|
||||||
|
|
||||||
def on_sim_ready(self):
|
def on_sim_ready(self):
|
||||||
print '---', 'SIM unlocked'
|
print '---', 'SIM unlocked'
|
||||||
|
@ -121,7 +121,7 @@ class MainScreen(EdjeGroup):
|
||||||
print ''.join(self.text)
|
print ''.join(self.text)
|
||||||
self.part_text_set("numberdisplay_text", "".join(self.text))
|
self.part_text_set("numberdisplay_text", "".join(self.text))
|
||||||
elif source == "dial":
|
elif source == "dial":
|
||||||
PyneoController.gsm_dial(self.text)
|
PyneoController.gsm_dial("".join(self.text))
|
||||||
|
|
||||||
|
|
||||||
class PyneoController(object):
|
class PyneoController(object):
|
||||||
|
@ -149,10 +149,10 @@ class PyneoController(object):
|
||||||
class_._callbacks[event_name] = [callback]
|
class_._callbacks[event_name] = [callback]
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def notify_callbacks(class_, event_name):
|
def notify_callbacks(class_, event_name, *args):
|
||||||
try:
|
try:
|
||||||
for cb in class_._callbacks[event_name]:
|
for cb in class_._callbacks[event_name]:
|
||||||
cb()
|
cb(*args)
|
||||||
|
|
||||||
except KeyError:
|
except KeyError:
|
||||||
pass
|
pass
|
||||||
|
@ -272,15 +272,28 @@ class PyneoController(object):
|
||||||
|
|
||||||
if nw_status == 0:
|
if nw_status == 0:
|
||||||
class_.notify_callbacks("gsm_unregistered")
|
class_.notify_callbacks("gsm_unregistered")
|
||||||
if nw_status in (1, 5):
|
elif nw_status in (1, 5):
|
||||||
class_.notify_callbacks("gsm_registered")
|
class_.notify_callbacks("gsm_registered")
|
||||||
if nw_status == 2:
|
elif nw_status == 2:
|
||||||
class_.notify_callbacks("gsm_registering")
|
class_.notify_callbacks("gsm_registering")
|
||||||
if nw_status == 3:
|
elif nw_status == 3:
|
||||||
class_.notify_callbacks("gsm_reg_denied")
|
class_.notify_callbacks("gsm_reg_denied")
|
||||||
if nw_status == 4:
|
elif nw_status == 4:
|
||||||
raise NotImplementedError("GSM registration has unknown state")
|
raise NotImplementedError("GSM registration has unknown state")
|
||||||
|
|
||||||
|
if status.has_key('phone_activity_status'):
|
||||||
|
ph_status = status['phone_activity_status']
|
||||||
|
|
||||||
|
if ph_status == 0:
|
||||||
|
class_.notify_callbacks("gsm_phone_call_end")
|
||||||
|
if ph_status == 3:
|
||||||
|
class_.notify_callbacks("gsm_phone_ringing")
|
||||||
|
if ph_status == 4:
|
||||||
|
class_.notify_callbacks("gsm_phone_call_start")
|
||||||
|
|
||||||
|
if status.has_key('rssi'):
|
||||||
|
class_.notify_callbacks("gsm_signal_strength_change", status['rssi'])
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def on_gsm_keyring_status(class_, status_map):
|
def on_gsm_keyring_status(class_, status_map):
|
||||||
status = dedbusmap(status_map)
|
status = dedbusmap(status_map)
|
||||||
|
@ -294,7 +307,7 @@ class PyneoController(object):
|
||||||
class_.gsm_wireless.Register(dbus_interface=DIN_WIRELESS)
|
class_.gsm_wireless.Register(dbus_interface=DIN_WIRELESS)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
class_.notify_callbacks("sim_key_required")
|
class_.notify_callbacks("sim_key_required", status["code"])
|
||||||
|
|
||||||
|
|
||||||
class Dialer(object):
|
class Dialer(object):
|
||||||
|
@ -321,6 +334,9 @@ class Dialer(object):
|
||||||
self.system_bus = SystemBus(mainloop=dbus_ml)
|
self.system_bus = SystemBus(mainloop=dbus_ml)
|
||||||
PyneoController.init()
|
PyneoController.init()
|
||||||
|
|
||||||
|
# Register our own callbacks
|
||||||
|
PyneoController.register_callback("gsm_phone_call_start", self.on_call_start)
|
||||||
|
PyneoController.register_callback("gsm_phone_call_end", self.on_call_start)
|
||||||
|
|
||||||
def init_screen(self, screen_name, instance):
|
def init_screen(self, screen_name, instance):
|
||||||
self.screens[screen_name] = instance
|
self.screens[screen_name] = instance
|
||||||
|
@ -342,6 +358,12 @@ class Dialer(object):
|
||||||
def get_evas(self):
|
def get_evas(self):
|
||||||
return self.evas_canvas.evas_obj.evas
|
return self.evas_canvas.evas_obj.evas
|
||||||
|
|
||||||
|
def on_call_start(self):
|
||||||
|
self.show_screen(INCALL_SCREEN_NAME)
|
||||||
|
|
||||||
|
def on_call_end(self):
|
||||||
|
self.show_screen(MAIN_SCREEN_NAME)
|
||||||
|
|
||||||
|
|
||||||
class EvasCanvas(object):
|
class EvasCanvas(object):
|
||||||
def __init__(self, fullscreen, engine_name):
|
def __init__(self, fullscreen, engine_name):
|
||||||
|
|
Loading…
Reference in a new issue