7
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

JUCEAdvent Calendar 2024

Day 1

JUCE ハンズオン 2024 ~JUCEをはじめよう~

Last updated at Posted at 2024-11-30

本記事はJUCE Advent Calendar 2024 の12月1日向けに投稿した記事です。

はじめに

本記事は、C++言語向けマルチメディア系アプリケーションフレームワーク『JUCE』の入門者向けの記事になります。記事全体を通して、以下の内容について触れています。

  • JUCEの紹介、特に技術的特徴やその背景について
  • JUCEの開発環境のセットアップ手順について
  • JUCEでプロジェクトを新規作成する手順について

本記事がJUCE入門者のサポートに役立つと幸いです。

本記事は過去に投稿したJUCEハンズオン2023 〜JUCEをはじめよう〜の改訂版になります。
過去の記事をベースに、2024年時点での情報を記載しております。
そのため、過去の記事と内容の多くが重複することをご了承ください。

本記事で対象とするバージョン

  • JUCE 8.0.4
  • Visual Studio 2022
  • Xcode 15.1
  • CMake 3.25以上
  • Git 2.3以上

JUCEについて

JUCE (Jules' Utility Class Extensions) は、C++言語によるマルチメディア系アプリケーションの開発を支援するフレームワークです。
JUCEフレームワークは次の要素によって構成されます。

  • JUCEライブラリ:C++言語で記述されたAPIを提供するクロスプラットフォーム設計のライブラリ
  • Projucer:JUCE専用のプロジェクトジェネレータ、ソースファイルやビルド設定等を管理し、統合開発環境 (IDE = VisualStudio, Xcode)やビルドシステム(Makefile) 向けにプロジェクトファイルを出力する
  • CMakeモジュール:JUCEライブラリをCMakeプロジェクトにインテグレーションするためのモジュールであり、Projucerと同等の機能(リソースのバイナリ化等)も提供する

上記ライブラリ、プロジェクトジェネレータを利用してプロジェクトを構築し、各プラットフォーム用のC++開発環境でビルドすることで、ワンソースからWindows, macOS, Linux, iOS, Android で動作するアプリケーションを作成することができます。
公式サイト

JUCEの特徴

JUCEの最大の特徴として、オーディオプラグインを開発するためのテンプレートが充実していることが挙げられます。VST3/AudioUnit/AAX/LV2/ARAプラグインといった、DTMユーザーにはお馴染みとなっているプラグインフォーマットをワンソースから開発することが挙げられます。効率良くオーディオプラグインを開発できることから、日本国内外で多くの採用事例があります。

公式サイトによる採用事例の紹介

image.png

2024年のトピック: JUCE 8 がリリースされました

2024年6月に JUCE 8 がリリースされました。JUCE 8 は JUCE 7 から2年ぶりのメジャーアップデートとなります。
今回のアップデート内容に含まれるトピック事項は、主にGUI周辺に関するものが多く含まれます。

  • WebViewベースのGUI実装を公式サポート
  • Direct2Dレンダラを新規追加
  • Unicode文字のサポートの強化
  • フォントレンダリング・バックエンドの刷新

特にコミュニティの反響が大きい「WebView UI」については本記事の公開前から詳しく解説をしている記事があります。
外部サイト:【最新版 / 入門】JUCEを使ってVSTプラグインを作ろう!!!!【WebView UI】
特に、WebView UI をきっかけにJUCEに入門する方は上記の記事を参考にすると目的が達成できるかもしれません。

JUCEライブラリ と Projucer

JUCEフレームワークは、各種機能のC++ APIを提供する『JUCEライブラリ』と、各種プラットフォーム向けのプロジェクトを出力するジェネレータ『Projucer』によって構成されます。
『JUCEライブラリ』には機能別に『モジュール』という単位で構成が分かれており、『Projucer』はプロジェクトに必要なモジュールを取り込んで、IDE用のプロジェクトファイルやビルドスクリプトに紐付ける作業を担当します。

JUCE_Projucer.png

JUCEライブラリ と CMake

2020年にリリースされたJUCE 6から、ビルドマネジメントツール『CMake』のサポートが追加されました。

image.png

『CMake』とは、主にC言語、C++言語などC系言語のビルドにおけるクロスプラットフォームビルド環境を提供するビルドマネジメントツールの一つです。様々なプロジェクトに採用されており、大きなエコシステムを形成しています。

JUCEがCMakeをサポートすることで以下のメリットを得ることができるようになりました。

  • ビルド設定をCMake用のフォーマットで記述することができる
  • CMakeのエコシステムの恩恵を受けることができる
  • CMakeが独自に提供する機能を利用することができる
  • CMakeに対応した他のライブラリとのインテグレーションが容易になる
  • Projucerの使い方を習得する必要がなくなる

JUCE_CMake.png

JUCEモジュールについて

JUCEライブラリは、機能毎のAPIがモジュールという単位で分離されて提供されます。例えば、オーディオデバイスとの接続を処理するモジュール、オーディオプラグインフォーマットの定義を持つモジュール、オーディオファイルを読み込む機能を持つモジュール、OSC(Open Sound Control)の機能を抽象化したモジュールなどが提供されます。開発者は、JUCEライブラリから必要なモジュールだけをリンクするように制御することができ、実行環境のOSのAPIやその他ライブラリとの依存関係を制御することができます。

■ JUCEライブラリに付属するモジュール一覧(JUCE 8.0.4時点)

モジュール名 提供する機能やクラス群
juce_analytics アナリティクス機構(ユーザーの利用情報を収集する機能)を提供するクラス群
juce_animation 描画コンポーネントにアニメーション適用を実装するクラス群
juce_audio_basics オーディオバッファの操作、MIDIメッセージ処理、シンセサイザーなどのクラス群
juce_audio_devices オーディオインターフェースおよびMIDIインターフェースの制御や、再生と録音をするクラス群
juce_audio_formats さまざまなオーディオファイル形式を読み込み・書き込みするクラス群
juce_audio_plugin_client VST、VST3、AudioUnit、AAX、LV2、ARAプラグインを構築するためのクラス群
juce_audio_processors VST、AU、または内部で生成されたオーディオプロセッサのロードおよび再生をするクラス群
juce_audio_utils オーディオ関連のGUIおよびその他のタスク(MIDI over BLE含む)を処理するクラス群
juce_box2d Box2D物理エンジンといくつかのユーティリティクラス群
juce_core JUCEモジュールの基盤となる基本API(文字列、メモリ操作)を提供するクラス群
juce_cryptography RSA、Blowfish、MD5、SHAなどの暗号化処理の機能を提供するクラス群
juce_data_structures variantなデータ型を提供する、アンドゥ/リドゥなどを管理する、スマートなデータ構造を操作するクラス群
juce_dsp オーディオバッファ操作、デジタルオーディオ処理、フィルタリング、オーバーサンプリング、数学関数などを高速に実行するクラス群
juce_events アプリケーションのメインイベントループを実行し、メッセージ、タイマーなどを送受信するためのクラス群
juce_graphics 2Dベクトルグラフィックス、画像読み込み/保存、フォント処理などをするためのクラス群
juce_gui_basics 基本的なユーザーインターフェイスを作成するコンポーネントおよび関連するクラス群
juce_gui_extra 特定用途に特化したユーザーインターフェースの実装を提供するクラス群
juce_javascript Javascriptインタープリタを提供するクラス群
juce_midi_ci MIDI 2.0規格に含まれるMIDI Capability Inquiry (MIDI-CI)規格を実装するためのクラス群
juce_opengl JUCEウィンドウでOpenGLをレンダリングするためのクラス群
juce_osc OSC(Open Sound Control)を実装したクラス群
juce_product_unlocking プログラムに認証機構を実装するためのクラス群
juce_video ビデオ再生と、カメラ入力をキャプチャするためのクラス群

なお、JUCEモジュールのフォーマット仕様は公開されているので、ユーザーが独自のJUCEモジュール(3rd party JUCE module)を構築することができます。

ライセンスについて

ライセンスの詳細は公式サイトのEULAをご参照ください。公式: JUCE 8 EULA
JUCEには複数のライセンスオプションが用意されており、ユーザーの事情に応じて選択することができます。

■ライセンスオプション一覧

  • Starter
  • Indie
  • Pro
  • AGPLv3

無料で利用することができるStarterライセンスとAGPLライセンスが設定されています。一定規模以上の事業者かつ配布・商流の形態に応じて、有料のIndieライセンスまたはProライセンスを取得する必要があります。

ライセンスの選択は法的な判断を要しますが、「製品をリリースする予定が無く、JUCEを本格的に使うか否かは試用してから判断したい」という状況であれば、Starterライセンスを選択して学習目的の範囲内で使用することが提案できます。

なお、ライセンス条件は随時改定されることが有ります。使用する際には最新のライセンス条件を確認するようにしましょう。

ライセンスタイプ Starter Indie Pro AGPLv3
年間の収入または資本金額の限度 $20,000 $300,000 - -
サブスクリプション最低契約期間 - 1ヶ月 12ヶ月 -
サブスクリプションライセンス料金 - $40(1名1月当たり) $175(1名1月当たり) -
永続ライセンス料金 - $800 $3,500 -

image.png

JUCEライブラリはオープンソース

JUCE は GitHub 上のリポジトリで開発が行われており、ソースコードも開示されています。Issue やPull request を送ることで不具合報告や機能改善の要望、修正の提案などのプロジェクトに貢献することができます。また、develop ブランチをチェックアウトすることで、将来リリース予定の機能を先行して試すこともできます。

Gitリポジトリ: juce-framework/JUCE

image.png


JUCEをはじめよう[Projucer版]

ここでは、パッケージに同梱されたサンプルプログラムである JUCE DemoRunner を、Projucerを使用する場合にビルドする手順について解説します。
JUCE DemoRunner をビルドできることを確認することで、JUCEフレームワークがサポートする基本的なJUCEアプリケーションの開発環境が整っていることを確認することができます。

開発環境をセットアップする

JUCEを使用したC++プロジェクトを実行可能なプログラムにコンパイルするには、C++言語の開発環境(コンパイラ、ビルドツール等)をセットアップする必要があります。

  • Windows
    • Visual Studio 2022をインストールする
      • IDE本体をインストールする
      • C++開発環境を追加インストールする
  • macOS
    • Xcodeをインストールする
      • AppStoreまたはDeveloper Programから入手してください

参考:JUCEが正式にサポートする開発環境

  • Building JUCE Projects
    • C++ Standard: 17
    • macOS/iOS: Xcode 12.4 (Intel macOS 10.15.4, Apple Silicon macOS 11.0)
    • Windows: Visual Studio 2019 (Windows 10)
    • Linux: g++ 7.0 or Clang 6.0 (for a full list of dependencies, see here).
    • Android: Android Studio (NDK 26) on Windows, macOS or Linux
  • Deployment Targets
    • macOS: macOS 10.11 (x86_64, Arm64)
    • Windows: Windows 10 (x86_64, x86, Arm64, Arm64EC)
    • Linux: Mainstream Linux distributions (x86_64, Arm64/aarch64, (32 bit Arm systems like armv7 should work but are not regularly tested))
    • iOS: iOS 12 (Arm64, Arm64e, x86_64 (Simulator))
    • Android: Android 5 - Lollipop (API Level 21) (arm64-v8a, armeabi-v7a, x86_64, x86)

JUCEを入手する

JUCEを入手するには、大きく2つの方法があります。

  • 公式サイトからダウンロード
  • GitHub上のGitリポジトリをクローン

上記のうち、入門者には『公式サイトからダウンロード』する方法をお勧めします。
『GitHub上のGitリポジトリをクローン』する方法では、Projucerを自身の開発環境でセルフビルドする手順が追加される点にご注意ください。

A. 公式サイトからダウンロードする

本記事ではStarterライセンスを選択した場合のダウンロード手順について案内します。
読者がStarter以外のライセンスを選択する場合は、選択したライセンスに対応するダウンロード手順から入手してください。

JUCE公式サイトのダウンロードページにアクセスする

URL: https://www.juce.com/get-juce

サイト内の[Download]をクリックします

image.png

プラットフォームごとに用意されたリンクからダウンロードします

image.png

プラットフォーム用にビルド済みのProjucerが同梱されています

ダウンロードしたアーカイブファイルを展開すると、以下の画像のようにProjucer実行ファイルが同梱されています。

image.png


B. GitHub上のGitリポジトリをクローンする

Gitリポジトリをローカル環境にクローンする


$ git clone https://github.com/juce-framework/JUCE.git

image.png

Projucerをセルフビルドする

以下のディレクトリに置かれたIDE向けプロジェクトから Projucer をセルフビルドしてください。
ディレクトリ: JUCE/extras/Projucer/Builds/(プラットフォームまたはIDE名)

image.png


ここからは、JUCEフレームワークによるアプリケーション開発環境を準備する手順になります。

Projucerをセットアップする

ここでは、Projucerからアプリケーションプロジェクトを作成するまでのセットアップの手順について示します。

Projucerを起動する

Projucerの初回起動時には、プロジェクト制作画面が表示されます

image.png

JUCEライブラリのPathを設定する

以下の作業を実施して、ProjucerからJUCEモジュールのパスを認識できるようにします。

  1. Projucerを起動する
  2. [File]→[Global Paths...]メニューをクリックして『Global paths』ダイアログを開く
  3. [Path to JUCE]欄にJUCEのルートディレクトリのパスを入力する(入力欄横の[...]をクリックするとファイルダイアログが開きます)
    • 公式サイトからDLした場合はアーカイブの解凍先ディレクトリ
    • git cloneした場合はリポジトリのルートディレクトリ
  4. [JUCE Modules]欄にJUCEディレクトリの直下に置かれた『modules』ディレクトリのパスを入力する

■ Projucerの[File]メニューから[Global Paths...]を選択する
image.png

■ JUCEのルートディレクトリとmodulesディレクトリを設定する
image.png

JUCE DemoRunnerのビルドと実行

JUCEライブラリのパッケージに含まれているデモアプリケーション『JUCE DemoRunner』をビルドすることができれば、JUCEとProjucerのセットアップは完了です。

  • Projucerのメニューから[File]→[Open Example]→[Launch Demo Runner]を選択する
    • 公式サイトからDLした場合、ビルド済みのDemoRunnerバイナリが同梱されているため、ビルドをスキップしてDemoRunnerが起動します
    • git cloneした場合、DemoRunnerを新規にビルドする必要があります。この場合、Projucerのダイアログが表示されて「IDEでプロジェクトを開くか否か」を尋ねられます。それに従ってプロジェクトを開きビルドを実行します
    • JUCEライブラリへのパス設定とDemoRunnerの実行ファイルのビルドが完了している場合に上記操作によってDemoRunnerが起動します

■ Projucerのメニューから[Launch Demo Runner]を選択する

image.png

↓ ビルド実行後に起動 or ビルド不要の場合はそのまま起動

■ JUCE DemoRunner

image.png

DemoRunnerのブラウジングメニューから様々なデモプログラムを起動してみましょう。
各デモプログラムからJUCEライブラリのリファレンス実装を確認することができます。

■ Audio > AudioWorkgroupDemo
image.png

■ GUI > GraphicsDemo
image.png


JUCEをはじめよう[CMake版]

ここでは、CMakeを使用してJUCE DemoRunnerをビルドするまでの手順について示します。
本記事では、CMake自体の使い方やAPI仕様についての詳細は解説を行わない点についてご了承ください。

開発環境のセットアップ

JUCEを使用したC++プロジェクトを実行可能なプログラムにコンパイルするには、C++言語の開発環境(コンパイラ、ビルドツール等)をセットアップする必要があります。

  • Windows
    • Visual Studio 2022をインストールする
      • IDE本体をインストールする
      • C++開発環境を追加インストールする
    • CMakeをインストールする
      • ダウンロードページから入手してインストールする 公式サイト
      • CMakeのパスを環境変数に追加する
  • macOS
    • Xcodeをインストールする
      • AppStoreまたはDeveloper Programから入手してください
    • CMakeをインストールする
      • Homebrewまたはダウンロードページから入手してインストールする 公式サイト
      • CMakeのパスを環境変数に追加する

JUCEを入手する

この項目はProjucer版の説明と同じです。

  • 公式サイトからダウンロードする
  • GitHub上のGitリポジトリをクローンする

JUCE DemoRunnerのビルドと実行

Windows - Visual Studio 2022 の場合

コマンドプロンプトから以下のコマンドを実行してJUCE DemoRunnerをビルドします

REM JUCEディレクトリに移動する
cd (JUCEディレクトリの置かれた場所)/JUCE

REM CMakeのconfigureとgenerateを実行する
REM この時カレントディレクトリ直下に"build"ディレクトリを作成する
cmake -G "Visual Studio 17 2022" -B build -DJUCE_BUILD_EXAMPLES=ON

REM "build"ディレクトリ内に生成されたDemoRunnerプロジェクトのビルドを実行する
cmake --build build --target DemoRunner

JUCE/build/examples/DemoRunner/DemoRunner_artefacts/Debugディレクトリに実行ファイルDemoRunner.exeが生成されます。この実行ファイルを起動すると、JUCE DemoRunnerが立ち上がります。

image.png

macOS - Xcode の場合

ターミナルから以下のコマンドを実行してJUCE DemoRunnerをビルドします

# JUCEディレクトリに移動する
$ cd (JUCEディレクトリの置かれた場所)/JUCE

# CMakeのconfigureとgenerateを実行する
# この時カレントディレクトリ直下に"build"ディレクトリを作成する
$ cmake -G Xcode -B build -DJUCE_BUILD_EXAMPLES=ON

# "build"ディレクトリ内に生成されたDemoRunnerプロジェクトのビルドを実行する
$ cmake --build build --target DemoRunner

JUCE/build/examples/DemoRunner/DemoRunner_artefacts/Debugディレクトリに実行ファイルDemoRunner.appが生成されます。この実行ファイルを起動すると、JUCE DemoRunnerが立ち上がります。

image.png


ここからは、JUCEフレームワークでアプリケーション・プロジェクトを新規作成する手順について解説します。

JUCEでHello Sinewave!

JUCEアプリケーションの開発環境が整ったら、簡単なアプリケーションを作成してみましょう。
今回は、サイン波を鳴らす処理を実装するオーディオプログラミング版 Hello world! を作成します。

プロジェクト作成からコード編集まで [Projucer版]

新規プロジェクトを作成する

Projucerを起動したら、[File]→[New Project...]をクリックして、新規プロジェクト作成画面を表示します。
今回は [Application]→[Audio] テンプレートを選択します。

image.png

新規プロジェクト作成画面の[Exporters]の項目を確認します。ターゲットとするプラットフォームに合わせてチェックを入れます。

  • macOS向け:Xcode にチェックを入れます
  • Windows向け:Visual Studioにチェックを入れます(2022, 2019をサポート)
  • Linux向け:Linux Makefile にチェックを入れます

image.png

新規プロジェクト作成画面の[Create Project]ボタンをクリックします。プロジェクトの保存先を選択するダイアログが開くので、保存先を選択してください。

image.png

新規プロジェクトを作成すると、Main.cpp, MainComponent.h, MainComponent.cpp の3つのソースファイルが作成されます。

image.png

プロジェクトの保存とIDEでプロジェクトを開く

Projucerで新規プロジェクトの保存と、IDE(VisualStudio、Xcode)でプロジェクトを開きます。

  1. Projucer上部のコンボボックスから、起動したいIDEを選択します
  2. IDEのアイコンが表示されているボタンをクリックします
  3. プロジェクトの保存とIDEの起動が実行されます

image.png

プロジェクト作成からコード編集まで [CMake版]

CMakeを使用してJUCEアプリケーションを作る場合、ソースファイルの作成や、ビルド設定の記述をCMakeLists.txtに記述していく作業を開発者自身で行う必要があります。
そのため、Projucerでプロジェクトを新規作成する場合と比べると、プロジェクトの最小の構成を組み上げるまでの手順が増えることになります。
本記事ではその手順を割愛して、私が作成した最小構成のCMake向けテンプレートを使用して説明をしていきます。

筆者作成のテンプレートを git clone する

筆者が作成したオーディオアプリケーションのテンプレートを以下のGitリポジトリに配置しました。
コマンドプロンプトやターミナルから次のコマンドを実行して、GitリポジトリのクローンとGitサブモジュールの初期化を実行してください。
Gitリポジトリ: juce_hands-on_2024.git

# Gitリポジトリのクローンと併せて内部のGitサブモジュールもクローンする
$ git clone --recursive https://github.com/COx2/juce_hands-on_2024

プロジェクトのファイル構成について

このテンプレートは以下のファイル構成になっています。
Sourceディレクトリに置かれたソースコードは、Projucer版の項目で説明したものと同一のファイルとなっています。

juce_hands-on_2024/
 ├ External/
  │  └ JUCE/  # Gitサブモジュールとして取り込んだJUCEリポジトリ
 ├ Source/   # プロジェクトのソースコードを配置するディレクトリ
  │  ├ Main.cpp
  │  ├ MainComponent.h
  │  └ MainComponent.cpp
 ├ CMakeLists.txt  # CMakeで実行するビルド設定を記述するテキストファイル
 └ LICENSE

上記のファイルのうち、CMakeLists.txtは以下の記述となっています。
CMakeのプロジェクトからJUCEライブラリを取り込むことで、JUCEライブラリ内に含まれるCMakeモジュールが読み込まれ、JUCE CMake APIが使えるようになります。
JUCE CMake APIについては JUCE/docs/CMake API.md にドキュメントが用意されています。

# CMakeの最低バージョンを特定する
cmake_minimum_required(VERSION 3.22)

# プロジェクト名を設定する
project(juce_hands-on_2024 VERSION 1.0.0)

# C++に関するオプション設定
enable_language(CXX)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_CXX_EXTENSIONS OFF)

