Files
krkr2doc/docs/kag3doc/contents/Var.html
2016-09-08 17:50:19 +09:00

314 lines
19 KiB
HTML

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja" lang="ja">
<!-- generated by to_html.pl from Var.xml -->
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>変数を使おう</title>
<meta name="author" content="W.Dee" />
<meta http-equiv="Content-Style-Type" content="text/css" />
<meta http-equiv="Content-Script-Type" content="text/javascript" />
<link href="browser.css" type="text/css" rel="stylesheet" title="吉里吉里関連リファレンス用標準スタイル" />
<link href="mailto:[email protected]" rev="Made" />
<link href="index.html" target="_top" rel="Start" title="トップページ" />
</head>
<body>
<h1><a id="id310" name="id310">変数とは</a>
</h1><div class="para"><div>
<br />
 KAG における変数とは、<br />
<br />
・なにかを記憶させておく物<br />
<br />
 にすぎません。<br />
<br />
 ただし、KAG は、<a id="id311" name="id311" class="targanchor"><dfn>TJS2</dfn></a> というスクリプト言語をベースにしているシステムであり、KAG における変数とは TJS2 の変数そのものですのでかなり強力な機能を発揮します。<br />
<br />
 ここはチュートリアルですので、基本的な使い方のみを述べますが、さらに KAG 内部のメソッドやプロパティにアクセスするとか、吉里吉里の機能を直接使うとなると、ほぼ<em>泥沼</em>状態なので、はまりやすい性格の方はご注意を(笑)。<br />
</div></div>
<h1><a id="id312" name="id312">変数の種類</a>
</h1><div class="para"><div>
 KAG の変数の種類には 3 つあります。栞のセーブとロードとともにセーブ・ロードされる普通の「<a id="id313" name="id313" class="targanchor"><dfn>ゲーム変数</dfn></a>」と、栞のセーブ・ロードとは関係なしに、常に値を保持できる「<a id="id314" name="id314" class="targanchor"><dfn>システム変数</dfn></a>」、一時的に値をおいておくための「<a id="id315" name="id315" class="targanchor"><dfn>一時変数</dfn></a>」があります。「システム変数」は、吉里吉里/KAG を終了させて、また同じゲームを起動すれば値を保持しています。「一時変数」は吉里吉里を終了させると内容は失われてしまいますし、栞にも値は保存されません。<br />
<br />
 ゲーム変数には <a id="id316" name="id316" class="targanchor"><dfn>f</dfn></a> という名前が、システム変数には <a id="id317" name="id317" class="targanchor"><dfn>sf</dfn></a> という名前が、一時変数には <a id="id318" name="id318" class="targanchor"><dfn>tf</dfn></a> という名前が与えられてます。<br />
<br />
 また、KAG ( というか TJS2 ) の変数には、文字列でも数値でも入れることができます ( 文字列や数値などの、変数の中に入れるものの種類を「<a id="id319" name="id319" class="targanchor"><dfn></dfn></a>」といいます )。変数には(ほぼ)自由な名前を付けることができ、変数の数に制限はありませんし、文字列の長さに制限はありません。数値は実数も扱うことができます。<br />
 KAG 3.x からは「配列」と「辞書配列」も扱うことができるようになりました ( ここでは説明しません )。<br />
<br /><div class="note"><div class="notehead"><span class="noteheadspan">Note</span></div>
 TJS2 の整数型は 64bit、実数型は double ( 倍精度 ) の精度を持っています。<br />
 文字列はゼロ終結 UNICODE 文字列を扱い、長さ制限はありません。<br />
</div><br />
</div></div>
<h1><a id="id320" name="id320">変数として使用可能な名前</a>
</h1><div class="para"><div>
 吉里吉里 / KAG では、変数はほぼ自由に名前を付けることができます。しかし、自由といっても吉里吉里 / KAG が使用可能な変数の名前にはルールがあります。<br />
