1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151
|
title:: 06
summary:: Mark Polishook tutorial (JP)
categories:: Tutorials>Mark_Polishook_tutorial>Japanese_version
related:: Tutorials/Mark_Polishook_tutorial/00_Introductory_tutorial
section::SynthDefのプロパティに関する議論を続けるために、次を評価してみて下さい。
code::
(
SynthDescLib.global.read;
SynthDescLib.global.browse;
)
::
そして、それぞれのシンセのためのコントロールをリストと表示するボックスに注目して下さい。
////////////////////////////////////////////////////////////////////////////////////////////////////
section::コントロールは(大抵は)アーギュメントである
シンセが生成される時や、動作中に情報を与えたいと思う時には、SynthDefにコントロールをセットします。このための最も一般的な方法は、1つ、またはそれ以上のアーギュメントをSynthDefに含めるということです。
////////////////////////////////////////////////////////////////////////////////////////////////////
次の例では、それぞれのアーギュメントはデフォルト値を持ちます。そのような場合には、もし必要なところにアーギュメントを与えるのを忘れたとしても、SynthDefが自動的に供給します。加えて、シンセが生成される時に必要となるものを示すアーギュメントに対するデフォルト値は、コードがより読みやすくします。
code::
(
// デフォルト値を持つ2つのアーギュメント
SynthDef("withControls", { arg freq = 440, mul = 0.22;
Out.ar(
0,
SinOsc.ar([freq, freq+1], 0, mul)
)
}).add;
)
Synth("withControls", [\freq, 440, \mul, 0.1]);
::
配列の中のアイテムはSynthDefのコントロールに渡される値です。
////////////////////////////////////////////////////////////////////////////////////////////////////
配列の中にそれぞれのコントロールを書く場合には、次の様にシンボル(バックスラッシュの後に名前が続く)を用いることもできますし、
code::
Synth("withControls", [\freq, 440, \mul, 0.1]);
::
または、次の様に文字列(引用符の中に名前)を用いることもでき、
code::
Synth("withControls", ["freq", 440, "mul", 0.1]);
::
その後に値が続きます。
////////////////////////////////////////////////////////////////////////////////////////////////////
いずれの場合でも、そのパターンは、
[ controlName, value, controlName, value].
です。
////////////////////////////////////////////////////////////////////////////////////////////////////
シンセにコントロールを渡す第3の方法もあります。前の例のシンセは次の様に書くこともできます。
code::
Synth("withControls", [0, 440, 1, 0.1]);
::
このパターンは次の様になります。
[ controlIndex, value, controlIndex, value].
この手法のディスアドバンテージは、コントロールをインデックス番号として表現するのは説明的ではなく、それゆえに名前をシンボルまたは文字列として与えるよりも読みにくくなるでしょう。
////////////////////////////////////////////////////////////////////////////////////////////////////
section::コントロールはリセットすることもできる
次の例は、シンセが生成された後に(動作中に)どのようにしてコントロールをリセットすることができるのかということを示しています。
code::
(
SynthDef("resetMyControls", { arg freq = 440, mul = 0.22;
Out.ar(
0,
SinOsc.ar([freq, freq+1], 0, mul)
)
}).add;
)
~aSynth = Synth("resetMyControls", [\freq, 440, \mul, 0.06]);
~aSynth.set(\freq, 600, \mul, 0.25);
::
aSynthの前の~はグローバル変数を定義します。このようにすることの主なアドバンテージは、次の様に明示的に宣言する必要がないということです。
code::
var aSynth; // '~'のない変数はまず宣言しなければならない!!
::
もっと正確に言えば、~という文字は「aSynth」という変数をcurrentEnvironmentという名前で知られるオブジェクトのインスタンスの中に配置します。詳しくは、SuperColliderのヘルプ・システムでEnvironmentというドキュメントを参照して下さい。
////////////////////////////////////////////////////////////////////////////////////////////////////
SynthDefはコントロールのそれぞれにラグ・タイムを定義することができます。ugenGraphFuncの後に配列として書くラグは、あるコントロール値から他のコントロール値にスムーズに変化する時間を指定します。
code::
(
SynthDef("controlsWithLags", { arg freq = 440, mul = 0.22;
Out.ar(
0,
SinOsc.ar([freq, freq+1], 0, mul)
)
}, [1, 1]).add;
)
~aSynth = Synth("controlsWithLags", [\freq, 550, \mul, 0.1]);
~aSynth.set(\freq, 600, \mul, 0.5);
::
////////////////////////////////////////////////////////////////////////////////////////////////////
SynthDefの中にラグタイムの配列を含めるというオプションがあるということは、前に議論したSynthDefのテンプレートは再定義されなければならないということを意味します。
code::
// 前のSynthDefのためのテンプレート。ラグタイムの配列なし。
SynthDef(
"i am a synthdef", // 第1アーギュメントは名前
{ .... i am a ugenGraphFunc ... } // 第2アーギュメントはugenGraphFunc
)
// ラグタイムの配列付きで再定義したSynthDefのためのテンプレート
// ラグタイムの配列のためのクラス定義は'rates'と呼ぶ
SynthDef(
"i am a synthdef", // 名前
{ .... i am a ugenGraphFunc ... }, // ugenGraphFunc
[ ... lagTimes ... ] // rates
)
::
どちらのテンプレートを用いるかという選択はユーザー次第です。もし、SynthDefにラグタイムを含める必要があるのであれば、第2のテンプレート、すなわち、レートの配列を含むもの、を使います。
////////////////////////////////////////////////////////////////////////////////////////////////////
go to link::Tutorials/Mark_Polishook_tutorial/Japanese_version/07::
|