# Visual Studioのコンパイラに文字エンコードをUTF-8であることを設定するコンパイルオプション
if(CMAKE_CXX_COMPILER_ID MATCHES "MSVC")
    add_compile_options(/utf-8)
endif()

# JUCEライブラリの場所を特定する
# JUCEライブラリ内に含まれるCMakeモジュールが読み込まれ、JUCE CMake APIが使えるようになる
add_subdirectory(External/JUCE)

# GUIアプリケーション版のJUCEプロジェクトを追加する
# プロジェクト名は"NewProject"にする
juce_add_gui_app(NewProject
    PRODUCT_NAME "NewProject")

# "NewProject"のソース上で"#include <JuceHeader.h>"によるJUCEライブラリのインクルードを可能にする
juce_generate_juce_header(NewProject)

# "NewProject"にC++ソースファイルを追加する
target_sources(NewProject
    PRIVATE
        Source/Main.cpp
        Source/MainComponent.h
        Source/MainComponent.cpp)

# "NewProject"に適用するコンパイル定義を設定する
target_compile_definitions(NewProject
    PRIVATE
        JUCE_APPLICATION_NAME_STRING="$<TARGET_PROPERTY:NewProject,JUCE_PRODUCT_NAME>"
        JUCE_APPLICATION_VERSION_STRING="$<TARGET_PROPERTY:NewProject,JUCE_VERSION>")