<br />
<dl>
<dt>変数名には半角英数と全角文字、_ (アンダーバー) を使うことができる</dt>
<dd> <em><code class="inlinecode">abc&amp;def</code></em> や、<em><code class="inlinecode">a-z</code></em> のような変数名は使用できません。<br />
 <em><code class="inlinecode">final_count</code></em> のようにアンダーバーを含んだり、<em><code class="inlinecode">主人公の名前</code></em> のように全角文字を使用することができます(全角の記号はすべて使用可能です)。</dd>
<dt>ただし 変数の名頭に半角の数字が来ることはできない</dt>
<dd> <em><code class="inlinecode">2friends</code></em><em><code class="inlinecode">3com</code></em> のような変数名は使用できません ( 全角の数字が先頭に来るのであれば OK です)。</dd></dl><br />
 これらの変数名の前に、ゲーム変数であれば <em><code class="inlinecode">f.</code></em> を、システム変数であれば <em><code class="inlinecode">sf.</code></em> を、一時変数であれば <em><code class="inlinecode">tf.</code></em> を付けます。<br />
 たとえば、以下のような変数名が考えられます。<br />
<br />
<code class="inlinecode"> <em>f.flag1 sf.username sf.playcount tf.i f.enokazu f.変数その1 </em>...</code><br />
<br />
 また、初めて使う変数はすべて数値としては 0 で、文字列としては '' ( 空文字列 ) という、すこし特殊な状態にあります。一般的には、変数は最初に値をいれてから使ってください。<br />
<br />
<br /><div class="note"><div class="notehead"><span class="noteheadspan">Note</span></div>
 <em>f</em><em>sf</em><em>tf</em> の他に <em>kag</em> というのを見かけるかも知れませんが、<em>kag</em> は KAG のシステム内部に直接アクセスするときに使われる物です。<br />
</div><br />
</div></div>
<h1><a id="id321" name="id321">変数への代入</a>
</h1><div class="para"><div>
 そうしたら、変数に値を代入するには、通常 <a id="id322" name="id322" class="targanchor"><dfn>eval</dfn></a> タグを使います。たとえば、<code class="inlinecode">f.flag1</code> に 1000 を代入したい場合・・・<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.flag1&nbsp;<a id="id323" name="id323" class="targanchor"><dfn>=</dfn></a>&nbsp;1000</em>&quot;]<br />
</code>
<br />
 とします。つまり、変数名の後に = を書き、その後に代入したい数値を指定します。<br />
<br />
 文字列を代入したい場合は、<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.変数その1&nbsp;=&nbsp;'文字列'</em>&quot;]<br />
</code>
<br />
 とします。つまり、 = の後に '' でくくった文字列を指定します ( シングルクォーテーションとダブルクォーテーションに注意してください )。<br />
 文字列用の変数や、数値用の変数というように、変数に入れるものの型によって名前が変わると言うことはありません。入れたものの型になります。<br />
<br />
 ほかの変数に内容をコピーする場合は、<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.flag1&nbsp;=&nbsp;f.flag2</em>&quot;]<br />
</code>
<br />
<br />
のようにします。<br />
</div></div>
<h1><a id="id324" name="id324">変数の演算</a>
</h1><div class="para"><div>
<br />
 計算をしたい場合は、<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.flag1&nbsp;=&nbsp;f.flag1&nbsp;+&nbsp;1</em>&quot;]<br />
