2012-07-30 69 views
0

工作,我在我的课已经typedef ProxyTray<QImage, ImageCaptureService> TrayType;(这的QObject但ProxyTray QObject的)。我在Signal,Slots中使用这种类型作为参数类型。不QMetaType与模板类型

确实qRegisterMetaType接受这样的类型?我将如何建模参数化类型的字符串类型名称?

+0

做'qRegisterMetaType ( “TrayType”);'在构造函数之前连接信号插槽。越来越'的QObject ::连接:(使用qRegisterMetaType()确保 'TrayType&' 被注册)' – 2012-07-30 16:51:05

+0

做你'Q_DECLARE_METATYPE'不能排队类型的参数 'TrayType&' ? – tmpearce 2012-07-30 17:08:13

+0

[这个问题](http://stackoverflow.com/questions/1276967/qt-4-5-how-do-i-perform-a-queued-connection-with-a-template-type)可能是有帮助 – tmpearce 2012-07-30 17:17:26

回答

1

是,模板类型可以在Qt信号/时隙被使用。当你已经有一个typedef你的类型,你可以简单地使用Q_DECLARE_METATYPE如下面的例子:

Q_DECLARE_METATYPE_TEMPLATE_1ARG(TemplatedClass) 
Q_DECLARE_METATYPE_TEMPLATE_2ARG(TemplatedClass) 

例如:

#include <QtCore> 

template <typename T> 
struct Proxy 
{ 
    T data; 
}; 
typedef Proxy<QImage> TrayType; 
Q_DECLARE_METATYPE(TrayType) 

class Donor : public QObject 
{ 
    Q_OBJECT 
public: 
    Donor() 
    { 
     m_proxy.data = QImage(10, 20, QImage::Format_Mono); 
    } 

    void test() 
    { 
     emit produce(m_proxy); 
    } 

signals: 
    void produce(const TrayType& proxy); 

private: 
    TrayType m_proxy; 
}; 

class Acceptor : public QObject 
{ 
    Q_OBJECT 
public slots: 
    void consume(const TrayType& proxy) 
    { 
     qDebug() << "The mage size is" << proxy.data.size(); 
    } 
}; 

int main(int argc, char* argv[]) 
{ 
    QCoreApplication app(argc, argv); 

    QScopedPointer<Donor> donor(new Donor); 
    QScopedPointer<Acceptor> acceptor(new Acceptor); 
    QObject::connect(donor.data(), SIGNAL(produce(TrayType)), 
        acceptor.data(), SLOT(consume(TrayType))); 

    // Test the signal-slot connection. 
    donor->test(); 
    return app.exec(); 
} 
1

你可以声明模板元类型

template<class T> 
class Foo { 

}; 
Q_DECLARE_METATYPE_TEMPLATE_1ARG(Foo) 

允许通过Foo<int>Foo<QString>,等...的信号和槽。

template<class T, class U> 
class Foo { 

}; 
Q_DECLARE_METATYPE_TEMPLATE_2ARG(Foo) 

允许通过Foo<int, double>Foo<bool, bool>等..

然而,有两点需要说明:

  • 这是不是官方的Qt API的一部分,并可能在某一时刻消失。
  • 的模板类型必须是自己注册使用Q_DECLARE_METATYPEFoo<Bar>要求Bar注册为一元类型太(如Qt的5.6 )