Используя функцию обратного вызова из стороннего API в вашем собственном классе, который является DLL

Я пытаюсь написать класс в DLL, которая использует функцию обратного вызова из другой библиотеки DLL. В настоящее время я могу заставить работать обратный вызов, когда я вызываю его в основной функции, но у меня возникают проблемы при интеграции его в мою собственную DLL.

Я использую Hinstance в обычном проекте и dll im compiling. Это работает в обычном проекте:

void mycallback(float values[], __int64 timestamp, int status) {
//stuff
 globalval[0]=values[0];
 ...
}

void main(){
 ...
 void(*_callback)(float[], __int64, int);
 _callback = &mycallback;
 API_CALLBACK finalCallBack = (API_CALLBACK)_callback;
....
//I pass this callback in another function that the api uses later
}

Однако это не удается, когда я пытаюсь перенести его в функцию инициализации в классе, который я компилирую как dll (я пытался использовать функцию связывания, но #include давало мне ошибки (с использованием visual studios 2015)

void MyClass::mycallback(float values[], __int64 timestamp, int status){
//stuff
  myClassval[0]=values[0];
 ...
}

MyClass::Init(){
    void(*_callback)(float[], __int64, int);=
    _callback = &MyClass::mycallback;<---This line is giving me error
    API_CALLBACK finalCallBack = (API_CALLBACK)_callback;
  }

Я получаю ошибку "assigning to ' void(*)(float *,long long, int)' from incompaible type 'void(MyClass::*)(float *,long long,int)"

Есть ли другой способ, которым я должен подходить к этому? Я не уверен, как справиться с этим, поскольку у меня есть доступ только к функциям обратного вызова, но не к источнику.

редактировать: я понимаю, что приведение mycallback в качестве статического решит проблему, но тогда я столкнусь с проблемой невозможности сохранить значение где-либо. или есть хороший способ сделать это?

полный код для дальнейшего использования:

void main() {
    //declare dll handler
    HINSTANCE hinstLib;
    FCALL _InitDevices,_ReleaseDevices;
    FCALL_GETHMDINFO _getHMDinfo;
    FCALL_HMDPRESENT _HMDPresent;
    FCALL_STARTTRACKING _StartTracking;
    BOOL fFreeResult;
    //Load dll
    hinstLib = LoadLibrary(TEXT("thirdparty.dll"));

    bool* isHMDpresent = new bool;


    void(*_hmdcallback)(float[], __int64, int);
    _hmdcallback = &hmdcallback;
    HMD_TRACK_CALLBACK hmdCallBack = (HMD_TRACK_CALLBACK)_hmdcallback;


    //float handle = (float)hmdCallBack;
    //if dll present
    if (hinstLib != NULL)
    {
        //initialise devices
        _InitDevices = (FCALL)GetProcAddress(hinstLib, "InitDevices");

        if (NULL != _InitDevices)
        {
            std::cout<<(_InitDevices)()<<std::endl;
        }



        //start tracking
        _StartTracking = (FCALL_STARTTRACKING)GetProcAddress(hinstLib, "StartTracking");

        if (NULL != _StartTracking)
        {

            std::cout << (_StartTracking)(hmdCallBack,nullptr,nullptr,nullptr) << std::endl;


        }

это функция от стороннего dll

DLL_EXPORT typedef void(__stdcall *HMD_TRACK_CALLBACK)(float values[], __int64 timestamp, int  status );

Я пытаюсь преобразовать выше и упаковать его в другой DLL (драйвер) с другими функциями из нескольких DLL. Конкретная задача, которую я пытаюсь сделать сейчас, состоит в том, чтобы сохранить массив из обратного вызова библиотеки, которую я использую. В этом случае одна из вещей, которую я сохраняю, values[]

0 ответов

Другие вопросы по тегам