windows build

This commit is contained in:
2025-12-22 22:17:35 -06:00
parent 40580179d1
commit 0d6ab4b88c
3 changed files with 56 additions and 25 deletions

View File

@@ -5,30 +5,53 @@ project(metabolus LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 20)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
if (WIN32)
add_library(RtAudio::RtAudio SHARED IMPORTED)
find_package(Qt6 REQUIRED COMPONENTS Widgets)
qt_standard_project_setup()
set_target_properties(RtAudio::RtAudio PROPERTIES
IMPORTED_LOCATION "C:/rtaudio/bin/rtaudio.dll"
IMPORTED_IMPLIB "C:/rtaudio/lib/rtaudio.lib"
INTERFACE_INCLUDE_DIRECTORIES "C:/rtaudio/include"
# windows 11 x86_64
# debian 12 x86_64
if (WIN32)
# 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()
find_package(Qt6 REQUIRED COMPONENTS Widgets)
find_package(PkgConfig REQUIRED)
pkg_check_modules(RTAUDIO REQUIRED rtaudio)
add_library(RtAudio::RtAudio INTERFACE IMPORTED)
set_target_properties(RtAudio::RtAudio PROPERTIES
INTERFACE_INCLUDE_DIRECTORIES "${RTAUDIO_INCLUDE_DIRS}"
INTERFACE_LINK_LIBRARIES "${RTAUDIO_LIBRARIES}"
add_library(rtaudio INTERFACE)
target_include_directories(rtaudio INTERFACE
${RTAUDIO_INCLUDE_DIRS}
)
target_link_libraries(rtaudio INTERFACE
${RTAUDIO_LIBRARIES}
)
add_library(RtAudio::RtAudio ALIAS rtaudio)
endif()
qt_standard_project_setup()
add_executable(metabolus
qt_add_executable(metabolus
src/main.cpp
src/MainWindow.cpp
src/MainWindow.h
@@ -40,14 +63,12 @@ add_executable(metabolus
resources/resources.qrc
)
# target_include_directories(metabolus PRIVATE ${RTAUDIO_INCLUDE_DIRS})
target_link_libraries(metabolus PRIVATE Qt6::Widgets ${RTAUDIO_LIBRARIES})
# target_compile_options(metabolus PRIVATE ${RTAUDIO_CFLAGS_OTHER})
target_link_libraries(metabolus PRIVATE Qt6::Widgets RtAudio::RtAudio)
if (WIN32)
add_custom_command(TARGET MyQtApp POST_BUILD
add_custom_command(TARGET metabolus POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different
"C:/rtaudio/bin/rtaudio.dll"
$<TARGET_FILE_DIR:MyQtApp>
$<TARGET_FILE_DIR:metabolus>
)
endif()

View File

@@ -8,8 +8,7 @@ REM ================================
set BUILD_DIR=build
set CONFIG=Release
REM Update these paths if needed
set QT_ROOT=C:\Qt\6.6.1\msvc2022_64
set QT_ROOT=C:\Qt\6.10.1\msvc2022_64
set RTAUDIO_ROOT=C:\rtaudio
REM ================================
@@ -50,7 +49,7 @@ REM ================================
cd %BUILD_DIR%
windeployqt MyQtApp.exe
windeployqt metabolus.exe
copy "%RTAUDIO_ROOT%\bin\rtaudio.dll" .

View File

@@ -1,8 +1,13 @@
#include "AudioEngine.h"
#define _USE_MATH_DEFINES
#include <cmath>
#include <iostream>
#include <math.h>
#ifndef M_PI // I hate my stupid chungus life
#define M_PI 3.14159265358979323846
#endif
AudioEngine::AudioEngine() {
if(audio_.getDeviceCount() < 1) {
@@ -18,12 +23,13 @@ bool AudioEngine::start() {
RtAudio::StreamParameters params;
params.deviceId = audio_.getDefaultOutputDevice();
params.nChannels = 1;
params.nChannels = 2;
params.firstChannel = 0;
RtAudio::StreamOptions options;
options.flags = RTAUDIO_MINIMIZE_LATENCY;
/*
try {
audio_.openStream(&params, nullptr, RTAUDIO_FLOAT32, sampleRate_, &bufferFrames_, &AudioEngine::audioCallback, this, &options);
audio_.startStream();
@@ -31,6 +37,9 @@ bool AudioEngine::start() {
std::cerr << e.getMessage() << std::endl;
return false;
}
*/
audio_.openStream(&params, nullptr, RTAUDIO_FLOAT32, sampleRate_, &bufferFrames_, &AudioEngine::audioCallback, this, &options);
audio_.startStream();
std::cout << "sample rate: " << sampleRate_ << " buffer frames: " << bufferFrames_ << std::endl;
return true;
@@ -63,7 +72,9 @@ int32_t AudioEngine::process(float* out, uint32_t nFrames) {
currentFreq_ += freqStep;
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;
if (phase_ > 2.0f * M_PI) phase_ -= 2.0f * M_PI;