• D言語でSDL

    2011年03月12日 14時23分
    稀に需要があるようなので置いておきます。

    SDLのD言語ポーティング

    SDL 1.2.14ベースです。
    OpenGLも入れておきました。


    人間の手で作業している部分も多いので、使っていて何かおかしいと思ったら大体変換がおかしいと思います。
    可能な限り直したいと思いますので、「ここなんか動かない」とか教えていただけると助かります。


    ビルド環境は各自でご用意願います。
    例えばビルドする場合はSDLのライブラリが必要です。(OpenGLを使う場合はOpenGLのも)
    Windowsですと、本家のSDLに含まれるBorland.zip内のSDL.libが必要です。
    OpenGLのlibはWindows SDKに含まれますが、COFF形式なのでcoff2omfで変換する必要があります。

    coff2omfは昔はDigital Marsで無償ダウンロード出来たと思うのですが、
    今は有償になったかリンクが切れてるかしているようです。


    実行環境についても各自でご用意願います。
    WindowsならばOpenGLの実行環境はあるはずなので、
    SDL本家のWindows用DLLをダウンロードするだけだと思います。


    モジュールについては下記のような簡単なサンプルプログラムだけは試しました。
    1import core.runtime;
    2import std.c.windows.windows;
    3import org.libsdl.sdl;
    4import org.opengl.gl;
    5
    6//--------------------------------------------------------------
    7// D言語でWindowsアプリを作るときの基本処理
    8
    9extern (Windows)
    10int WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
    11{
    12    void exceptionHandler(Throwable e)
    13    {
    14        throw e;
    15    }
    16
    17    int result;
    18    try
    19    {
    20        Runtime.initialize(&exceptionHandler);
    21        scope (exit) Runtime.terminate(&exceptionHandler);
    22
    23        dmain();
    24    }
    25    catch (Throwable o)
    26    {
    27        MessageBoxA(nullcast(char*)o.toString(), "Error", MB_OK | MB_ICONEXCLAMATION);
    28        result = 1;
    29    }
    30
    31    return result;
    32}
    33
    34
    35//--------------------------------------------------------------
    36// メインの処理
    37
    38// 画面サイズ
    39immutable int SCREEN_WIDTH = 640;
    40immutable int SCREEN_HEIGHT = 480;
    41
    42void dmain()
    43{
    44    if (SDL_Init(SDL_INIT_VIDEO) < 0)
    45        throw new Error("SDL_Init failed.");
    46    scope(exit) SDL_Quit();
    47
    48    SDL_GL_SetAttribute(SDL_GL_DOUBLEBUFFER, 1);
    49    SDL_Surface* screen = SDL_SetVideoMode(SCREEN_WIDTH, SCREEN_HEIGHT, 32, SDL_OPENGL);
    50    if (screen is null)
    51        throw new Error("SDL_SetVideoMode failed.");
    52
    53    glClearColor(0.0f, 0.5f, 0.0f, 0.0f);
    54
    55    glOrtho(0.0, SCREEN_WIDTH, SCREEN_HEIGHT, 0.0, -1.0, 1.0);
    56
    57    for (;;)
    58    {
    59        SDL_Event event;
    60        while (SDL_PollEvent(&event))
    61        {
    62            if (event.type == SDL_QUIT)
    63                return;
    64        }
    65
    66        glClear(GL_COLOR_BUFFER_BIT);
    67
    68        glBegin(GL_TRIANGLES);
    69
    70        glColor3f(1.0f, 0.5f, 1.0f);
    71
    72        glVertex3f(100.0f, 100.0f, 0);
    73        glVertex3f(600.0f, 300.0f, 0);
    74        glVertex3f(50.0f, 400.0f, 0);
    75
    76        glEnd();
    77
    78        SDL_GL_SwapBuffers();
    79    }
    80}


    実行結果
    スクリーンショット


    ちなみに私はDirectX派です。
    Windowsのみ対応で良いならDirectXのほうが慣れてて使いやすいなぁと思います。
  • OpenSL ES Tips (On VIVID Runtime)

    2011年03月09日 23時35分
    OpenSL ES自体はサンプルとリファレンス見ながら
    なんとなく使えるとは思います。

    なので、何点か引っかかったとこだけ記しておこうと思います。

    MIDI再生を使用していたときに調べたことなので、
    基本的にMIDI再生に関することだと思ってください。
    WaveとかMP3も当てはまるかもしれませんが未検証です。

    また、対象のVIVID Runtime SDKのバージョンは1.1です。
    最近1.2が出ているので、そちらでは改善されているかもしれません。

    音量について

    SLVolumeItfのSetVolumeLevelで設定するわけですが、
    この引数が「SL_MILLIBEL_MIN ~ 端末のサポートする最大値(多くの場合は0)」と書いてあるのですが、
    SL_MILLIBEL_MINを指定するとエラーが返ってきます。
    (エミュレータとXperiaで確認)

    エラーが出ない数値を探ると-2000でした。
    なので、-2000 ~ 0の間で指定しましょう。

    端末によってはこの数値も怪しいかもしれません。

    あと、SL_MILLIBEL_MAXというのが定義されていまして、
    これが最大値っぽいですが全然違うので気をつけましょう。

    プレイヤーの解放について

    MIDIのプレイヤーはCreateMidiPlayerで作成するわけですが、
    これを解放する前には手動でSLPlayItfのステータスをSL_PLAYSTATE_STOPPEDにしなければなりません。

    SL_PLAYSTATE_PAUSEDのままDestroyしてしまうと
    どうもきちんと解放されないようです。
    (実機が落ちたり、動作が不安定になりました。)

    MIDIの複数再生について

    CreateMidiPlayerで再生オブジェクトを2個作ると
    何故か再生速度が速くなります。

    2個作ってはいけないのかもしれません。

    CreateMidiPlayer & CreateAudioPlayerで2個作ると
    Xperiaは大丈夫でしたがエミュレータだと同じ現象です。

    これは未だ解決方法不明です。
  • VIVID Runtimeはじめました Ogg vorbis編

    2011年03月07日 23時00分
    VIVID Runtimeは音声再生にOpenALとOpenSL ESがありますが、
    公式にはOpenSL ESの方をプッシュしてきます。

    だったら最初から片方だけにしとけばいいんじゃとか思わないでもないですが、
    複雑な事情があるのでしょう。


    私は素直な人間なので、お勧めされるがままにOpenSL ESを使いました。

    しかしこのOpenSL ESですが、全く普及している気配がありません。
    私などは今回初めてこの単語を目にしたくらいです。

    ネット上を調べてみても情報がさっぱり出てきません。

    一応Kronos公式ドキュメントがSDKに含まれるので
    なんとかなるといえばなるのですが・・・
    たまに実装とドキュメントが違うこともあるので気が抜けません。



    今回ゲームのBGMにOgg vorbisを使えないかという相談を受けました。
    しかしOpenSL ESは対応していないようです。

    どうもOpenSL ES 1.1ならば対応している気配があるのですが、
    VIVID Runtime SDKに含まれるのは1.0です。

    1.0でもMP3ならば再生出来るのですが、MP3だとライセンス料が半端ないので使いにくいです。
    もしかしたらVIVID Runtime側でライセンス処理をしてるかもしれませんが、その辺り不明です。

    そこで今回はVIVID Runtime上で頑張ってOgg vorbisを再生してみます。


    そもそもWaveの再生はあるのです。
    SDKのサンプルにplaystreamというのがあり、これがメモリ上のWaveデータを再生しています。

    ということは、vorbisデータをデコードして
    このバッファにぶち込んでやれば再生出来るということになります。

    そこで早速libogg-1.2.2とlibvorbis-1.3.2を入手しました。

    私は未だにconfigureとかmakeとかよくわからんのですが、
    要はCコードをVIVID Runtime SDKに含まれるクロスコンパイル環境でコンパイルしてやればいいと思うのです。

    例えばoggならばこんな感じです。
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 src\framing.c -o framing.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 src\bitwise.c -o bitwise.o
    
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-ar.exe" rcs libogg.a framing.o bitwise.o

    ※config_types.hにconfigureでOS判定して埋め込む部分があったのでそこだけは手動で解決しています。

    同じ感じでvorbisの方も作成します。


    作成したライブラリとヘッダを次のフォルダに配置します。
    $VIVID_RUNTIME_SDK\tools\gcc_toolchain\arm-runtime-eabi\usr

    ※$VIVID_RUNTIME_SDKはVIVID Runtime SDKを展開したフォルダ


    こうするとビルド時に参照することが出来ます。


    あとはサンプルのコードにvorbisのデコード処理を入れて完了です。

    で、実行してみたのですが、デコードが追いつきません。
    エミュレータとはいえ、Phenom II 3GHzで足りないという状態です。
    中でどんな処理してるんだろう・・・


    これはもう少しなんとかならんかと調べてみたのですが、
    Tremorという整数演算で高速デコードするバージョンがありました。
    しかもARM用に最適化してあったりします。

    これをチェックアウトしてきておりゃおりゃっとビルドします。
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 mdct.c -o mdct.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 block.c -o block.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 window.c -o window.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 synthesis.c -o synthesis.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 info.c -o info.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 floor1.c -o floor1.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 floor0.c -o floor0.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 vorbisfile.c -o vorbisfile.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 res012.c -o res012.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 mapping0.c -o mapping0.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 registry.c -o registry.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 codebook.c -o codebook.o
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-gcc.exe" -I include -c -fpic -mno-thumb-interwork -Wall -O3 sharedbook.c -o sharedbook.o
    
    "C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\bin\arm-runtime-eabi-ar.exe" rcs libvorbisidec.a mdct.o block.o window.o synthesis.o info.o floor1.o floor0.o vorbisfile.o res012.o mapping0.o registry.o codebook.o sharedbook.o

    ※os.hのエンディアンの設定がよろしくないので調整しています。


    出来たlibvorbisidec.aでデコードしてみたところなんとか再生できました。
    本当になんとか・・・といった感じで、稀にデコードが追いついていません。

    あとはFPUを使って最適化でなんとかならんかなと思うのですが、
    ARMのFPUを使ったデコーダは見つけられませんでした。
    さすがに自分で書く気も起きません。


    エミュレータで厳しくても実機ならいけるんじゃないか?と思わなくもないのですが、
    今は手元に実機がないんですよねぇ・・・。Xperia arcでも買おうかしら。


    今回使ったファイル
  • VIVID Runtimeはじめました 実機編

    2011年03月01日 22時41分
    エミュレータでの実行は簡単ですが、実機での実行は一手間かかります。

    この辺りを覚えている限り書きたいと思います。
    かなり試行錯誤しつつ作業していたので、間違いがある可能性がありますがご容赦ください。
    前回書き忘れましたが、私の環境はWindows 7 64bit Ultimateです。



    実機での実行には次の2パターンがあります。
    • thrip.exeがadb.exeを使って転送し実行
    • rpkを作成してSDカードに転送し実行

    開発中には前者で行い、テスト終盤は後者で行うことになるかと思います。


    証明書の準備

    上記2パターンのどちらの場合でも証明書が必要になります。
    証明書は1実機につき1つ必要です。
    複数の実機で実行する場合は複数必要です。


    証明書を取得するための証明書署名要求(CSR)と秘密鍵ファイルを作成します。

    作成にはOpenSSLが必要です。OpenSSLは次のサイトからダウンロードしてインストールします。
    http://www.slproweb.com/products/Win32OpenSSL.html
    実行にはVisual C++ 2008の再配布パッケージが必要になるので、インストールしていない場合はこれもインストールします。


    作成はコマンドプロンプトから行います。

    VIVID Runtime SDKのcertificatesフォルダに移動
    (SDKのパスに合わせて調整してください。)
    cd C:\vivid_runtime_sdk_1_1\certificates


    環境変数PATHに一時的にOpenSSLのbinフォルダを追加。
    (これは64bitバージョンの例です。インストールしたパスに合わせて調整してください。)
    set PATH=%PATH%;C:\OpenSSL-Win64\bin


    gen_request.batを実行します。
    gen_request.bat


    IMEI Codeを入力します。
    IMEI Codes:IMEI:01234567890123

    IMEI:の文字列も自分で入力しなければならないので注意してください。
    また、IMEI Codeの最後の1文字はCheck Digitなのでここでは入力しません。(数字14桁を入力します。)

    IMEI Codeは動作させる実機から取得します。
    多くの機種では電話をかける画面で*#06#と入力すると表示されるようです。(Xperiaで確認)
    この辺りは機種毎に確認してください。

    @GMOゲームセンター デベロッパーサイトのログインIDを入力します。
    Developer portal login  []:hogehoge


    以上でcertificatesフォルダに、developer.csrdeveloper.keyファイルが作成されます。

    このdeveloper.csrを@GMOゲームセンター デベロッパーサイトにアップロードすると
    証明書(developer.cert)が取得出来ます。
    この手順はサイトにログインすればすぐわかるかと思います。

    取得したdeveloper.certはcertificatesに配置します。


    ※今回developer.csr, developer.key, developer.certはcertificatesフォルダに配置しましたが、
    実機が複数の場合はアプリのビルド時に個別に指定する必要があります。


    adb.exeの準備

    adb.exeは実機に対して色々な操作を行うツールです。
    実機へのファイルのやりとり、アプリのインストールに使用します。

    このツールはAndroid SDKをインストールした後、
    SDK Manager.exeを起動し、Android SDK Platform-toolsをインストールすると手に入ります。

    adb.exeについてはthrip.exeから呼び出される為、PATHを通しておく必要があります。
    環境変数PATHにAndroid SDKのplatform-toolsフォルダを追加してください。


    ランタイムのインストール

    VIVID Runtime SDKで作成したプログラムを実機で実行するには、
    予めランタイムと管理アプリを実機にインストールしておく必要があります。

    ランタイムについてですが、私の手元に実機が届いた時点で既にインストール済みだったため不正確ですが、Gゲーアプリのはずです。

    管理アプリは@GMOゲームセンター デベロッパーサイトで
    VIVID Runtime SDKと一緒に置いてありますので、adbを使ってインストールします。

    USBケーブルで実機を繋ぎ、次のコマンドを実行します。
    adb install VIVIDRuntimeManager.apk


    thrip.exeがadb.exeを使って転送し実行する場合

    thrip.exeはVIVID Runtime SDKのツールです。
    VIVID Runtime SDKをインストールしてあれば使うことが出来ます。

    一度thrip.exeで実行すると、タスクトレイに次のアイコンが出ます。
    アイコン

    これを選択し、次のダイアログでProfileをandroidにすると実機での実行になります。
    ダイアログ

    上記ダイアログを設定した後、thrip.exeで実行すると、
    Android上のVIVID Runtime Managerにアプリが表示されますので、そこから起動出来ます。

    rpkを作成してSDカードに転送し実行する場合

    rpkを作成するには、ビルド設定ファイル(hogehoge.vcproj.config)ファイルの次の項目にTrueを設定します。
    <use_package>True</use_package>


    これでビルドすればrpkファイルが作成されます。

    このrpkファイルをSDカードのルートにコピーします。
    実機をUSBケーブルで接続し、SDカードをマウントすれはコピー出来ます。

    VIVID Runtime Managerからインストールするためにはマウントを解除しなければならないのでご注意ください。

    SDカードを取り外してPCに刺してやってもいいと思いますがめんどくさいです。


    rpkファイルをコピーした後、Android上のVIVID Runtime Managerを起動します。
    メニューボタンを押し、installを選択するとコピーしたアプリが表示されるのでインストールしてください。
  • VIVID Runtimeはじめました

    2011年02月19日 11時21分
    最近書いた記事のため下書きが残っていました。再投稿します。


    MacbookとiPod touchを買ってきてにわかにやる気だったのですが、
    依頼された仕事はAndroidでした。


    死亡フラグみたいなもんだったわけです。


    今回作ったのはアンドロイドやろうぜ!by GMO向けゲームでした。

    利用規約等を見たところ、特に守秘義務が無かったので、
    開発について覚えている限り書いてみようと思います。


    アンドロイドやろうぜ!by GMOのゲームは、GoogleのAndroid SDKではなく、
    AcrodiaのVIVID Runtimeという物を使います。
    詳細については公式ページを参照下さい。

    VIVID Runtime SDKはAndroid SDKと違い、C/C++/Objective-Cでの開発が可能です。
    これらの言語で書いたソースをgccでコンパイルます。

    ネイティブコード実行になるのでゲーム向きと言えるでしょう。
    ただ、ARM向けにコンパイルされるので、x86のAndroid端末だと動かないと思います。(未検証)


    開発環境

    開発を始めるには、VIVID Runtime SDKが必要になります。
    これは、@GMOゲームセンター デベロッパーサイトにCPとして登録するとダウンロードすることが出来ます。

    私が使用したのはバージョン 1.1でした。

    これを任意のフォルダに解凍します。


    C:\vivid_runtime_sdk_1_1


    以上で開発環境の構築は完了です。簡単。


    プログラム作成

    例によってHello work!!プログラムを作ってみましょう。
    最小限のコードは次の通りです。

    1#include <KD/kd.h>
    2
    3KDint kdMain(KDint argc, const KDchar *const * argv)
    4{
    5    kdLogMessage("Hello work!!");
    6    return 0;
    7}


    main.cppとして保存します。


    ビルドと実行

    ビルドを行うためには設定ファイルを書く必要があります。
    どのプロジェクトでもだいたい同じだと思うので、まずは下記のサンプルをまるコピしてみてください。

    <?xml version="1.0" encoding="shift_jis"?>
    <VisualStudioProject
    	ProjectType="Visual C++"
    	Version="9.00"
    	Name="Hello work"
    	ProjectGUID="{329BA7C7-513D-406D-BCC8-D813DCCD497A}"
    	RootNamespace="Platform"
    	Keyword="MakeFileProj"
    	TargetFrameworkVersion="196613"
    	>
    	<Platforms>
    		<Platform
    			Name="Win32"
    		/>
    	</Platforms>
    	<ToolFiles>
    	</ToolFiles>
    	<Configurations>
    		<Configuration
    			Name="Debug|Win32"
    			OutputDirectory="$(ConfigurationName)"
    			IntermediateDirectory="$(ConfigurationName)"
    			ConfigurationType="0"
    			>
    			<Tool
    				Name="VCNMakeTool"
    				BuildCommandLine="C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe vs build &quot;$(InputFilename)&quot; $(ConfigurationName)"
    				ReBuildCommandLine="C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe vs rebuild &quot;$(InputFilename)&quot; $(ConfigurationName)"
    				CleanCommandLine="C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe vs clean &quot;$(InputFilename)&quot; $(ConfigurationName)"
    				Output="hello_work.exe"
    				PreprocessorDefinitions=""
    				IncludeSearchPath="C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\arm-runtime-eabi\usr\include"
    				ForcedIncludes=""
    				AssemblySearchPath=""
    				ForcedUsingAssemblies="KD"
    				CompileAsManaged=""
    			/>
    		</Configuration>
    		<Configuration
    			Name="Release|Win32"
    			OutputDirectory="$(ConfigurationName)"
    			IntermediateDirectory="$(ConfigurationName)"
    			ConfigurationType="0"
    			>
    			<Tool
    				Name="VCNMakeTool"
    				BuildCommandLine="C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe vs build &quot;$(InputFilename)&quot; $(ConfigurationName)"
    				ReBuildCommandLine="C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe vs rebuild &quot;$(InputFilename)&quot; $(ConfigurationName)"
    				CleanCommandLine="C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe vs clean &quot;$(InputFilename)&quot; $(ConfigurationName)"
    				Output="hello_work.exe"
    				PreprocessorDefinitions="KD_NDEBUG"
    				IncludeSearchPath="C:\vivid_runtime_sdk_1_1\tools\gcc_toolchain\arm-runtime-eabi\usr\include"
    				ForcedIncludes=""
    				AssemblySearchPath=""
    				ForcedUsingAssemblies="KD"
    				CompileAsManaged=""
    			/>
    		</Configuration>
    	</Configurations>
    	<References>
    	</References>
    	<Files>
    		<File RelativePath=".\main.cpp"></File>
    	</Files>
    	<Globals>
    	</Globals>
    </VisualStudioProject>


    hello_work.vcprojとして保存します。

    main.cppとhello_work.vcprojを同じフォルダに置き、
    コマンドプロンプトでそのフォルダにcdします。

    ビルドは次のコマンドになります。
    C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe vs build hello_work.vcproj Debug


    実行は次のコマンドになります。
    C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe vs debug hello_work.vcproj Debug


    実行すると、「Hello Work!!」と表示されるはずです。
    (QEMUでエミュレーションしているようです。)


    hello_work.vcprojの内容については見覚えのある人も多いと思いますが、
    これはVisual Studioのプロジェクトファイルです。

    よって、もちろんVisual Studioで開くことが出来ますし、そこからビルドすることも出来ます。
    (Visual Studio Express Editionで確認。)



    Visual Studio上から実行する場合についてはもう一つ設定ファイルが必要です。
    次の内容をhello_work.vcproj.userとして保存します。
    <?xml version="1.0" encoding="shift_jis"?>
    <VisualStudioUserFile
    	ProjectType="Visual C++"
    	Version="9.00"
    	ShowAllFiles="false"
    	>
    	<Configurations>
    		<Configuration
    			Name="Debug|Win32"
    			>
    			<DebugSettings
    				Command="C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe"
    				WorkingDirectory=""
    				CommandArguments="vs debug &quot;$(InputFilename)&quot; $(ConfigurationName)"
    				Attach="false"
    				DebuggerType="3"
    				Remote="1"
    				RemoteMachine=""
    				RemoteCommand=""
    				HttpUrl=""
    				PDBPath=""
    				SQLDebugging=""
    				Environment=""
    				EnvironmentMerge="true"
    				DebuggerFlavor="0"
    				MPIRunCommand=""
    				MPIRunArguments=""
    				MPIRunWorkingDirectory=""
    				ApplicationCommand=""
    				ApplicationArguments=""
    				ShimCommand=""
    				MPIAcceptMode=""
    				MPIAcceptFilter=""
    			/>
    		</Configuration>
    		<Configuration
    			Name="Release|Win32"
    			>
    			<DebugSettings
    				Command="C:\vivid_runtime_sdk_1_1\tools\thrip\thrip.exe"
    				WorkingDirectory=""
    				CommandArguments="vs debug &quot;$(InputFilename)&quot; $(ConfigurationName)"
    				Attach="false"
    				DebuggerType="3"
    				Remote="1"
    				RemoteMachine=""
    				RemoteCommand=""
    				HttpUrl=""
    				PDBPath=""
    				SQLDebugging=""
    				Environment=""
    				EnvironmentMerge="true"
    				DebuggerFlavor="0"
    				MPIRunCommand=""
    				MPIRunArguments=""
    				MPIRunWorkingDirectory=""
    				ApplicationCommand=""
    				ApplicationArguments=""
    				ShimCommand=""
    				MPIAcceptMode=""
    				MPIAcceptFilter=""
    			/>
    		</Configuration>
    	</Configurations>
    </VisualStudioUserFile>


    ビルド(追加情報)

    Visual Studioの設定ファイルからだと、設定出来る項目に限界があります。
    そのため、追加の設定ファイルも用意することになります。

    追加設定については、hello_work.vcproj.configファイルで設定します。
    内容はこんな感じです。
    <?xml version="1.0" encoding="utf-8" ?>
    
    <!-- This is a VIVID Runtime specific configuration file. Please see VIVID Runtime SDK documentation for details.-->
    <config>
    
      <!-- Common properties for all configurations. -->
      <common>
        <!-- Verbose compiler and linker output. -->
        <verbose>true</verbose>
    
        <!-- General options. -->
        <!-- <warning_level>1</warning_level> -->
        <!-- <optimization_level>3</optimization_level> -->
        <!-- <include_symbols>false</include_symbols> -->
        <!-- <thumb>true</thumb -->
        <!-- <interworking>true</interworking -->
        <!-- <pic>true</pic> -->
    
        <!-- Determines whether the general options listed above are used. If false, you must supply the needed flags using compiler and linker options. -->
        <enable_general_options>true</enable_general_options>
    
        <!-- Determines whether the automatic options depending on the output target type (.a, .so, .exe) are used. If false, you must supply your own options. -->
        <enable_automatic_options>true</enable_automatic_options>
    
        <!-- Additional compiler flags passed directly to compiler. -->
        <compiler_options></compiler_options>
    
        <!-- Additional compiler flags passed directly to linker. -->
        <linker_options></linker_options>
    
        <!-- Postbuild action that points to an .exe or .bat -->
        <!--postbuild_action></postbuild_action-->
      </common>
    
      <!-- Configuration specific overrides for "release" configuration. You can also add other configuration names here if available in the project. -->
      <configuration name="release">
        <!-- You can put any of the property values in the common section here as well. -->
      </configuration>
    
      <!-- Configuration specific overrides for "debug" configuration. -->
      <configuration name="debug">
        <!-- You can put any of the property values in the common section here as well. -->
      </configuration>
    
    </config>


    この内容については完全に把握出来ていないので、マニュアルを参照してください。
    私が読んでもよくわかりませんでした。


    リリース時に使用する設定情報を記載するファイルもあります。
    これは、rpkという名前のフォルダを作り、その中にconfig.xmlという名前で配置するようです。


    また、この2つのファイルを設定するアプリが用意されています。
    コマンドプロンプトから次の様に起動します。
    C:\vivid_runtime_sdk_1_1\tools\thrip\config.exe hello_work.vcproj.config rpk\config.xml



    最後に

    以上が基本的な開発環境設定になります。
    まとめて見るとそんなに複雑ではないのですが、
    初心者がノーヒントの状態から内容を把握するのは大変でした。

    あと、Eclipseでも開発出来るそうですが、私はVisual Studio派なので調べませんでした。
    Eclipse派は自力で調べてください。