</code>
<br />
 等とします。この例では、f.flag1 に 1 を足した物を f.flag1 に代入しています ( つまり f.flag1 に 1 を足している )。<br />
 exp 属性には TJS2 における「<a id="id325" name="id325" class="targanchor"><dfn></dfn></a>」を書きます。<br />
 式には、<a id="id326" name="id326" class="targanchor"><dfn>*</dfn></a>(乗算) <a id="id327" name="id327" class="targanchor"><dfn>/</dfn></a>(除算) <a id="id328" name="id328" class="targanchor"><dfn>+</dfn></a>(加算) <a id="id329" name="id329" class="targanchor"><dfn>-</dfn></a>(減算) のような普通の<a id="id330" name="id330" class="targanchor"><dfn>演算子</dfn></a>は普通に使えます ( 数学の式のように優先順位もあります )。( ) カッコも普通に使えます。<br />
 たとえば、<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.flag1&nbsp;=&nbsp;f.flag1&nbsp;+&nbsp;f.flag2&nbsp;*&nbsp;f.flag3</em>&quot;]<br />
</code>
<br />
 とすると、f.flag2 と f.flag3 をかけたものに f.flag1 が加算されたものが f.flag1 に入ります。<br />
<br />
 除算を行うときは / (スラッシュ) を用います。<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.flag1&nbsp;=&nbsp;f.flag2&nbsp;/&nbsp;f.flag3</em>&quot;]<br />
</code>
<br />
 この場合は f.flag2 を f.flag3 で割った物が f.flag1 に入ります。<br />
 しかし、割り切れなかった場合は f.flag1 が実数になってしまうので、あまった分を切り捨てて整数の結果を得たい場合は、整数除算演算子 \ を用いて、<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.flag1&nbsp;=&nbsp;f.flag2&nbsp;\&nbsp;f.flag3</em>&quot;]<br />
</code>
<br />
 と記述します。<br />
<br />
<br />
 あと、文字列同士のつなぎ合わせにも + 演算子を使います。<br />
<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;f.flag2&nbsp;=&nbsp;'hoge'&quot;]<br />
[eval&nbsp;exp=&quot;f.flag3&nbsp;=&nbsp;'une'&quot;]<br />
[eval&nbsp;exp=&quot;<em>f.flag1=&nbsp;f.flag2&nbsp;+&nbsp;f.flag3</em>&quot;]<br />
</code>
<br />
 上記の例では、 f.flag1 には 'hogeune' という文字列が入ります。<br />
<br />
<br /><div class="note"><div class="notehead"><span class="noteheadspan">Note</span></div>
 TJS2 の文法は JavaScript (ECMAScript) を参考にして作られたため、これによく似ています ( 完全に同じではありません )。<br />
 通常の算術演算の振る舞いはほぼ同じです。文字列の扱いや文字列と数値の混合演算もほぼ同じです。<br />
</div><br />
</div></div>
<h1><a id="id331" name="id331">文字列と数値</a>
</h1><div class="para"><div>
 KAG の変数は、文字列用の変数、数値用の変数というように変数が分かれることも、名前が変わることもありません。<br />
 文字列を入れればその変数は文字列が、数値をいれればその変数は数値の入った変数になります。<br />
 厄介なのはこれらをまぜて使うときです。+ 演算子にはいろいろな意味とその使い方があります(^^;<br />
<br />
 文字列同士のつなぎ合わせには + 演算子、数値の加算にも + 演算子を使いますが、文字列と数値を足そうとしたときは、どちらか一方が文字列ならば、片方の数値は文字列に変換されてつなぎ合わさるというルールがあります。<br />
<br />
 たとえば、f.flag2 に 'hoge' という文字列、f.flag3 に 10 という数値が入っていた場合、<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.flag1&nbsp;=&nbsp;f.flag2&nbsp;+&nbsp;f.flag2</em>&quot;]<br />
</code>
<br />
 では、f.flag1 には 'hoge10' という文字列が入ります。<br />
<br />
 また、どうしても文字列を数値に変換したい場合があると思います。たとえば [input] タグで入力したものを数値として扱いたいときなどですが、この場合にも + 演算子を使います。+ 演算子は、数値にしたい変数の前につけて使います。たとえば、f.flag1 に '20' という文字列が入っていたとして、<br />
