将uint16_t和char*与QMetaObject::invokeMethod()一起使用

Using uint16_t and char* with QMetaObject::invokeMethod()

本文关键字:invokeMethod 一起 QMetaObject uint16 char      更新时间:2023-10-16

我想使用QMetaObject::invokeMethod()从不同的线程异步调用插槽

包含插槽的类声明为:

class Paintable : public QObject {
  Q_OBJECT
  [...]
  public slots:
    void drawString(uint16_t x, uint16_t y, uint16_t size, const char* str, color c);
}

调用invokeMethod的方法定义为:

void drawStringAsynchronously(uint16_t x, uint16_t y, uint16_t size, const char* str, color c) {
  QMetaObject::invokeMethod(paintable,
               "drawString",
               Qt::QueuedConnection,
               Q_ARG(uint16_t, x), Q_ARG(uint16_t, y), Q_ARG(uint16_t, size),
               Q_ARG(const char*, str), Q_ARG(color, c));
}

(其中paintable属于Paintable*类型)

但是Qt似乎无法在invokeMethod中使用uint16_t或char*,因为在运行时我会收到以下消息:

QMetaMethod::invoke: Unable to handle unregistered datatype 'const char*'

QMetaMethod::invoke: Unable to handle unregistered datatype 'uint16_t'

分别。

我能够使用qRegisterMetaType()成功注册我的自定义结构体color,但由于uint16_tchar*不是结构体或类,这将不起作用。

如果有人能教我怎么做,或者展示一个好的替代方案,我会很高兴。

注册uint16_t的问题是:它是一个typedef,Qt已经注册了这个类型,但它的名称不同。由于QMetaType系统是基于根据类型的名称来确定类型的,这会导致问题。

你可以用来解决这个问题

Q_DECLARE_METATYPE(uint16_t)

然后:

qRegisterMetaType<uint16_t>("uint16_t");

这将创建一个别名,以便可以使用该名称创建元类型。