Я наконец-то нашел решение, которое - после нескольких часов неприятностей - теперь работает.
Класс QLibrary позволяет динамически загружать .dll-файлы, поэтому все, что мне нужно было сделать, это поместить свой класс в .dll и добавить функцию, которая возвращает указатель на требуемый класс.
это заголовочный файл .dll:
#ifndef DIVFIXTURE_H
#define DIVFIXTURE_H
#include<QObject>
#include<QVariant>
class __declspec(dllexport) DivFixture : public QObject
{
Q_OBJECT
public:
Q_INVOKABLE DivFixture();
Q_INVOKABLE void setNumerator(QVariant num);
Q_INVOKABLE void setDenominator(QVariant denom);
Q_INVOKABLE QVariant quotient();
private:
double numerator, denominator;
};
#endif
Это cpp-файл .dll:
#include "testfixture.h"
DivFixture::DivFixture(){}
extern "C" __declspec(dllexport) void DivFixture::setNumerator(QVariant num)
{
numerator=num.toDouble();
}
extern "C" __declspec(dllexport) void DivFixture::setDenominator(QVariant denom)
{
denominator=denom.toDouble();
}
extern "C" __declspec(dllexport) QVariant DivFixture::quotient()
{
QVariant ret;
ret=numerator/denominator;
return ret;
}
//non-class function to return pointer to class
extern "C" __declspec(dllexport) DivFixture* create()
{
return new DivFixture();
}
и вот как я загружаю свой класс:
currentFixture.setFileName("C:\\somepath\\testFixture.dll");
if(currentFixture.load());
{
typedef QObject* (*getCurrentFixture)();
getCurrentFixture fixture=(getCurrentFixture)currentFixture.resolve("create");
if (fixture)
{
Fixture=fixture();
}
}
После этого я могу получить QMetaObject и вызвать любой метод, который мне нравится.
Надеюсь, что это поможет тем, кто столкнется с подобной проблемой в будущем.