<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>f.flag1&nbsp;=&nbsp;+f.flag1</em>&quot;]<br />
</code>
<br />
<br />
 と書けば、f.flag1 の内容は数値に変換され、再び f.flag1 に入ります。f.flag1 は数値の 20 になります。<br />
<br />
<br /><div class="note"><div class="notehead"><span class="noteheadspan">Note</span></div>
 + 演算子が続く場合は注意しなければなりません。f.flag3 を数値にして f.flag2 に加算するなどという式を書く場合、<code class="inlinecode">f.flag2++f.flag3</code> という書き方ではエラーになります ( ++ という別の演算子があるため )。スペースを空けて <code class="inlinecode">f.flag2+ +f.flag3</code> と書いてください。<br />
</div><br />
<br /><div class="note"><div class="notehead"><span class="noteheadspan">Note</span></div>
 単項の + 演算子 ( 上記例の <code class="inlinecode">f.flag1 = +f.flag1</code> のような場合の + ) は、文字列がもし小数表記を含む場合 ( 0.3 とか ) は、結果が実数になります。整数のみを得たい場合は ( 小数点以下を切り捨ててしまいたい場合は )、int + と書けば OK です。たとえば上記例でいけば、<code class="inlinecode">f.flag1 = int +f.flag1</code> となります。<br />
</div><br />
</div></div>
<h1><a id="id332" name="id332">変数の削除・そのほか</a>
</h1><div class="para"><div>
 変数を削除するには <a id="id333" name="id333" class="targanchor"><dfn>delete</dfn></a> を用います。<em>delete 変数名</em> でその変数を削除することができます。<br />
 たとえば、<code class="inlinecode">f.flag1</code> を削除したい場合は、<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;<em>delete&nbsp;f.flag1</em>&quot;]<br />
</code>
<br />
 とします。<br />
<br />
 また、<a id="id334" name="id334" class="targanchor"><dfn>clearvar</dfn></a> タグは、ゲーム変数をすべて削除します。<br />
<br />
 そのほか、TJS2 で使用可能な演算子や math オブジェクトによる三角関数等の計算 ( そんなの必要かはわかりませんが ) などをすべて使えます。詳しくは吉里吉里 SDK の TJS2 ヘルプを参照してください。<br />
<br />
 <a id="id335" name="id335" class="targanchor"><dfn>,</dfn></a> (カンマ)を使って複数の式を一つの eval タグ内に書くことができます。<br />
たとえば、<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;f.first=true&quot;]<br />
[eval&nbsp;exp=&quot;f.flag0=0&quot;]<br />
[eval&nbsp;exp=&quot;f.flag1=0&quot;]<br />
</code>
<br />
 というような式は、以下のように簡潔に書くことができます。<br />
<br />
<code class="bq">[eval&nbsp;exp=&quot;f.first=true<em>,</em>&nbsp;f.flag0=0<em>,</em>&nbsp;f.flag1=0&quot;]<br />
</code>
<br />
<br />
 また、<a id="id336" name="id336" class="targanchor"><dfn>iscript</dfn></a> タグを用いると、連続した eval タグを簡潔に書くことができます。<br />
<br />
 たとえば、上の式は、<br />
<br />
<br />
<code class="bq">[iscript]<br />
f.first=true<em>;</em><br />
f.flag0=0<em>;</em><br />
f.flag1=0<em>;</em><br />
[endscript]<br />
</code>
<br />
<br />
 と書くことができます。各式のあとに ; ( セミコロン ) を忘れないでください。<br />
 このように , (カンマ) や iscript を使うと、使わない場合に比べて非常に高速になります。<br />
</div></div>
<h1><a id="id337" name="id337">変数の内容を表示する</a>
</h1><div class="para"><div>
 変数の内容をシナリオ中に表示したい場合は、<a id="id338" name="id338" class="targanchor"><dfn>emb</dfn></a> タグを使います。<br />
 たとえば、以下のようになります。<br />
