click 2, click dial, power gps on/off
git-svn-id: http://www.neo1973-germany.de/svn@168 46df4e5c-bc4e-4628-a0fc-830ba316316d
This commit is contained in:
parent
a0d7b603e5
commit
1d4693fdcb
3 changed files with 112 additions and 8 deletions
|
@ -75,7 +75,7 @@ part { \
|
||||||
description { \
|
description { \
|
||||||
state: "default" 0.5; \
|
state: "default" 0.5; \
|
||||||
inherit: "default" 0; \
|
inherit: "default" 0; \
|
||||||
color_class: "button_active"; \
|
color_class: "unvisible"; \
|
||||||
rel1.offset: 0 -5; \
|
rel1.offset: 0 -5; \
|
||||||
rel2.offset: 0 5; \
|
rel2.offset: 0 5; \
|
||||||
} \
|
} \
|
||||||
|
@ -521,8 +521,6 @@ collections {
|
||||||
name: "hash_key_emit_signal_screen_locked";
|
name: "hash_key_emit_signal_screen_locked";
|
||||||
action: SIGNAL_EMIT "dialer_send" "screen_locked";
|
action: SIGNAL_EMIT "dialer_send" "screen_locked";
|
||||||
}
|
}
|
||||||
/*DESIGN_SEPERATOR(10, 1/3, 58/70, 1/3, 68/70);
|
|
||||||
DESIGN_SEPERATOR(11, 2/3, 58/70, 2/3, 68/70);*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
|
@ -1,6 +1,6 @@
|
||||||
#!/usr/bin/env python2.5
|
#!/usr/bin/env python2.5
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
__author__ = "Soeren Apel (abraxa@dar-clan.de), fgau, Thomas Gstaedner (thomas (a) gstaedtner (.) net)"
|
__author__ = "Soeren Apel (abraxa@dar-clan.de), Frank Gau (fgau@gau-net.de), Thomas Gstaedner (thomas (a) gstaedtner (.) net)"
|
||||||
__version__ = "prototype"
|
__version__ = "prototype"
|
||||||
__copyright__ = "Copyright (c) 2008"
|
__copyright__ = "Copyright (c) 2008"
|
||||||
__license__ = "GPL3"
|
__license__ = "GPL3"
|
||||||
|
@ -20,6 +20,8 @@ EDJE_FILE_PATH = "data/themes/blackwhite/"
|
||||||
|
|
||||||
MAIN_SCREEN_NAME = "pyneo/dialer/main"
|
MAIN_SCREEN_NAME = "pyneo/dialer/main"
|
||||||
INCALL_SCREEN_NAME = "pyneo/dialer/incall"
|
INCALL_SCREEN_NAME = "pyneo/dialer/incall"
|
||||||
|
GSM_STATUS_SCREEN_NAME = "pyneo/dialer/status"
|
||||||
|
GPS_STATUS_SCREEN_NAME = "pyneo/gps/status"
|
||||||
|
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from dbus import SystemBus
|
from dbus import SystemBus
|
||||||
|
@ -59,6 +61,38 @@ class EdjeGroup(edje.Edje):
|
||||||
|
|
||||||
self.size = group_manager.get_evas().size
|
self.size = group_manager.get_evas().size
|
||||||
|
|
||||||
|
class GpsStatusScreen(EdjeGroup):
|
||||||
|
def __init__(self, screen_manager):
|
||||||
|
EdjeGroup.__init__(self, screen_manager, GPS_STATUS_SCREEN_NAME)
|
||||||
|
|
||||||
|
def register_pyneo_callbacks(self):
|
||||||
|
PyneoController.register_callback("gps_power_status", self.on_gps_power_status)
|
||||||
|
|
||||||
|
def on_gps_power_status(self, status):
|
||||||
|
if status: p_status = "on"
|
||||||
|
else: p_status = "off"
|
||||||
|
print '--- gps device is ', p_status
|
||||||
|
self.part_text_set("button_11_caption", p_status)
|
||||||
|
|
||||||
|
@edje.decorators.signal_callback("gps_send", "*")
|
||||||
|
def on_edje_signal_dialer_status_triggered(self, emission, source):
|
||||||
|
status = self.part_text_get("button_11_caption")
|
||||||
|
if source == "<":
|
||||||
|
PyneoController.show_dailer_main()
|
||||||
|
if source == "on" and status == "on": PyneoController.power_down_gps()
|
||||||
|
elif source == "on" and status == "off": PyneoController.power_up_gps()
|
||||||
|
|
||||||
|
|
||||||
|
class GsmStatusScreen(EdjeGroup):
|
||||||
|
def __init__(self, screen_manager):
|
||||||
|
EdjeGroup.__init__(self, screen_manager, GSM_STATUS_SCREEN_NAME)
|
||||||
|
|
||||||
|
@edje.decorators.signal_callback("mouse,up,1", "*")
|
||||||
|
def on_edje_signal_dialer_status_triggered(self, emission, source):
|
||||||
|
if source == "button_back_caption":
|
||||||
|
PyneoController.show_dailer_main()
|
||||||
|
print source
|
||||||
|
|
||||||
|
|
||||||
class InCallScreen(EdjeGroup):
|
class InCallScreen(EdjeGroup):
|
||||||
def __init__(self, screen_manager):
|
def __init__(self, screen_manager):
|
||||||
|
@ -166,6 +200,17 @@ class MainScreen(EdjeGroup):
|
||||||
self.text = []
|
self.text = []
|
||||||
self.look_screen = True
|
self.look_screen = True
|
||||||
self.part_text_set("numberdisplay_text", "Screen locked")
|
self.part_text_set("numberdisplay_text", "Screen locked")
|
||||||
|
elif source == "dial" and ''.join(self.text) == "1":
|
||||||
|
print '--- Gsm Status'
|
||||||
|
self.text = []
|
||||||
|
self.part_text_set("numberdisplay_text", "".join(self.text))
|
||||||
|
PyneoController.gsm_status_start()
|
||||||
|
elif source == "dial" and ''.join(self.text) == "2":
|
||||||
|
print '--- Gps Status'
|
||||||
|
self.text = []
|
||||||
|
self.part_text_set("numberdisplay_text", "".join(self.text))
|
||||||
|
PyneoController.gps_power_status()
|
||||||
|
PyneoController.gps_status_start()
|
||||||
elif source == "dial":
|
elif source == "dial":
|
||||||
PyneoController.gsm_dial("".join(self.text))
|
PyneoController.gsm_dial("".join(self.text))
|
||||||
|
|
||||||
|
@ -174,10 +219,13 @@ class PyneoController(object):
|
||||||
_dbus_timer = None
|
_dbus_timer = None
|
||||||
_gsm_timer = None
|
_gsm_timer = None
|
||||||
_keyring_timer = None
|
_keyring_timer = None
|
||||||
|
_gps_timer = None
|
||||||
_callbacks = {}
|
_callbacks = {}
|
||||||
_calls = {}
|
_calls = {}
|
||||||
|
|
||||||
gsm = None
|
gsm = None
|
||||||
|
pwr = None
|
||||||
|
gps = None
|
||||||
gsm_wireless = None
|
gsm_wireless = None
|
||||||
gsm_keyring = None
|
gsm_keyring = None
|
||||||
|
|
||||||
|
@ -208,8 +256,8 @@ class PyneoController(object):
|
||||||
try:
|
try:
|
||||||
class_.gsm = object_by_url('dbus:///org/pyneo/GsmDevice')
|
class_.gsm = object_by_url('dbus:///org/pyneo/GsmDevice')
|
||||||
class_.gsm_wireless = object_by_url(class_.gsm.GetDevice('wireless'))
|
class_.gsm_wireless = object_by_url(class_.gsm.GetDevice('wireless'))
|
||||||
|
|
||||||
class_.pwr = object_by_url('dbus:///org/pyneo/Power')
|
class_.pwr = object_by_url('dbus:///org/pyneo/Power')
|
||||||
|
class_.gps = object_by_url('dbus:///org/pyneo/GpsLocation')
|
||||||
|
|
||||||
except Exception, e:
|
except Exception, e:
|
||||||
print "Pyneo error: " + str(e)
|
print "Pyneo error: " + str(e)
|
||||||
|
@ -229,6 +277,41 @@ class PyneoController(object):
|
||||||
class_.power_up_gsm()
|
class_.power_up_gsm()
|
||||||
|
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def gps_power_status(class_):
|
||||||
|
class_.notify_callbacks("gps_power_status", class_.gps.GetPower(APP_TITLE, dbus_interface=DIN_POWERED))
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def power_up_gps(class_):
|
||||||
|
try:
|
||||||
|
if class_.gps.GetPower(APP_TITLE, dbus_interface=DIN_POWERED):
|
||||||
|
print '---', 'gps device is already on'
|
||||||
|
else:
|
||||||
|
class_.gps.SetPower(APP_TITLE, True, dbus_interface=DIN_POWERED)
|
||||||
|
print '---', 'switching gps device on'
|
||||||
|
|
||||||
|
except Exception, e:
|
||||||
|
print "GPS error: " + str(e)
|
||||||
|
if not class_._gps_timer:
|
||||||
|
class_._gps_timer = ecore.timer_add(5, class_.power_up_gps)
|
||||||
|
|
||||||
|
# We had an error, keep the timer running if we were called by ecore
|
||||||
|
return True
|
||||||
|
|
||||||
|
# No error (anymore)
|
||||||
|
if class_._gps_timer: class_._gps_timer.stop()
|
||||||
|
|
||||||
|
class_.notify_callbacks("gps_power_status", class_.gps.GetPower(APP_TITLE, dbus_interface=DIN_POWERED))
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def power_down_gps(class_):
|
||||||
|
class_.gps.SetPower(APP_TITLE, False, dbus_interface=DIN_POWERED)
|
||||||
|
class_.notify_callbacks("gps_power_status", class_.gps.GetPower(APP_TITLE, dbus_interface=DIN_POWERED))
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def power_status_gsm(class_):
|
||||||
|
return class_.gsm.GetPower(APP_TITLE, dbus_interface=DIN_POWERED)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def power_up_gsm(class_):
|
def power_up_gsm(class_):
|
||||||
try:
|
try:
|
||||||
|
@ -236,7 +319,7 @@ class PyneoController(object):
|
||||||
print '---', 'gsm device is already on'
|
print '---', 'gsm device is already on'
|
||||||
else:
|
else:
|
||||||
class_.gsm.SetPower(APP_TITLE, True, dbus_interface=DIN_POWERED)
|
class_.gsm.SetPower(APP_TITLE, True, dbus_interface=DIN_POWERED)
|
||||||
print '---', 'switching device on'
|
print '---', 'switching gsm device on'
|
||||||
|
|
||||||
except Exception, e:
|
except Exception, e:
|
||||||
print "GSM error: " + str(e)
|
print "GSM error: " + str(e)
|
||||||
|
@ -360,13 +443,25 @@ class PyneoController(object):
|
||||||
|
|
||||||
if status["code"] == "READY":
|
if status["code"] == "READY":
|
||||||
class_.notify_callbacks("sim_ready")
|
class_.notify_callbacks("sim_ready")
|
||||||
|
|
||||||
# Try registering on the network
|
# Try registering on the network
|
||||||
class_.gsm_wireless.Register(dbus_interface=DIN_WIRELESS)
|
class_.gsm_wireless.Register(dbus_interface=DIN_WIRELESS)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
class_.notify_callbacks("sim_key_required", status["code"])
|
class_.notify_callbacks("sim_key_required", status["code"])
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def gsm_status_start(class_):
|
||||||
|
class_.notify_callbacks("gsm_status_start")
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def gps_status_start(class_):
|
||||||
|
class_.notify_callbacks("gps_status_start")
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def show_dailer_main(class_):
|
||||||
|
class_.notify_callbacks("show_dialer_main")
|
||||||
|
|
||||||
|
|
||||||
class Dialer(object):
|
class Dialer(object):
|
||||||
screens = None
|
screens = None
|
||||||
|
@ -382,6 +477,8 @@ class Dialer(object):
|
||||||
|
|
||||||
self.init_screen(MAIN_SCREEN_NAME, MainScreen(self))
|
self.init_screen(MAIN_SCREEN_NAME, MainScreen(self))
|
||||||
self.init_screen(INCALL_SCREEN_NAME, InCallScreen(self))
|
self.init_screen(INCALL_SCREEN_NAME, InCallScreen(self))
|
||||||
|
self.init_screen(GSM_STATUS_SCREEN_NAME, GsmStatusScreen(self))
|
||||||
|
self.init_screen(GPS_STATUS_SCREEN_NAME, GpsStatusScreen(self))
|
||||||
|
|
||||||
self.screens[MAIN_SCREEN_NAME].part_text_set("numberdisplay_text", "wait ...")
|
self.screens[MAIN_SCREEN_NAME].part_text_set("numberdisplay_text", "wait ...")
|
||||||
|
|
||||||
|
@ -396,6 +493,9 @@ class Dialer(object):
|
||||||
PyneoController.register_callback("gsm_phone_ringing", self.on_ringing)
|
PyneoController.register_callback("gsm_phone_ringing", self.on_ringing)
|
||||||
PyneoController.register_callback("gsm_phone_call_start", self.on_call_start)
|
PyneoController.register_callback("gsm_phone_call_start", self.on_call_start)
|
||||||
PyneoController.register_callback("gsm_phone_call_end", self.on_call_end)
|
PyneoController.register_callback("gsm_phone_call_end", self.on_call_end)
|
||||||
|
PyneoController.register_callback("gsm_status_start", self.on_gsm_status_start)
|
||||||
|
PyneoController.register_callback("gps_status_start", self.on_gps_status_start)
|
||||||
|
PyneoController.register_callback("show_dialer_main", self.on_call_end)
|
||||||
|
|
||||||
def init_screen(self, screen_name, instance):
|
def init_screen(self, screen_name, instance):
|
||||||
self.screens[screen_name] = instance
|
self.screens[screen_name] = instance
|
||||||
|
@ -426,6 +526,12 @@ class Dialer(object):
|
||||||
def on_call_end(self):
|
def on_call_end(self):
|
||||||
self.show_screen(MAIN_SCREEN_NAME)
|
self.show_screen(MAIN_SCREEN_NAME)
|
||||||
|
|
||||||
|
def on_gsm_status_start(self):
|
||||||
|
self.show_screen(GSM_STATUS_SCREEN_NAME)
|
||||||
|
|
||||||
|
def on_gps_status_start(self):
|
||||||
|
self.show_screen(GPS_STATUS_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