# "NewProject"にリンクするライブラリを決定する
target_link_libraries(NewProject
    PRIVATE
        juce::juce_audio_utils
    PUBLIC
        juce::juce_recommended_config_flags
        juce::juce_recommended_lto_flags
        juce::juce_recommended_warning_flags)

CMakeのconfigureとgenerateを実行する

コマンドプロンプトやターミナルから次のコマンドを実行すると、CMakeのconfigureとgenerateが実行され、IDE用のプロジェクトが生成されます。
なお、CMake --buildコマンドを実行することでコマンドラインからビルドを実行することもできます。

Windows - Visual Studio 2022 の場合

REM リポジトリのディレクトリに移動する
cd (リポジトリが置かれた場所)/juce_hands-on_2024

REM CMakeのconfigureとgenerateを実行する
REM この時カレントディレクトリ直下に"build"ディレクトリを作成する
cmake -G "Visual Studio 17 2022" -B build

REM "build"ディレクトリ内に生成されたプロジェクトのビルドを実行する
cmake --build build

macOS - Xcode の場合

# リポジトリのディレクトリに移動する
$ cd (リポジトリが置かれた場所)/juce_hands-on_2024

# CMakeのconfigureとgenerateを実行する
# この時カレントディレクトリ直下に"build"ディレクトリを作成する
$ cmake -G Xcode -B build