<br />
<code class="bq">[wait&nbsp;time=200]<br />
*start<br />
[cm]<br />
[eval&nbsp;exp=&quot;f.数値=200&quot;][eval&nbsp;exp=&quot;f.mojiretu='文字列'&quot;]<br />
f.数値&nbsp;の内容&nbsp;:&nbsp;[emb&nbsp;exp=&quot;f.数値&quot;][l][r]<br />
f.mojiretu&nbsp;の内容&nbsp;:&nbsp;[emb&nbsp;exp=&quot;f.mojiretu&quot;][l][r]<br />
</code>
<br />
<br />
 実行すると、<br />
<br />
f.数値 の内容 : 200<br />
f.mojiretu の内容 : 文字列<br />
<br />
 と表示されるはずです。<br />
</div></div>
<h1><a id="id339" name="id339">エンティティ</a>
</h1><div class="para"><div>
 エンティティというのは、変数の内容で、他のタグの属性の値を置き換える機能です。<br />
 属性の値に、 <a id="id340" name="id340" class="targanchor"><dfn>&amp;</dfn></a> に続けて変数名を書きます。<br />
<br />
<code class="bq">[wait&nbsp;time=200]<br />
*start<br />
[cm]<br />
[eval&nbsp;exp=&quot;f.fontsize=60&quot;]<br />
[font&nbsp;size=&quot;&amp;f.fontsize&quot;]サイズ&nbsp;60&nbsp;の文字[resetfont]<br />
</code>
<br />
<br />
 この場合は、f.fontsize に代入された 60 という数値で、font タグの size 属性の値を置き換えています。<br />
<br />
 実際はエンティティは、&amp; の後に書かれた属性の値の内容を、TJS2 式として実行して、その結果で属性の値を置き換える機能です。従って、&amp; の後には TJS2 式を書くことが出来ます。<br />
</div></div>
<h1><a id="id341" name="id341">条件の判断</a>
</h1><div class="para"><div>
 変数がある値と同じであるかを判断するためには以下の演算子を使うことができます。<br />
<br />
<code class="bq">a<a id="id342" name="id342" class="targanchor"><dfn>==</dfn></a>b&nbsp;&nbsp;&nbsp;&nbsp;a&nbsp;&nbsp;b&nbsp;と等しいときに真(true)<br />
a<a id="id343" name="id343" class="targanchor"><dfn>!=</dfn></a>b&nbsp;&nbsp;&nbsp;&nbsp;a&nbsp;&nbsp;b&nbsp;と等しくない場合に真(true)<br />
a<a id="id344" name="id344" class="targanchor"><dfn>&lt;</dfn></a>b&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;a&nbsp;&nbsp;b&nbsp;より少ない場合に真(true)<br />
a<a id="id345" name="id345" class="targanchor"><dfn>&gt;</dfn></a>b&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;a&nbsp;&nbsp;b&nbsp;より大きい場合に真(true)<br />
</code>
<br />
<br />
 このほか &gt;= や &lt;= (同じかより大きい、同じかより小さい) も使うことができます。<br />
 このような条件判断は主に if タグで使います。<br />
<br />
 <a id="id346" name="id346" class="targanchor"><dfn>if</dfn></a> タグは、exp で指定した式が 真(true) を示した場合にのみ endif タグまでにある文章やタグを実行します。<br />
<br />
<br />
<code class="bq">[if&nbsp;exp=&quot;f.flag1<em>==</em>2&quot;]f.flag1&nbsp;&nbsp;2&nbsp;です[endif]<br />
[if&nbsp;exp=&quot;f.flag1<em>!=</em>2&quot;]f.flag1&nbsp;&nbsp;2&nbsp;ではありません[endif]<br />
</code>
<br />
<br />
 変数は使い方次第で非常に強力な機能となります。<br />
</div></div>
<script type="text/javascript" charset="UTF-8" src="documentid.js" ></script>
<script type="text/javascript" charset="UTF-8" src="postcontent.js" ></script>
</body>
</html>