diff options
| author | Javier S. Pedro <maemo@javispedro.com> | 2011-09-25 01:36:10 +0200 | 
|---|---|---|
| committer | Javier S. Pedro <maemo@javispedro.com> | 2011-09-25 01:36:10 +0200 | 
| commit | 2b4e878938215ac743bdc36deace4c2a4cb0c7a2 (patch) | |
| tree | b2b8341615898e5cbf5cdb08ee34a629df093897 | |
| parent | 5153fb9a2b5d8a7af069a75b75bdc7bee591d0a9 (diff) | |
| download | sowatch-2b4e878938215ac743bdc36deace4c2a4cb0c7a2.tar.gz sowatch-2b4e878938215ac743bdc36deace4c2a4cb0c7a2.zip | |
preparing for watchlet support
| -rw-r--r-- | ckitcallnotification/ckitcallprovider.cpp | 8 | ||||
| -rw-r--r-- | libsowatch/libsowatch.pro | 8 | ||||
| -rw-r--r-- | libsowatch/sowatch.h | 1 | ||||
| -rw-r--r-- | libsowatch/watch.h | 33 | ||||
| -rw-r--r-- | libsowatch/watchletplugininterface.cpp | 7 | ||||
| -rw-r--r-- | libsowatch/watchletplugininterface.h | 28 | ||||
| -rw-r--r-- | libsowatch/watchserver.cpp | 81 | ||||
| -rw-r--r-- | libsowatch/watchserver.h | 11 | ||||
| -rw-r--r-- | metawatch/metawatch.cpp | 202 | ||||
| -rw-r--r-- | metawatch/metawatch.h | 77 | ||||
| -rw-r--r-- | metawatch/metawatchplugin.cpp | 2 | ||||
| -rw-r--r-- | metawatch/metawatchplugin.h | 2 | ||||
| -rw-r--r-- | sowatch.pro | 2 | ||||
| -rw-r--r-- | sowatchd/daemon.cpp | 31 | 
14 files changed, 390 insertions, 103 deletions
| diff --git a/ckitcallnotification/ckitcallprovider.cpp b/ckitcallnotification/ckitcallprovider.cpp index adcb6d5..90dab97 100644 --- a/ckitcallnotification/ckitcallprovider.cpp +++ b/ckitcallnotification/ckitcallprovider.cpp @@ -21,9 +21,17 @@ CKitCallProvider::~CKitCallProvider()  void CKitCallProvider::activeCallChanged()  {  	QVariantMap info = _activeCall->value().toMap(); +	qDebug() << "active call changed" << info; +	if (!info.contains("state")) { +		qWarning() << "broken active call context property"; +	}  	int state = info["state"].toInt();  	if (state == 0) {  		QString displayName = info["displayName"].toString(); +		if (displayName.isEmpty()) { +			// Ignore call until display name is not empty. +			return; +		}  		// "Incoming call"  		if (_notification) {  			_notification->changeDisplayName(displayName); diff --git a/libsowatch/libsowatch.pro b/libsowatch/libsowatch.pro index aefdadd..44458c2 100644 --- a/libsowatch/libsowatch.pro +++ b/libsowatch/libsowatch.pro @@ -27,7 +27,8 @@ SOURCES += \      watchplugininterface.cpp \      notification.cpp \      notificationplugininterface.cpp \ -    notificationprovider.cpp +    notificationprovider.cpp \ +    watchletplugininterface.cpp  HEADERS +=\      watchsimulator.h \ @@ -45,7 +46,8 @@ HEADERS +=\      watchplugininterface.h \      notification.h \      notificationplugininterface.h \ -    notificationprovider.h +    notificationprovider.h \ +    watchletplugininterface.h  install_headers.files = $$HEADERS @@ -89,3 +91,5 @@ unix:!symbian { + + diff --git a/libsowatch/sowatch.h b/libsowatch/sowatch.h index e294ece..d8844bc 100644 --- a/libsowatch/sowatch.h +++ b/libsowatch/sowatch.h @@ -15,5 +15,6 @@  #include "watchlet.h"  #include "graphicswatchlet.h"  #include "declarativewatchlet.h" +#include "watchletplugininterface.h"  #endif // SOWATCH_H diff --git a/libsowatch/watch.h b/libsowatch/watch.h index eabfa06..ee9bde7 100644 --- a/libsowatch/watch.h +++ b/libsowatch/watch.h @@ -3,6 +3,7 @@  #include <QtCore/QObject>  #include <QtCore/QDateTime> +#include <QtCore/QStringList>  #include <QtGui/QPaintDevice>  #include <QtGui/QImage>  #include "notification.h" @@ -21,18 +22,34 @@ public:  	explicit Watch(QObject* parent = 0);  	~Watch(); -	/** Return a string identiyfying this watch's model. */ +	/** Return a string identifying this watch's model. */  	virtual QString model() const = 0; + +	/** Names for all the buttons this watch has. Order is important. */ +	virtual QStringList buttons() const = 0; +  	/** Should return true if the watch is connected. */  	virtual bool isConnected() const = 0; -  	/** Indicates if watch is too busy atm and we should limit frame rate. */  	virtual bool busy() const = 0; -	/** Changes the current date/time on the watch. */ +	/** Gets the current date/time on the watch. */  	virtual QDateTime dateTime() = 0; +	/** Sets the current date/time on the watch. */  	virtual void setDateTime(const QDateTime& dateTime) = 0; +	/** Go back to the idle screen. */ +	virtual void displayIdleScreen() = 0; +	/** A standard notification; it's up to the watch when to stop showing it. */ +	virtual void displayNotification(Notification* n) = 0; +	/** Enter application mode. */ +	virtual void displayApplication() = 0; + +	/** Grabs a button from whatever is default function is for the current mode. */ +	virtual void grabButton(int button) = 0; +	/** Restores a button to its default function. */ +	virtual void ungrabButton(int button) = 0; +  	/** Tells the watch to update the unread notifications count, if visible. */  	virtual void updateNotificationCount(Notification::Type type, int count) = 0; @@ -43,16 +60,10 @@ signals:  	void disconnected();  	/** The watch has returned to the idle screen by either inactivity or notification cleared/timeout. */  	void idling(); +	/** A button has been pressed. */  	void buttonPressed(int button); +	/** A button has been pressed and then released. */  	void buttonReleased(int button); - -public slots: -	/** Go back to the idle screen. */ -	virtual void displayIdleScreen() = 0; -	/** A standard notification; it's up to the watch when to stop showing it. */ -	virtual void displayNotification(Notification* n) = 0; -	/** Enter application mode. */ -	virtual void displayApplication() = 0;  };  } diff --git a/libsowatch/watchletplugininterface.cpp b/libsowatch/watchletplugininterface.cpp new file mode 100644 index 0000000..c575236 --- /dev/null +++ b/libsowatch/watchletplugininterface.cpp @@ -0,0 +1,7 @@ +#include "watchletplugininterface.h" + +using namespace sowatch; + +WatchletPluginInterface::~WatchletPluginInterface() +{ +} diff --git a/libsowatch/watchletplugininterface.h b/libsowatch/watchletplugininterface.h new file mode 100644 index 0000000..ad83dd4 --- /dev/null +++ b/libsowatch/watchletplugininterface.h @@ -0,0 +1,28 @@ +#ifndef SOWATCH_WATCHLETPLUGININTERFACE_H +#define SOWATCH_WATCHLETPLUGININTERFACE_H + +#include <QtPlugin> +#include <QtCore/QSettings> +#include <QtCore/QStringList> +#include "sowatch_global.h" + +namespace sowatch +{ + +class Watchlet; +class WatchServer; + +class SOWATCH_EXPORT WatchletPluginInterface +{ +public: +	virtual ~WatchletPluginInterface(); + +	virtual QStringList watchlets() = 0; +	virtual Watchlet* getProvider(const QString& id, QSettings& settings, WatchServer *server) = 0; +}; + +} + +Q_DECLARE_INTERFACE(sowatch::WatchletPluginInterface, "com.javispedro.sowatch.WatchletPluginInterface") + +#endif // SOWATCH_WATCHLETPLUGININTERFACE_H diff --git a/libsowatch/watchserver.cpp b/libsowatch/watchserver.cpp index d95d4fb..39802f9 100644 --- a/libsowatch/watchserver.cpp +++ b/libsowatch/watchserver.cpp @@ -9,11 +9,14 @@  using namespace sowatch;  WatchServer::WatchServer(Watch* watch, QObject* parent) : -	QObject(parent), _watch(watch), _currentWatchlet(0) +	QObject(parent), _watch(watch), +	_nextWatchletButton(-1), +	_currentWatchlet(0), _currentWatchletIndex(-1)  {  	connect(_watch, SIGNAL(connected()), SLOT(watchConnected()));  	connect(_watch, SIGNAL(disconnected()), SLOT(watchDisconnected()));  	connect(_watch, SIGNAL(idling()), SLOT(watchIdling())); +	connect(_watch, SIGNAL(buttonPressed(int)), SLOT(watchButtonPress(int)));  }  Watch* WatchServer::watch() @@ -21,6 +24,27 @@ Watch* WatchServer::watch()  	return _watch;  } +QString WatchServer::nextWatchletButton() const +{ +	if (_nextWatchletButton >= 0) { +		return _watch->buttons().at(_nextWatchletButton); +	} else { +		return QString(); +	} +} + +void WatchServer::setNextWatchletButton(const QString& value) +{ +	if (value.isEmpty()) { +		_nextWatchletButton = -1; +		return; +	} +	_nextWatchletButton = _watch->buttons().indexOf(value); +	if (_nextWatchletButton < 0) { +		qWarning() << "Invalid watch button" << value; +	} +} +  void WatchServer::addProvider(NotificationProvider *provider)  {  	provider->setParent(this); @@ -33,6 +57,7 @@ void WatchServer::runWatchlet(const QString& id)  	if (_currentWatchlet) {  		closeWatchlet();  	} +	qDebug() << "activating watchlet" << id;  	_currentWatchlet = _watchlets[id];  	if (_watch->isConnected()) {  		reactivateCurrentWatchlet(); @@ -41,11 +66,15 @@ void WatchServer::runWatchlet(const QString& id)  void WatchServer::closeWatchlet()  { -	Q_ASSERT(_currentWatchlet != 0); -	if (_watch->isConnected()) { -		_currentWatchlet->deactivate(); +	if (_currentWatchlet) { +		if (_watch->isConnected()) { +			_currentWatchlet->deactivate(); +		} +		_currentWatchlet = 0; +		if (_pendingNotifications.empty()) { +			goToIdle(); +		}  	} -	_currentWatchlet = 0;  }  void WatchServer::registerWatchlet(Watchlet *watchlet) @@ -61,6 +90,20 @@ void WatchServer::reactivateCurrentWatchlet()  	_currentWatchlet->activate();  } +void WatchServer::nextWatchlet() +{ +	QStringList watchlets = _watchlets.keys(); +	_currentWatchletIndex++; +	qDebug() << "next watchlet" << _currentWatchletIndex; +	if (_currentWatchletIndex >= watchlets.size()) { +		_currentWatchletIndex = -1; +		closeWatchlet(); +	} else { +		QString watchlet = watchlets.at(_currentWatchletIndex); +		runWatchlet(watchlet); +	} +} +  void WatchServer::nextNotification()  {  	if (!_watch->isConnected()) return; @@ -70,7 +113,7 @@ void WatchServer::nextNotification()  	} else if (_currentWatchlet) {  		reactivateCurrentWatchlet();  	} else { -		_watch->displayIdleScreen(); +		goToIdle();  	}  } @@ -83,12 +126,22 @@ uint WatchServer::getNotificationCount(Notification::Type type)  	return count;  } +void WatchServer::goToIdle() +{ +	_watch->displayIdleScreen(); +	if (_nextWatchletButton >= 0) { +		_watch->grabButton(_nextWatchletButton); +	} +} +  void WatchServer::watchConnected()  {  	if (!_pendingNotifications.isEmpty()) {  		nextNotification();  	} else if (_currentWatchlet) {  		reactivateCurrentWatchlet(); +	} else { +		goToIdle();  	}  } @@ -102,13 +155,27 @@ void WatchServer::watchDisconnected()  void WatchServer::watchIdling()  { -	qDebug() << "Watch idling"; +	qDebug() << "watch idling";  	if (!_pendingNotifications.empty()) {  		_pendingNotifications.dequeue();  		nextNotification();  	}  } +void WatchServer::watchButtonPress(int button) +{ +	if (button == _nextWatchletButton) { +		if (_pendingNotifications.empty()) { +			// No notifications: either app or idle mode. +			nextWatchlet(); +		} else { +			// Skip to next notification if any +			_pendingNotifications.dequeue(); +			nextNotification(); +		} +	} +} +  void WatchServer::notificationReceived(Notification *notification)  {  	const Notification::Type type = notification->type(); diff --git a/libsowatch/watchserver.h b/libsowatch/watchserver.h index 1ece104..681c758 100644 --- a/libsowatch/watchserver.h +++ b/libsowatch/watchserver.h @@ -19,12 +19,16 @@ class SOWATCH_EXPORT WatchServer : public QObject  {      Q_OBJECT  	Q_PROPERTY(Watch* watch READ watch CONSTANT) +	Q_PROPERTY(QString nextWatchletButton READ nextWatchletButton WRITE setNextWatchletButton)  public:  	explicit WatchServer(Watch* watch, QObject* parent = 0);  	Watch* watch(); +	QString nextWatchletButton() const; +	void setNextWatchletButton(const QString& value); +  	void addProvider(NotificationProvider* provider);  	void runWatchlet(const QString& id); @@ -33,6 +37,8 @@ public:  protected:  	Watch* _watch; +	char _nextWatchletButton; +  	QMap<QString, Watchlet*> _watchlets;  	/** Stores current notifications, classified by type. */ @@ -40,17 +46,22 @@ protected:  	QQueue<Notification*> _pendingNotifications;  	Watchlet* _currentWatchlet; +	char _currentWatchletIndex;  	void registerWatchlet(Watchlet *watchlet);  	void reactivateCurrentWatchlet(); +	void nextWatchlet();  	void nextNotification();  	uint getNotificationCount(Notification::Type type); +	void goToIdle(); +  protected slots:  	void watchConnected();  	void watchDisconnected();  	void watchIdling(); +	void watchButtonPress(int button);  	void notificationReceived(Notification* notification);  	void notificationChanged();  	void notificationCleared(); diff --git a/metawatch/metawatch.cpp b/metawatch/metawatch.cpp index 5e6a8fb..a429083 100644 --- a/metawatch/metawatch.cpp +++ b/metawatch/metawatch.cpp @@ -9,6 +9,13 @@ QTM_USE_NAMESPACE  #define SINGLE_LINE_UPDATE 0 +const char MetaWatch::watchToBtn[8] = { +	0, 1, 2, 3, -1, 4, 5, -1 +}; +const char MetaWatch::btnToWatch[8] = { +	0, 1, 2, 3, 5, 6, -1, -1 +}; +  const int MetaWatch::connectRetryTimes[] = {  	5, 10, 30, 60, 120, 300  }; @@ -74,21 +81,17 @@ const quint16 MetaWatch::crcTable[256] = {  	}  #endif -MetaWatch::MetaWatch(const QBluetoothAddress& address, QObject *parent) : +MetaWatch::MetaWatch(const QBluetoothAddress& address, QSettings* settings, QObject* parent) :  	Watch(parent), +	_nMails(0), _nCalls(0), _nIms(0), _nSms(0), _nMms(0), +	_idleTimer(new QTimer(this)), _ringTimer(new QTimer(this)), +	_currentMode(IdleMode),	_paintMode(IdleMode),  	_paintEngine(0), -	_address(address), -	_socket(0), -	_24hMode(true), _dayMonthOrder(true), _notificationTimeout(10), -	_connectRetries(0), -	_connected(false), +	_connectRetries(0),	_connected(false),  	_connectTimer(new QTimer(this)),  	_connectAlignedTimer(new QSystemAlignedTimer(this)), -	_sendTimer(new QTimer(this)), -	_currentMode(IdleMode), -	_paintMode(IdleMode), -	_nMails(0), _nCalls(0), _nIms(0), _nSms(0), _nMms(0), -	_idleTimer(new QTimer(this)), _ringTimer(new QTimer(this)) +	_address(address), _socket(0), +	_sendTimer(new QTimer(this))  {  	QImage baseImage(screenWidth, screenHeight, QImage::Format_MonoLSB);  	baseImage.setColor(0, QColor(Qt::white).rgb()); @@ -97,13 +100,13 @@ MetaWatch::MetaWatch(const QBluetoothAddress& address, QObject *parent) :  	_image[ApplicationMode] = baseImage;  	_image[NotificationMode] = baseImage; -	_connectTimer->setSingleShot(true); -	_connectAlignedTimer->setSingleShot(true); -	connect(_connectTimer, SIGNAL(timeout()), SLOT(retryConnect())); -	connect(_connectAlignedTimer, SIGNAL(timeout()), SLOT(retryConnect())); +	_buttonNames << "A" << "B" << "C" << "D" << "E" << "F"; -	_sendTimer->setInterval(10); -	connect(_sendTimer, SIGNAL(timeout()), SLOT(timedSend())); +	if (settings) { +		_24hMode = settings->value("24hMode", false).toBool(); +		_dayMonthOrder = settings->value("DayMonthOrder", false).toBool(); +		_notificationTimeout = settings->value("NotificationTimeout", 10).toInt(); +	}  	_idleTimer->setInterval(_notificationTimeout * 1000);  	_idleTimer->setSingleShot(true); @@ -112,6 +115,14 @@ MetaWatch::MetaWatch(const QBluetoothAddress& address, QObject *parent) :  	_ringTimer->setInterval(2000);  	connect(_ringTimer, SIGNAL(timeout()), SLOT(timedRing())); +	_connectTimer->setSingleShot(true); +	_connectAlignedTimer->setSingleShot(true); +	connect(_connectTimer, SIGNAL(timeout()), SLOT(retryConnect())); +	connect(_connectAlignedTimer, SIGNAL(timeout()), SLOT(retryConnect())); + +	_sendTimer->setInterval(10); +	connect(_sendTimer, SIGNAL(timeout()), SLOT(timedSend())); +  	retryConnect();  } @@ -161,6 +172,11 @@ QString MetaWatch::model() const  	return "metawatch-digital";  } +QStringList MetaWatch::buttons() const +{ +	return _buttonNames; +} +  bool MetaWatch::isConnected() const  {  	return _connected; @@ -199,32 +215,6 @@ void MetaWatch::setDateTime(const QDateTime &dateTime)  	send(msg);  } -void MetaWatch::updateNotificationCount(Notification::Type type, int count) -{ -	switch (type) { -	case Notification::MissedCallNotification: -		_nCalls = count; -		break; -	case Notification::EmailNotification: -		_nMails = count; -		break; -	case Notification::ImNotification: -		_nIms = count; -		break; -	case Notification::SmsNotification: -		_nSms = count; -		break; -	case Notification::MmsNotification: -		_nMms = count; -		break; -	default: -		// Ignore -		break; -	} - -	renderIdleCounts(); -} -  void MetaWatch::displayIdleScreen()  {  	_currentMode = IdleMode; @@ -234,7 +224,6 @@ void MetaWatch::displayIdleScreen()  	updateDisplay(IdleMode);  	// Usually, idle screen is kept updated, so we can show it already.  	qDebug() << "displayIdle"; -  }  void MetaWatch::displayNotification(Notification *n) @@ -313,6 +302,42 @@ void MetaWatch::displayApplication()  	qDebug() << "displayApplication";  } +void MetaWatch::grabButton(int button) +{ +	grabButton(_currentMode, (Button) button); +} + +void MetaWatch::ungrabButton(int button) +{ +	ungrabButton(_currentMode, (Button) button); +} + +void MetaWatch::updateNotificationCount(Notification::Type type, int count) +{ +	switch (type) { +	case Notification::MissedCallNotification: +		_nCalls = count; +		break; +	case Notification::EmailNotification: +		_nMails = count; +		break; +	case Notification::ImNotification: +		_nIms = count; +		break; +	case Notification::SmsNotification: +		_nSms = count; +		break; +	case Notification::MmsNotification: +		_nMms = count; +		break; +	default: +		// Ignore +		break; +	} + +	renderIdleCounts(); +} +  MetaWatch::Mode MetaWatch::currentMode() const  {  	return _currentMode; @@ -353,6 +378,18 @@ void MetaWatch::clear(Mode mode, bool black)  	loadTemplate(mode, black ? 1 : 0);  } +void MetaWatch::grabButton(Mode mode, Button button) +{ +	enableButton(mode, button, PressOnly); +	enableButton(mode, button, PressAndRelease); +} + +void MetaWatch::ungrabButton(Mode mode, Button button) +{ +	disableButton(mode, button, PressOnly); +	disableButton(mode, button, PressAndRelease); +} +  void MetaWatch::renderIdleScreen()  {  	QImage idle_call(QString(":/metawatch/graphics/idle_call.bmp")); @@ -602,19 +639,66 @@ void MetaWatch::loadTemplate(Mode mode, int templ)  	send(msg);  } +void MetaWatch::enableButton(Mode mode, Button button, ButtonPress press) +{ +	Message msg(EnableButton, QByteArray(5, 0)); + +	Q_ASSERT(button >= 0 && button < 8); + +	msg.data[0] = mode; +	msg.data[1] = btnToWatch[button]; +	msg.data[2] = press; +	msg.data[3] = ButtonEvent; +	msg.data[4] = 0x80 | ((press << 4) & 0x30) | (button & 0xF); + +	send(msg); +} + +void MetaWatch::disableButton(Mode mode, Button button, ButtonPress press) +{ +	Message msg(DisableButton, QByteArray(3, 0)); + +	Q_ASSERT(button >= 0 && button < 8); + +	msg.data[0] = mode; +	msg.data[1] = btnToWatch[button]; +	msg.data[2] = press; + +	send(msg); +} +  void MetaWatch::handleStatusChange(const Message &msg)  { -	qDebug() << "watch status changed" << msg.options << msg.data.at(0); +	QString s; +	qDebug() << "watch status changed" << s.sprintf("0x%hx", msg.options) << s.sprintf("0x%hx", msg.data.at(0));  }  void MetaWatch::handleButtonEvent(const Message &msg)  { -	if (msg.data.size() < 1) return; -	quint8 button = msg.data[0]; +	if (!(msg.options & 0x80)) { +		// We didn't configure this button, reject. +		return; +	} + +	quint8 watchBtn = msg.options & 0xF; +	ButtonPress press = (ButtonPress) ((msg.options & 0x30) >> 4); +	int button = -1; -	qDebug() << "button event" << msg.data.size() << msg.options << msg.data.at(0); +	if (watchBtn < 8) { +		button = watchToBtn[watchBtn]; +	} +	if (button == -1) { +		qWarning() << "Unknown watch button" << watchBtn; +		return; +	} + +	qDebug() << "button event" << button << press; -	emit buttonPressed(button); // TODO This is completely broken +	if (press == PressOnly) { +		emit buttonPressed(button); +	} else if (press == PressAndRelease) { +		emit buttonReleased(button); +	}  }  void MetaWatch::socketConnected() @@ -628,11 +712,23 @@ void MetaWatch::socketConnected()  		_partialReceived.data.clear();  		_currentMode = IdleMode;  		_paintMode = IdleMode; -		_buttonState = 0;  		setDateTime(QDateTime::currentDateTime());  		configureIdleSystemArea(false); +		grabButton(ApplicationMode, BtnA); +		grabButton(ApplicationMode, BtnB); +		grabButton(ApplicationMode, BtnC); +		grabButton(ApplicationMode, BtnD); +		grabButton(ApplicationMode, BtnE); +		grabButton(ApplicationMode, BtnF); +		grabButton(NotificationMode, BtnA); +		grabButton(NotificationMode, BtnB); +		grabButton(NotificationMode, BtnC); +		grabButton(NotificationMode, BtnD); +		grabButton(NotificationMode, BtnE); +		grabButton(NotificationMode, BtnF); +  		renderIdleScreen();  		renderNotificationScreen(); @@ -673,12 +769,14 @@ void MetaWatch::socketData()  	qint64 dataRead;  	if (_partialReceived.type == 0) { +		/* Still not received even the packet type */ +		/* Receive the full header, 4 bytes. */  		if (_socket->bytesAvailable() < 4) return; /* Wait for more. */  		char header[4];  		dataRead = _socket->read(header, 4);  		if (dataRead < 4 || header[0] != 0x01) { -			qWarning() << "TODO: Resync/Handle Garbage"; +			qWarning() << "TODO: Resync / Handle Garbage";  			return;  		} @@ -686,6 +784,8 @@ void MetaWatch::socketData()  		_partialReceived.data.resize(header[1] - 6);  		_partialReceived.options = header[3];  	} + +	/* Got the header; now, try to get the complete packet. */  	if (_socket->bytesAvailable() < _partialReceived.data.size() + 2) {  		return; /* Wait for more. */  	} diff --git a/metawatch/metawatch.h b/metawatch/metawatch.h index da0f323..0a9123a 100644 --- a/metawatch/metawatch.h +++ b/metawatch/metawatch.h @@ -3,6 +3,7 @@  #include <QtCore/QQueue>  #include <QtCore/QTimer> +#include <QtCore/QSettings>  #include <QtConnectivity/QBluetoothAddress>  #include <QtConnectivity/QBluetoothSocket>  #include <QtSystemInfo/QSystemAlignedTimer> @@ -20,10 +21,9 @@ class MetaWatchPaintEngine;  class MetaWatch : public Watch  {      Q_OBJECT -	Q_ENUMS(MessageType Mode)  public: -	explicit MetaWatch(const QBluetoothAddress& address, QObject *parent = 0); +	explicit MetaWatch(const QBluetoothAddress& address, QSettings* settings = 0, QObject *parent = 0);  	~MetaWatch();  	static const int screenWidth = 96; @@ -66,28 +66,49 @@ public:  		NotificationMode = 2  	}; +	enum Button { +		BtnA = 0, +		BtnB, +		BtnC, +		BtnD, +		BtnE, +		BtnF +	}; + +	enum ButtonPress { +		PressOnly = 0, +		PressAndRelease = 1, +		HoldAndRelease = 2, +		LongHoldAndRelease = 3 +	}; +  	QPaintEngine* paintEngine() const;  	int metric(PaintDeviceMetric metric) const;  	QString model() const; +	QStringList buttons() const;  	bool isConnected() const;  	bool busy() const;  	QDateTime dateTime();  	void setDateTime(const QDateTime& dateTime); -	void updateNotificationCount(Notification::Type type, int count); -  	void displayIdleScreen();  	void displayNotification(Notification *n);  	void displayApplication(); +	void grabButton(int button); +	void ungrabButton(int button); + +	void updateNotificationCount(Notification::Type type, int count);  	Mode currentMode() const;  	Mode paintTargetMode() const;  	QImage* imageFor(Mode mode);  	void clear(Mode mode, bool black = false);  	void update(Mode mode, const QList<QRect>& rects = QList<QRect>()); +	void grabButton(Mode mode, Button button); +	void ungrabButton(Mode mode, Button button);  	void renderIdleScreen();  	void renderIdleWeather(); @@ -97,18 +118,32 @@ public:  	QImage iconForNotification(const Notification *n);  protected: -	mutable MetaWatchPaintEngine* _paintEngine; -	QImage _image[3]; - -	QBluetoothAddress _address; -	QBluetoothSocket* _socket; - -	/* Some configurable stuff. */ +	// Some configurable stuff.  	bool _24hMode : 1;  	bool _dayMonthOrder : 1; -  	short _notificationTimeout; +	// Notifications: Unread count +	uint _nMails, _nCalls, _nIms, _nSms, _nMms; + +	// Notifications: timers +	QTimer* _idleTimer; +	QTimer* _ringTimer; + +	// Buttons +	static const char watchToBtn[8]; +	static const char btnToWatch[8]; +	QStringList _buttonNames; + +	// Current watch state +	Mode _currentMode; +	Mode _paintMode; + +	// For QPaintDevice +	mutable MetaWatchPaintEngine* _paintEngine; +	QImage _image[3]; + +	// Timers to retry the connection when the watch is not found.  	static const int connectRetryTimesSize = 6;  	static const int connectRetryTimes[connectRetryTimesSize];  	short _connectRetries; @@ -116,6 +151,11 @@ protected:  	QTimer* _connectTimer;  	QSystemAlignedTimer* _connectAlignedTimer; +	// Connection stuff +	QBluetoothAddress _address; +	QBluetoothSocket* _socket; + +	// Base watch protocol stuff  	struct Message {  		MessageType type;  		quint8 options; @@ -129,17 +169,6 @@ protected:  	QTimer* _sendTimer;  	Message _partialReceived; -	Mode _currentMode; -	Mode _paintMode; -	quint8 _buttonState; - -	// Notifications: Unread count -	uint _nMails, _nCalls, _nIms, _nSms, _nMms; - -	// Notifications: timers -	QTimer* _idleTimer; -	QTimer* _ringTimer; -  	static const quint8 bitRevTable[16];  	static const quint16 crcTable[256];  	quint16 calcCrc(const QByteArray& data, int size); @@ -156,6 +185,8 @@ protected:  	void configureIdleSystemArea(bool entireScreen);  	void updateDisplay(Mode mode, bool copy = true);  	void loadTemplate(Mode mode, int templ); +	void enableButton(Mode mode, Button button, ButtonPress press); +	void disableButton(Mode mode, Button button, ButtonPress press);  	void handleStatusChange(const Message& msg);  	void handleButtonEvent(const Message& msg); diff --git a/metawatch/metawatchplugin.cpp b/metawatch/metawatchplugin.cpp index 6a97297..23a4f63 100644 --- a/metawatch/metawatchplugin.cpp +++ b/metawatch/metawatchplugin.cpp @@ -36,7 +36,7 @@ Watch* MetaWatchPlugin::getWatch(const QString& driver, QSettings& settings, QOb  {  	if (driver == "metawatch-digital") {  		QBluetoothAddress address(settings.value("address").toString()); -		return new MetaWatch(address, parent); +		return new MetaWatch(address, &settings, parent);  	} else {  		return 0;  	} diff --git a/metawatch/metawatchplugin.h b/metawatch/metawatchplugin.h index 57b1029..6834247 100644 --- a/metawatch/metawatchplugin.h +++ b/metawatch/metawatchplugin.h @@ -15,7 +15,7 @@ public:  	~MetaWatchPlugin();  	virtual QStringList drivers(); -	virtual Watch* getWatch(const QString& driver, QSettings& settings, QObject *parent = 0); +	virtual Watch* getWatch(const QString& driver, QSettings& settings, QObject* parent = 0);  protected:  	static bool fontsLoaded; diff --git a/sowatch.pro b/sowatch.pro index 0402176..db0228b 100644 --- a/sowatch.pro +++ b/sowatch.pro @@ -4,7 +4,7 @@ SUBDIRS = libsowatch \  	sowatchd  !isEmpty(MEEGO_VERSION_MAJOR) { -	SUBDIRS += meegohandsetnotification ckitcallnotification +	#SUBDIRS += meegohandsetnotification ckitcallnotification  }  unix:!symbian { diff --git a/sowatchd/daemon.cpp b/sowatchd/daemon.cpp index 645ecf6..26cbad0 100644 --- a/sowatchd/daemon.cpp +++ b/sowatchd/daemon.cpp @@ -3,6 +3,7 @@  #include <QtCore/QSettings>  #include <QtCore/QDir>  #include <sowatch.h> +#include <testwatchlet.h>  #include "daemon.h"  using namespace sowatch; @@ -108,6 +109,9 @@ void Daemon::initWatch(Watch* watch, QSettings& settings)  	WatchServer* server = new WatchServer(watch, this);  	_servers.append(server); +	// Configure the server +	server->setNextWatchletButton(settings.value("nextWatchletButton").toString()); +  	// Initialize providers  	size = settings.beginReadArray("notifications");  	for (int i = 0; i < size; i++) { @@ -120,25 +124,40 @@ void Daemon::initWatch(Watch* watch, QSettings& settings)  		}  	} +	// Initialize test watchlets +	new TestWatchlet(server); +  	settings.endArray();  }  void Daemon::loadWatchlets()  { -#if 0  	QDir dir(SOWATCH_WATCHLETS_DIR);  	foreach (QString file, dir.entryList(QDir::Files)) { +#if defined(Q_OS_UNIX) +		// Temporary workaround for QtC deploy plugin issues +		if (!file.endsWith(".so")) continue; +#endif  		QPluginLoader loader(dir.absoluteFilePath(file));  		QObject *pluginObj = loader.instance();  		if (pluginObj) { -			WatchPluginInterface *plugin = qobject_cast<WatchPluginInterface*>(pluginObj); +#if 0 +			WatchletPluginInterface *plugin = qobject_cast<WatchletPluginInterface*>(pluginObj);  			if (plugin) { -				QStringList drivers = plugin->drivers(); -				foreach (const QString& driver, drivers) { -					_drivers[driver] = plugin; +				QStringList providers = plugin->providers(); +				foreach (const QString& provider, providers) { +					_providers[provider] = plugin;  				} +			} else { +				qWarning() << "Invalid plugin" << file; +				loader.unload();  			} +#endif +		} else { +			qWarning() << "Invalid plugin" << file << loader.errorString(); +			loader.unload();  		}  	} -#endif + +	qDebug() << "loaded watchlets";  } | 