# "build"ディレクトリ内に生成されたプロジェクトのビルドを実行する
$ cmake --build build

IDEでプロジェクトを開く

CMakeのconfigureとgenerateを実行すると、juce_hands-on_2024/buildディレクトリにIDE向けのプロジェクトファイルが生成されます。プロジェクトファイルをIDEで開くことで、IDE上でソーコードの編集を始めることができます。

サイン波を鳴らすプログラムを実装する

プロジェクト内のソースコードを編集して、サイン波を鳴らす処理を実装してみましょう。
MainComponent.cppにある関数void getNextAudioBlock (const AudioSourceChannelInfo& bufferToFill) overrideの内部実装を以下のように編集します。

#include "MainComponent.h"

~~~中略~~~

void MainComponent::getNextAudioBlock (const juce::AudioSourceChannelInfo& bufferToFill)
{
    bufferToFill.clearActiveBufferRegion();

    const float level = 0.5f;

    auto* buffer = bufferToFill.buffer;
    for (int channel = 0; channel < buffer->getNumChannels(); channel++)
    {
        float* channelData = buffer->getWritePointer(channel);

        for (int sample = 0; sample < buffer->getNumSamples(); sample++)
        {
            channelData[sample] = std::sin(juce::MathConstants<float>::twoPi * sample / buffer->getNumSamples() * 2) * level;
        }
    }
}
~~~中略~~~

