Передача объектов RtMidi в функции (C ++) - PullRequest
0 голосов
/ 11 января 2012

Изложив некоторые идеи в Processing, я решил переместить свой MIDI-проект на C ++ для переносимости на встроенную платформу. Я решил использовать библиотеку RtMidi для ввода / вывода MIDI, но у меня возникли некоторые проблемы с разметкой кода так, как я хочу. Я еще не очень хорош в C ++.

По сути, я хочу передать объект RtMidiIn и объект RtMidiOut в мою функцию printMidiPorts (код такой же, как в примере кода в комплекте с RtMidi). Я понимаю, что это как-то связано с инициализацией midiin и midiout в качестве указателей, но я не совсем уверен.

Это мой код:

#include <stdio.h>
#include <iostream>
#include <string>
#include "rtmidi/RtMidi.h"

using namespace std;

void printMidiPorts(RtMidiIn midiin, RtMidiOut midiout)
{
    // Check inputs.
    unsigned int nPorts = midiin->getPortCount();
    std::cout << "\nThere are " << nPorts << " MIDI input sources available.\n";
    std::string portName;
    for ( unsigned int i=0; i<nPorts; i++ ) {
        try {
            portName = midiin->getPortName(i);
        }
        catch ( RtError &error ) {
            error.printMessage();
            goto cleanup;
        }
        std::cout << "  Input Port #" << i+1 << ": " << portName << '\n';
    }

    // Check outputs.
    nPorts = midiout->getPortCount();
    std::cout << "\nThere are " << nPorts << " MIDI output ports available.\n";
    for ( unsigned int i=0; i<nPorts; i++ ) {
        try {
            portName = midiout->getPortName(i);
        }
        catch (RtError &error) {
            error.printMessage();
            goto cleanup;
        }
        std::cout << "  Output Port #" << i+1 << ": " << portName << '\n';
    }
    std::cout << '\n';

    // Clean up
    cleanup:
    delete midiin;
    delete midiout;

}

int main ()
{

    RtMidiIn  *midiin = 0;
    RtMidiOut *midiout = 0;

    // RtMidiIn constructor
    try {
        midiin = new RtMidiIn();
    }
    catch ( RtError &error ) {
        error.printMessage();
        exit( EXIT_FAILURE );
    }

    // RtMidiOut constructor
    try {
        midiout = new RtMidiOut();
    }
    catch ( RtError &error ) {
        error.printMessage();
        exit( EXIT_FAILURE );
    }

    printMidiPorts(midiin, midiout);

    return 0;
}

И это мой вывод компилятора:

    lightArray.cpp: In function ‘void printMidiPorts(RtMidiIn, RtMidiOut)’:
    lightArray.cpp:19: error: base operand of ‘->’ has non-pointer type ‘RtMidiIn’
    lightArray.cpp:24: error: base operand of ‘->’ has non-pointer type ‘RtMidiIn’
    lightArray.cpp:34: error: base operand of ‘->’ has non-pointer type ‘RtMidiOut’
    lightArray.cpp:38: error: base operand of ‘->’ has non-pointer type ‘RtMidiOut’
    lightArray.cpp:50: error: type ‘class RtMidiIn’ argument given to ‘delete’, expected pointer
    lightArray.cpp:51: error: type ‘class RtMidiOut’ argument given to ‘delete’, expected pointer
    lightArray.cpp: In function ‘int main()’:
    lightArray.cpp:79: error: conversion from ‘RtMidiIn*’ to non-scalar type ‘RtMidiIn’ req

Любая помощь очень ценится. Спасибо!

Ответы [ 2 ]

1 голос
/ 11 января 2012

Похоже, что в основной функции midiin и midiout имеют типы RtMidiIn* и RtMidiOut* (указатели на объекты), тогда как параметры printMidiPorts имеют типы RtMidiIn и * 1007. * (объекты). Похоже, все, что вам нужно сделать, это изменить подпись для printMidiPorts.

0 голосов
/ 11 января 2012

Ваша подпись функции неверна.

это: void printMidiPorts(RtMidiIn midiin, RtMidiOut midiout) объявляет midiin и midiout как обычные значения, а не как указатели.

void printMidiPorts(RtMidiIn *midiin, RtMidiOut *midiout) будет правильной подписью для вашей функции.

...