LoginSignup
0
0

openFrameworksでVDMX5にSyphonでリアルタイム映像を送信する

Last updated at Posted at 2023-12-14

Syphonとは、アプリケーション間で映像をリアルタイムやり取りするためのフレームワークです。同様のフレームワークにNewTekのNDIがある。

VDMX5とはコンピューターでリアルタイムに映像をプレゼン演出するためのアプリで、結婚式やコンサート、クラブの映像演出によく使われる。あと学園祭でも使われたりする。

openFrameworksについては参考リンクにWiki貼っとく。

oFとVDMX5を連携する方法を記す。他者さんの同様の記事もあったが、情報が古かったので自分なりにまとめ直して書いた。

環境

  • Intel CPU
  • OS 11.7.10
  • openFrameworks 0.12.0

ダウンロード

必要なものをダウンロードする

  • openFrameworks
  • ofxSyphon
    openFrameworksのホームページのaddonsからリンクを辿れるのでダウンロードする
  • VDMX5

oFプロジェクトを生成する

ここではofxSyphonアドオンが適用された空のopenFrameworksのプロジェクトを生成するのだが、

まずプロジェクトを生成する前に、projectGeneratorはopenFrameworksフォルダ直下に移動する
そうしないとエラーで動かない

ダウンロードしたofxSyphonはopenFrameworks/addonsフォルダ配下に格納する

projectGeneratorを立ち上げたらAddonsにofxSyphonを追加して、他はいじらずにGenerateボタンを押す
23a.png

するとプロジェクトがopenFrameworks/apps/myApps以下に生成される

適当なアニメーションを書く

とりあえず動作確認として、Syphon関係なしにアニメーションを書いてみる

ofApp.h
#include "ofMain.h"

class ofApp : public ofBaseApp{

    public:
        void setup();
        void update();
        void draw();

    int r,add;

};

ofApp.cpp
#include "ofApp.h"

//--------------------------------------------------------------
void ofApp::setup(){
    r=10;
    add=10;
}

//--------------------------------------------------------------
void ofApp::update(){
   if(r==200)add=-10;
    if(r==10)add=10;
    r=r+add; 
}

//--------------------------------------------------------------
void ofApp::draw(){
    //丸が大きくなったり、小さくなったりするだけのアニメーション

    ofSetColor(200, 0, 0);
    ofCircle(ofGetWidth()/2, ofGetHeight()/2, r);
}

syphonでoFからアニメーションを送信

うまく行ってるようであれば続けてやる

ofApp.h
#pragma once

#include "ofMain.h"
#include "ofxSyphon.h"

class ofApp : public ofBaseApp{

    public:
        void setup();
        void update();
        void draw();
    ofxSyphonServer output;
    int r,add;

};
ofApp.cpp
#include "ofApp.h"

//--------------------------------------------------------------
void ofApp::setup(){
    output.setName("Main");
    r=10;
    add=10;
}

//--------------------------------------------------------------
void ofApp::update(){
   if(r==200)add=-10;
    if(r==10)add=10;
    r=r+add; 
}

//--------------------------------------------------------------
void ofApp::draw(){
    //丸が大きくなったり、小さくなったりするだけのアニメーション

    ofSetColor(200, 0, 0);
    ofCircle(ofGetWidth()/2, ofGetHeight()/2, r);
//ここで送信している
    output.publishScreen();
}

VDMXでアニメーションを受信

VDMXを起動->Templates->simple mixerを選択

oFのアプリをビルド

右クリックでAdd clips from Built-in Sources->syphon->oFアプリを選択

参考リンク

0
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
0
0