このソースコードを記述すると、オーディオバッファを更新する度に、オーディオバッファ全体でサイン波一周分(360°=2π)を書き込む処理が実行されます。

juce_hands-on_2013.jpg

ビルドと動作確認

上記のソースコードを記述したら、ビルドを実行します。
ビルドが成功したらアプリケーションを起動してみましょう。
アプリケーションを起動すると、ウインドウが表示されるとともに、オーディオデバイスとの連携が正常にできていれば、サイン波が鳴っているのが聞こえるはずです。

image.png

トラブルシューティング:音が鳴らない場合

プログラムとオーディオデバイスを正常に連携できていない可能性があります。
以下の記事を参考にオーディオデバイス設定の編集を試してみてください。


JUCEのことをもっと知りたくなったら

ドキュメントを読んでみよう

JUCEライブラリには沢山のAPIが用意されています。JUCE APIを理解することが快適なアプリケーション開発への近道と言えるでしょう。

・API:モジュール
https://docs.juce.com/master/modules.html

・API:クラスリファレンス
https://docs.juce.com/master/index.html

公式サイトには入門者向けのチュートリアルが提供されています。チュートリアルを一通り試してみると、JUCE APIの使い方について体系的に学習することができます。

・チュートリアル
https://juce.com/learn/tutorials

