我正在尝试将 QStandardItemModel 派生对象发送到 PythonQt,但我对如何发送它有点困惑。当我使用 boost::python 时,我有几个控件,比如 boost::noncopyable,以确保我没有重新创建这个对象,而是与 python 共享它。我还有一些构造可以从 python 内部提供一个指向 python 的 boost 共享指针。
class Scene : public boost::enable_shared_from_this<Scene>, public QStandardItemModel
但是,在 PythonQt 中,我不确定有什么可用的。该函数call
为所有函数参数采用 QVariantList。
QVariant PythonQt::call(PyObject* object, const QString &callable, const QVariantList &args = QVariantList))
我现在很困惑的是如何通过 QVariant 将我的对象传递给 python。由于它是从 QStandardItemModel 派生的,我认为它已经注册了
void MyObject::someFunction(QString fileName)
{
QVariant myObjectV = qVariantFromValue(this);
// send to python
...
}
但这给了我以下错误:
'qt_metatype_id' : is not a member of 'QMetaTypeId<MyObject>'
我在声明我的班级后尝试注册它,但这会引发不同的错误。
class MyObject : public QStandardItemModel
{
Q_OBJECT
...
};
Q_DECLARE_METATYPE(MyObject)
QStandardItemModel::QStandardItemModel(const QStandardItemModel&) is private within this context.
我实际上得到了两次错误——一次是在我添加 Q_DECLARE_METATYPE 的标题中,另一个是另一个标题,它有一个始终派生自 QStandardItemModel 但在其他方面无关的类。
Q_DECLARE_METATYPE 甚至是将此对象转换为 QVariant 的正确方法吗?
BOOST_PYTHON_MODULE(场景) { class_("场景"); }