Я пытаюсь разработать какую-нибудь программу на QT с помощью QT SDK. Вчера я читал о Unity Launcher API на официальном сайте Ubuntu. Но есть пример только для Vala и Python. Можно использовать Unity Launcher API (быстрые списки, счетчики и индикаторы выполнения) с языком C ++, и, если это возможно, опубликуйте пример.
Я также изучаю QT и судивший для нахождения способа использовать Единицу API в QT, я мог только использовать API Dbus, но никакая удача с Quicklist, так как этому нужен DbusMenu и я не знаю, как реализовать это (все еще изучение :)).
Это - пример, который я создал для моего сам, и я надеюсь, что это полезно для других. Возможно, Единица devs может помочь исправить / фиксируют / добавляет новый код (quicklist) к ней :)
/*
Unity Launcher Dbus API exmable for Qt
foxoman [gplus.to/foxoman][foxoman.u@gmail.com]
https://wiki.ubuntu.com/Unity/LauncherAPI#Low_level_DBus_API:_com.canonical.Unity.LauncherEntry
First step : add this line to your Qt project file .pro
QT += dbus
*/
/* I will run this example as Qt console apps */
#include <QtCore/QCoreApplication>
/* Include Qt Dbus required */
#include <QtDBus>
// Qt Main Method
int main(int argc, char *argv[])
{
/* Qt console Main Loop [ in GUI application the Main loop is QApplication ]
Unity API need Main Loop to run */
QCoreApplication a(argc, argv);
/* Create Qt Dbus Signal to send Dbus Message to unity Dbus API
signal com.canonical.Unity.LauncherEntry.Update (in s app_uri, in a{sv} properties)
*/
QDBusMessage signal = QDBusMessage::createSignal(
"/", /* Path */
"com.canonical.Unity.LauncherEntry", /* Unity DBus Interface */
"Update"); /* Update Signal */
/* app_uri
Desktop ID ex: firefox -> need to be pined in the launcher to see the effect
*/
signal << "application://firefox.desktop";
/* properties : A map of strings to variants with the properties to set on the launcher icon */
QVariantMap setProperty;
/* A number to display on the launcher icon */
setProperty.insert("count", qint64(80));
/* show count */
setProperty.insert("count-visible", true);
/* progress bar count must be float between 0 and 1 (mean from 0.00 to 0.100)*/
setProperty.insert("progress", double(0.80));
/* show progress bar */
setProperty.insert("progress-visible", true);
/* Tells the launcher to get the users attention */
setProperty.insert("urgent",true);
/* Pack the properties Map to the signal */
signal << setProperty;
/* Send the signal */
QDBusConnection::sessionBus().send(signal);
return a.exec();
}
загрузите пример здесь http://ubuntuone.com/1SLDPcN9OhrU6LD1wgDs3r
В настоящее время не существует специальной библиотеки для доступа к функциональности модуля запуска из Qt C ++. Есть библиотека libunity, но она сильно ориентирована на glib, поэтому относительно не подходит для Qt. Как упоминалось в другом ответе, наиболее удобный способ интеграции с модулем запуска - это использование низкоуровневого API dbus .
Основная концепция интеграции с модулем запуска заключается в отправке на модуль запуска сигнала с идентификатором приложения и набором свойств. Идентификатор приложения - это имя файла .desktop, обычно хранящегося в /usr/share/applications
:
//create the signal
QDBusMessage signal = QDBusMessage::createSignal("/",
"com.canonical.Unity.LauncherEntry", "Update");
//set the application ID
signal << "application://firefox.desktop";
//set the properties
QVariantMap properties;
...
signal << properties;
//send the signal
QDBusConnection::sessionBus().send(signal);
Чтобы установить счетчик, вам нужно установить свойства так, чтобы счетчик виден и дает ему желаемое целочисленное значение:
qint64 counter_value = 1;
properties["count-visible"] = true; //set the count to visible
properties["count"] = counter_value; //set the counter value
Чтобы установить индикатор выполнения, вам нужно установить свойства так, чтобы прогресс был видимым, и дать это желаемое двойное значение:
double progress_value = 0.5;
properties["progress-visible"] = true; //set the progress bar to visible
properties["progress"] = progress_value; //set the progress value
Быстрый список можно настроить с помощью библиотеки Qbus dbusmenu. Вам нужно будет включить файл заголовка:
#include <dbusmenuexporter.h>
Быстрый список создается как меню QMenu
в Qt. Это меню «экспортируется» через dbusmenu с использованием объекта DBusMenuExporter
. При экспорте вы даете этому объекту уникальный путь, а затем ссылаетесь на этот путь, чтобы указать элементу запуска, какое меню отображать в качестве быстрого списка.
В объявлении класса главного окна добавьте следующие переменные экземпляра:
QMenu *quicklist;
DBusMenuExporter *quicklist_exporter;
Затем в функции конструктора:
quicklist = new QMenu(this);
//exports the menu over dbus using the object: /com/me/myapp/quicklist
quicklist_exporter = new DBusMenuExporter("/com/me/myapp/quicklist", quicklist);
Чтобы добавить элементы в меню, используйте [addAction] (http: //qt-project.org/doc/qt-5.0/qtwidgets/qmenu.html#addAction) метод меню для добавления [QAction] (http: //qt-project.org/doc/ qt-5.0 / qtwidgets / qaction.html) объектов.
Чтобы установить быстрый список значка средства запуска, установите свойство «quicklist» для сигнала:
properties["quicklist"] = "/com/me/myapp/quicklist";
Вам потребуется настроить файл .pro добавить поддержку dbus: QT += dbus
. Для сборки с поддержкой быстрого списка вам необходимо установить библиотеки разработки dbusmenu-qt (libdbusmenu*dev
). Затем вы можете добавить следующее в файл проекта для включения библиотеки dbusmenu:
#import the dbusmenu-qt library for quicklists
greaterThan(QT_MAJOR_VERSION, 4) {
INCLUDEPATH += /usr/include/dbusmenu-qt5/
LIBS += -ldbusmenu-qt5
} else {
INCLUDEPATH += /usr/include/dbusmenu-qt/
LIBS += -ldbusmenu-qt
}
Чтобы увидеть полный пример использования всех функций запуска из Qt, посмотрите на это Проект Github .