windows build
This commit is contained in:
@@ -5,30 +5,53 @@ project(metabolus LANGUAGES CXX)
|
|||||||
set(CMAKE_CXX_STANDARD 20)
|
set(CMAKE_CXX_STANDARD 20)
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
if (WIN32)
|
find_package(Qt6 REQUIRED COMPONENTS Widgets)
|
||||||
add_library(RtAudio::RtAudio SHARED IMPORTED)
|
qt_standard_project_setup()
|
||||||
|
|
||||||
set_target_properties(RtAudio::RtAudio PROPERTIES
|
# windows 11 x86_64
|
||||||
IMPORTED_LOCATION "C:/rtaudio/bin/rtaudio.dll"
|
# debian 12 x86_64
|
||||||
IMPORTED_IMPLIB "C:/rtaudio/lib/rtaudio.lib"
|
if (WIN32)
|
||||||
INTERFACE_INCLUDE_DIRECTORIES "C:/rtaudio/include"
|
# Header-only target (real target, no ::)
|
||||||
|
add_library(rtaudio_headers INTERFACE)
|
||||||
|
target_include_directories(rtaudio_headers INTERFACE
|
||||||
|
"C:/rtaudio/include"
|
||||||
|
"C:/rtaudio/include/rtAudio"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Imported binary (real target, no ::)
|
||||||
|
add_library(rtaudio_binary SHARED IMPORTED)
|
||||||
|
set_target_properties(rtaudio_binary PROPERTIES
|
||||||
|
IMPORTED_LOCATION "C:/rtaudio/bin/rtaudio.dll"
|
||||||
|
IMPORTED_IMPLIB "C:/rtaudio/lib/rtaudio.lib"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Unified interface target
|
||||||
|
add_library(rtaudio INTERFACE)
|
||||||
|
target_link_libraries(rtaudio INTERFACE
|
||||||
|
rtaudio_headers
|
||||||
|
rtaudio_binary
|
||||||
|
)
|
||||||
|
|
||||||
|
# Public alias (this is where :: belongs)
|
||||||
|
add_library(RtAudio::RtAudio ALIAS rtaudio)
|
||||||
|
|
||||||
else()
|
else()
|
||||||
find_package(Qt6 REQUIRED COMPONENTS Widgets)
|
|
||||||
find_package(PkgConfig REQUIRED)
|
find_package(PkgConfig REQUIRED)
|
||||||
pkg_check_modules(RTAUDIO REQUIRED rtaudio)
|
pkg_check_modules(RTAUDIO REQUIRED rtaudio)
|
||||||
|
|
||||||
add_library(RtAudio::RtAudio INTERFACE IMPORTED)
|
add_library(rtaudio INTERFACE)
|
||||||
set_target_properties(RtAudio::RtAudio PROPERTIES
|
target_include_directories(rtaudio INTERFACE
|
||||||
INTERFACE_INCLUDE_DIRECTORIES "${RTAUDIO_INCLUDE_DIRS}"
|
${RTAUDIO_INCLUDE_DIRS}
|
||||||
INTERFACE_LINK_LIBRARIES "${RTAUDIO_LIBRARIES}"
|
|
||||||
)
|
)
|
||||||
|
target_link_libraries(rtaudio INTERFACE
|
||||||
|
${RTAUDIO_LIBRARIES}
|
||||||
|
)
|
||||||
|
|
||||||
|
add_library(RtAudio::RtAudio ALIAS rtaudio)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
qt_standard_project_setup()
|
|
||||||
|
|
||||||
add_executable(metabolus
|
qt_add_executable(metabolus
|
||||||
src/main.cpp
|
src/main.cpp
|
||||||
src/MainWindow.cpp
|
src/MainWindow.cpp
|
||||||
src/MainWindow.h
|
src/MainWindow.h
|
||||||
@@ -40,14 +63,12 @@ add_executable(metabolus
|
|||||||
resources/resources.qrc
|
resources/resources.qrc
|
||||||
)
|
)
|
||||||
|
|
||||||
# target_include_directories(metabolus PRIVATE ${RTAUDIO_INCLUDE_DIRS})
|
target_link_libraries(metabolus PRIVATE Qt6::Widgets RtAudio::RtAudio)
|
||||||
target_link_libraries(metabolus PRIVATE Qt6::Widgets ${RTAUDIO_LIBRARIES})
|
|
||||||
# target_compile_options(metabolus PRIVATE ${RTAUDIO_CFLAGS_OTHER})
|
|
||||||
|
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
add_custom_command(TARGET MyQtApp POST_BUILD
|
add_custom_command(TARGET metabolus POST_BUILD
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy_if_different
|
COMMAND ${CMAKE_COMMAND} -E copy_if_different
|
||||||
"C:/rtaudio/bin/rtaudio.dll"
|
"C:/rtaudio/bin/rtaudio.dll"
|
||||||
$<TARGET_FILE_DIR:MyQtApp>
|
$<TARGET_FILE_DIR:metabolus>
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
@@ -8,8 +8,7 @@ REM ================================
|
|||||||
set BUILD_DIR=build
|
set BUILD_DIR=build
|
||||||
set CONFIG=Release
|
set CONFIG=Release
|
||||||
|
|
||||||
REM Update these paths if needed
|
set QT_ROOT=C:\Qt\6.10.1\msvc2022_64
|
||||||
set QT_ROOT=C:\Qt\6.6.1\msvc2022_64
|
|
||||||
set RTAUDIO_ROOT=C:\rtaudio
|
set RTAUDIO_ROOT=C:\rtaudio
|
||||||
|
|
||||||
REM ================================
|
REM ================================
|
||||||
@@ -50,7 +49,7 @@ REM ================================
|
|||||||
|
|
||||||
cd %BUILD_DIR%
|
cd %BUILD_DIR%
|
||||||
|
|
||||||
windeployqt MyQtApp.exe
|
windeployqt metabolus.exe
|
||||||
|
|
||||||
copy "%RTAUDIO_ROOT%\bin\rtaudio.dll" .
|
copy "%RTAUDIO_ROOT%\bin\rtaudio.dll" .
|
||||||
|
|
||||||
|
|||||||
@@ -1,8 +1,13 @@
|
|||||||
|
|
||||||
#include "AudioEngine.h"
|
#include "AudioEngine.h"
|
||||||
|
|
||||||
|
#define _USE_MATH_DEFINES
|
||||||
|
#include <cmath>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <math.h>
|
|
||||||
|
#ifndef M_PI // I hate my stupid chungus life
|
||||||
|
#define M_PI 3.14159265358979323846
|
||||||
|
#endif
|
||||||
|
|
||||||
AudioEngine::AudioEngine() {
|
AudioEngine::AudioEngine() {
|
||||||
if(audio_.getDeviceCount() < 1) {
|
if(audio_.getDeviceCount() < 1) {
|
||||||
@@ -18,12 +23,13 @@ bool AudioEngine::start() {
|
|||||||
|
|
||||||
RtAudio::StreamParameters params;
|
RtAudio::StreamParameters params;
|
||||||
params.deviceId = audio_.getDefaultOutputDevice();
|
params.deviceId = audio_.getDefaultOutputDevice();
|
||||||
params.nChannels = 1;
|
params.nChannels = 2;
|
||||||
params.firstChannel = 0;
|
params.firstChannel = 0;
|
||||||
|
|
||||||
RtAudio::StreamOptions options;
|
RtAudio::StreamOptions options;
|
||||||
options.flags = RTAUDIO_MINIMIZE_LATENCY;
|
options.flags = RTAUDIO_MINIMIZE_LATENCY;
|
||||||
|
|
||||||
|
/*
|
||||||
try {
|
try {
|
||||||
audio_.openStream(¶ms, nullptr, RTAUDIO_FLOAT32, sampleRate_, &bufferFrames_, &AudioEngine::audioCallback, this, &options);
|
audio_.openStream(¶ms, nullptr, RTAUDIO_FLOAT32, sampleRate_, &bufferFrames_, &AudioEngine::audioCallback, this, &options);
|
||||||
audio_.startStream();
|
audio_.startStream();
|
||||||
@@ -31,6 +37,9 @@ bool AudioEngine::start() {
|
|||||||
std::cerr << e.getMessage() << std::endl;
|
std::cerr << e.getMessage() << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
audio_.openStream(¶ms, nullptr, RTAUDIO_FLOAT32, sampleRate_, &bufferFrames_, &AudioEngine::audioCallback, this, &options);
|
||||||
|
audio_.startStream();
|
||||||
|
|
||||||
std::cout << "sample rate: " << sampleRate_ << " buffer frames: " << bufferFrames_ << std::endl;
|
std::cout << "sample rate: " << sampleRate_ << " buffer frames: " << bufferFrames_ << std::endl;
|
||||||
return true;
|
return true;
|
||||||
@@ -63,7 +72,9 @@ int32_t AudioEngine::process(float* out, uint32_t nFrames) {
|
|||||||
currentFreq_ += freqStep;
|
currentFreq_ += freqStep;
|
||||||
|
|
||||||
float phaseInc = 2.0f * M_PI * currentFreq_ / sr;
|
float phaseInc = 2.0f * M_PI * currentFreq_ / sr;
|
||||||
out[i] = std::sin(phase_);
|
|
||||||
|
out[2*i] = std::sin(phase_); // left
|
||||||
|
out[2*i+1] = std::sin(phase_); // right
|
||||||
|
|
||||||
phase_ += phaseInc;
|
phase_ += phaseInc;
|
||||||
if (phase_ > 2.0f * M_PI) phase_ -= 2.0f * M_PI;
|
if (phase_ > 2.0f * M_PI) phase_ -= 2.0f * M_PI;
|
||||||
|
|||||||
Reference in New Issue
Block a user