我正在使用自定义类型为 Enum 的 QDBUS。谷歌搜索后,我发现下面的链接解释了 QDBUS 自定义类型的编组。
这没有解释要在 QTDBUS interospection xml 中指定的注释以使用 qdbusxml2cpp 生成代理。
如何在 QTDBUS interospection xml 中添加枚举注释?
如果可能,请用一些示例代码进行解释。
我正在使用自定义类型为 Enum 的 QDBUS。谷歌搜索后,我发现下面的链接解释了 QDBUS 自定义类型的编组。
这没有解释要在 QTDBUS interospection xml 中指定的注释以使用 qdbusxml2cpp 生成代理。
如何在 QTDBUS interospection xml 中添加枚举注释?
如果可能,请用一些示例代码进行解释。
我找到了解决我的问题的方法:
首先创建一个名为enums.h的新头文件,如下所示:
#ifndef ENUMS_H
#define ENUMS_H
#include <QtDBus>
#include "enumDBus.h"
enum Color {
RED = 0,
BLUE,
GREEN
};
Q_DECLARE_METATYPE(Color)
#endif /* ENUMS_H */
注意下面的 #include "enumDBus.h"行,你可以在这里找到这个头文件!
所以在你声明了枚举之后,你可以声明一个以枚举为参数的方法,在这个例子中,我在calculator.h中声明了以下方法:
void setColor(Color color);
此方法的实现:
void Calculator::setColor(Color c)
{
switch (c) {
case BLUE: std::cout << "Color: blue" << std::endl;
break;
case GREEN: std::cout << "Color: green" << std::endl;
break;
case RED: std::cout << "Color: reed" << std::endl;
break;
default:
std::cout << "Color: FAIL!" << std::endl;
}
}
现在让我们生成接口描述(xml),使用以下命令
qdbuscpp2xml -M -s calculator.h -o com.meJ.system.CalculatorInterface.xml
包含自定义类型的方法的生成不能正常工作,所以我们需要做一些调整:
<!DOCTYPE node PUBLIC "-//freedesktop//DTD D-BUS Object Introspection 1.0//EN" "http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd">
<node>
<interface name="com.meJ.system.CalculatorInterface">
<method name="setColor">
<annotation name="org.qtproject.QtDBus.QtTypeName.In0" value="Color"/>
<arg type="(i)" direction="in" name="c"/>
</method>
</interface>
</node>
使用这个 xml 文件,我们可以简单地创建我们的适配器和接口类。
在我们的main.cpp中(在客户端和服务器上!)我们必须注册我们的自定义类型:
int main(int argc, char** argv)
{
qRegisterMetaType<Color>("Color");
qDBusRegisterMetaType<Color>();
}
客户端
在 main.cpp 中包含生成的calculatorInterface.h 和enums.h。
现在您可以简单地调用您的方法:
int main(int argc, char** argv)
{
qRegisterMetaType<Color>("Color");
qDBusRegisterMetaType<Color>();
QDBusConnection dbus = QDBusConnection::sessionBus();
com::meJ::system::CalculatorInterface *calculator = new com::meJ::system::CalculatorInterface("com.meJ.system", "/Calc", dbus);
if (calculator->isValid() == false) {
cerr << "ERROR: " << qPrintable(calculator->lastError().message()) << endl;
exit(1);
}
Color c = GREEN;
calculator->setColor(c);
std::cout << qPrintable(calculator->lastError().message()) << std::endl;
exit(0);
}
如果一切正常,您应该在服务器程序中看到以下输出:
~# Color: green