フォーラムサイトを覗いてみよう

JUCEは公式のフォーラムサイトを設置しています。
ユーザーからの疑問・質問にJUCEのメンテナが回答してくれたり、ユーザー間で知見の共有が行われています。

・JUCEフォーラム
https://forum.juce.com/

JUCEを利用したオープンソースプロジェクト

JUCEを利用したオープンソースなプロジェクトを紹介します。
様々なプロジェクトのソースコードから、JUCE APIの使い方やJUCEならではの実装テクニックについても触れることができるでしょう。

Vital

GitHubリポジトリ:https://github.com/mtytel/vital

リッチなグラフィック表現を搭載したウェーブテーブルシンセサイザ

image.png

Wavetable

GitHubリポジトリ:https://github.com/FigBug/Wavetable

FigBug氏によるWavetableシンセサイザ
image.png

CHOWTapeModel

GitHubリポジトリ:https://github.com/jatinchowdhury18/AnalogTapeModel

テープエフェクトを物理シミュレーションしたエフェクトプラグイン

image.png

Utility clone

GitHubリポジトリ:https://github.com/m1m0zzz/utility-clone

Ableton Liveの内蔵エフェクトをVST形式で再現したエフェクトプラグイン。
LiveライクなUIを表現する LookAndFeel のカスタム実装がチャレンジング。

image.png

Magical8bitPlug2

GitHubリポジトリ:https://github.com/yokemura/Magical8bitPlug2

8bitサウンドのクリエイターとして著名なYMCK Yokemura氏が開発した、往年の8bitゲーム機サウンドを奏でるシンプルなインストゥルメントプラグイン

image.png

OB-Xd

GitHubリポジトリ:https://github.com/reales/OB-Xd

Oberheim OB-Xをエミュレート&モディファイしたVAシンセサイザ

image.png

tracktion_engine

GitHubリポジトリ:https://github.com/Tracktion/tracktion_engine

Tracktion社のDAW『Waveform』で使用されている、DAWの音楽演奏・再生などを司るエンジン部分
JUCEを利用して開発されており、ライセンスを取得してオリジナルのDAWを自作することができる
こちらの解説記事が参考になります

image.png

7
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?