.
UXPACK/UYPACK/UZPACK は直交座標系の座標軸をプロットするための
サブルーチンパッケージである.
したがって,変換関数番号としてはITR=1 ~ 4(直角直線座標系)の
正規化変換に対してのみ使用できる.
それ以外の変換関数番号を指定しても動作は保証されない.
このパッケージにもとづいてULPACK(第[here]章),
UCPACK(第[here]章), USPACK(第[here]章)などの
座標軸関連パッケージは構築されている.
UXPACK/UYPACK/UZPACK それぞれのパッケージの機能は
次のようになっている.
UXPACK : X軸をプロットする
UYPACK : Y軸をプロットする
UZPACK :
内部変数の管理や初期化をおこなう
UXPACK, UYPACKはそれぞれ次のような3レベルのサブルーチン群からなる.
- 基本ルーチン群 (Basic Routines) :
基本的な作画をおこなうサブルーチン.
ユーザーは知る必要がない.
- 下位応用ルーチン群 (Lower Level Applications) :
基本ルーチン群を使って書かれていて,
具体的な作画をおこなうルーチン群.(以下ではLLAと略記する)
- 上位応用ルーチン群 (Upper Level Applications) :
LLA を組み合わせて書かれていて,
実際にユーザーが使用するルーチン群.(以下ではULAと略記する)
このほかに座標軸のオフセットあるいは座標系のリニアオフセットを
コントロールするサブルーチン群がある.
簡単な座標軸の作画はほとんどULAで実現できる.
ULAで満足のゆく作画ができない場合,LLAを組み合わせれば
さらに高度な目的に応じたULAが作成できるはずである.
以下の「サブルーチンの説明」では,上位応用ルーチン(ULA), UZPACK,
下位応用ルーチン(LLA)の順に説明する.
簡単な座標軸の作画をしようとするユーザーは,
「座標軸の場所」に関する次節の説明を読んだあと
[here]節の「上位応用ルーチンの説明」に
進んでもらえれば,
おそらく期待に沿うような座標軸の描画ができるはずである.
このパッケージを使うためには,あらかじめ変換関数番号が
ITR=1 ~ 4(直角直線座標系)の正規化変換が
設定されていなければならない
(「GRPH1」のマニュアル参照). たとえば
CALL SGSVPT(VXMIN,VXMAX,VYMIN,VYMAX)
CALL SGSWND(UXMIN,UXMAX,UYMIN,UYMAX)
CALL SGSTRN(ITR)
CALL SGSTRF
が呼んであるとする.
このときLLA, ULAは次の場所に座標軸を設定できる.
UXPACKについては
'B'ottom - (UXMIN, UYMIN)と(UXMAX, UYMIN)を結ぶ線
'T'op - (UXMIN, UYMAX)と(UXMAX, UYMAX)を結ぶ線
'U'ser - (UXMIN, UYUSER)と(UXMAX, UYUSER)
を結ぶ線
UYPACKについては
'L'eft - (UXMIN, UYMIN)と(UXMIN, UYMAX)を結ぶ線
'R'ight - (UXMAX, UYMIN)と(UXMAX, UYMAX)を結ぶ線
'U'ser - (UXUSER, UYMIN)と(UXUSER, UYMAX)
を結ぶ線
X軸に関する'B', 'T', 'U',
Y軸に関する'L', 'R', 'U'は,
座標軸の構成要素(次節参照)を作画する場所を示すための
パラメーター(CSIDE)として用いられる.
UXUSER, UYUSERは内部変数'UXUSER', 'UYUSER'を
設定して初めて有効となる(初期値は不定).
以下,特に断らないかぎり単に「内部変数」というのは
UZpGET/UZpSET([here]節参照)の
管理する内部変数のことを指す.
座標軸を設定できるこれらの場所は,
UXPACKについてはUXSAXZまたはUXSAXSによって
Y方向に平行移動することができる;
UYPACKについてはUYSAXZまたはUYSAXSによって
X方向に平行移動することができる([here]節参照).
LLA が作画する座標軸の構成要素には次のものがある
(カッコ内はその構成要素を描くサブルーチン名).
- 軸を示す線分 (UXPAXS/UYPAXS)
- 目盛 (UXPTMK/UYPTMK)
- ラベル
- 文字列で指定 (UXPLBL/UYPLBL)
- 数値で指定 (UXPNUM/UYPNUM)
- タイトル (UXPTTL/UYPTTL)
それぞれの構成要素は次のような属性を持っている.
- 軸を示す線分については
a. <ISLCT>
線分のラインインデクス
- 目盛については
a. 目盛の長さ <ISLCT>
b. <ISLCT>
目盛を描く線のラインインデクス
- ラベルについては
a. 文字の高さ <ISLCT>
b. 文字列の回転角 <CSIDE>
c. 文字列のセンタリングオプション <CSIDE>
d. <ISLCT>
文字列を描く線のラインインデクス
- タイトルについては
a. 文字の高さ <ISLCT>
b. 文字列の回転角 <CSIDE>
c. 文字列のセンタリングオプション <引き数>
d. <ISLCT>
文字列を描く線のラインインデクス
これらの属性の指定方法および
<ISLCT>, <CSIDE>, <引き数>の
意味については次節で述べる.
座標軸の設定を'U'ser以外でおこなった場合,
ラベルとタイトルは常にウインドウの外側に向かって描かれる.
'U'serで設定をおこなった場合,ラベルとタイトルを軸のどちら側に書くかは
内部変数'IFLAG'が決める([here]節参照).
LLAの各サブルーチンにはISLCT, CSIDEという2つの引き数がある.
この2つの引き数およびその他の引き数が各構成要素の属性を決める.
- ISLCTは0,1,2の値をとりうる.[here]節で述べた
属性のうち<ISLCT>とあるものは,この引き数によって定まる
内部変数を参照して決まる.
ISLCT=0,1,2の具体的な意味は,
- ISLCT=0 : ユーザーが定義した内部変数を使って作画する.
- ISLCT=1 : このパッケージがあらかじめ設定している
内部変数を使って作画する.
小さめの目盛,ラベル,タイトルを描くときに用いる.
- ISLCT=2 : このパッケージがあらかじめ設定している
内部変数を使って作画する.
大きめの目盛,ラベル,タイトルを描くときに用いる.
たとえば,軸を示す線分のラインインデクスについては,
ISLCT=0,1,2それぞれについて'INDEXT0', 'INDEXT1',
'INDEXT2'という内部変数があって(初期値は順に,不定,1, 3)
これを参照して属性が決まる.
以下では以上の表現をまとめて次のように略記する.-
「内部変数'INDEXTi'で指定してある値を参照してラインインデクスの属性が
決まる(初期値は,不定,1, 3)」.
これらの内部変数は UZpGET/UZpSETによって
参照/変更できる([here]節参照).
- CSIDEは構成要素を描く場所を指定するとともに,
描く場所に依存する属性を決める.
[here]節で述べた属性のうち<CSIDE>とあるものは,
この引き数によって定まる内部変数を参照して決まる.
たとえば,X軸につけるタイトルの回転角については,
CSIDE='B','T','U'それぞれについて'IROTCXB', 'IROTCXT',
'IROTCXU'という内部変数があって(初期値は順に,0, 0, 0)
これを参照して属性が決まる.
以下では以上の表現をまとめて次のように略記する.-
「内部変数'IROTCXs'で指定してある値を参照して,
X軸につけるタイトルの回転角に関する属性が
決まる(初期値は,0, 0, 0)」.
また,Y軸につけるタイトルの回転角については,
CSIDE='L','R','U'それぞれについて'IROTCYL', 'IROTCYR',
'IROTCYU'という内部変数があって(初期値は順に,1, 1, 1)
これを参照して属性が決まる.
以下では以上の表現をまとめて次のように略記する.-
「内部変数'IROTCYs'で指定してある値を参照して,
Y軸につけるタイトルの回転角に関する属性が
決まる(初期値は,1, 1, 1)」.
さらに'IROTCXs'と'IROTCYs'をまとめて次のように略記する.-
「内部変数'IROTCzs'で指定してある値を参照して,
軸につけるラベルの回転角に関する属性が
決まる(初期値は,0, 0, 0, 1, 1, 1)」.
- [here]節で述べた
属性のうち<引き数>とあるものは,
引き数として直接指定することによって決まる.
[here]節で述べた属性は具体的に次のように決まる.
- 軸を示す線分については
- a. 線分のラインインデクス <ISLCT>
内部変数'INDEXTi'で指定してあるラインインデクスを用いて線分を描く
(初期値は,不定,1, 3).
- 目盛については
- a. 目盛の長さ <ISLCT>
内部変数'RSIZETi'で指定してある長さ(単位はV座標系)の目盛を描く
(初期値は,不定,0.007, 0.014).
- b. 目盛を描く線のラインインデクス <ISLCT>
内部変数'INDEXTi'で指定してあるラインインデクスを用いて目盛を描く
(初期値は,不定,1, 3).
(注:目盛を描く向きは内部変数'INNER'が決める.
'INNER'が正のとき内側に向かって目盛を描く;
負のとき外側に向かって目盛を描く(初期値は+1). )
- ラベルについては
- a. 文字の高さ <ISLCT>
内部変数'RSIZELi'で指定してある高さ(単位はV座標系)の文字を描く
(初期値は,不定,0.021, 0.028).
- b. 文字列の回転角 <CSIDE>
内部変数'IROTLzs'で指定してある回転角オプションを
使ってラベルを描く(初期値は,0, 0, 0, 0, 0, 0).
回転角オプションとは,ラベルを描くときの回転角を90度が
1単位の整数値で指定するものである.
(たとえば90度のとき1, -90度のとき-1と指定する.)
- c. 文字列のセンタリングオプション <CSIDE>
内部変数'ICENTzs'で指定してあるセンタリングオプションを
使ってラベルを描く(初期値は,0, 0, 0, +1, +1, +1).
センタリングオプションとは,ラベルを描くときに左よせ(-1)するか,
センタリング(0)するか,右よせ(+1)するかを指定するものである.
- d. 文字列を描く線のラインインデクス <ISLCT>
内部変数'INDEXLi'で指定してあるラインインデクスを用いて文字を描く
(初期値は,不定,3, 3).
- タイトルについては
- a. 文字の高さ <ISLCT>
内部変数'RSIZECi'で指定してある高さ(単位はV座標系)の文字を描く
(初期値は,不定,0.028, 0.035).
- b. 文字列の回転角 <CSIDE>
内部変数'IROTCzs'で指定してある回転角オプションを
使ってラベルを描く(初期値は,0, 0, 0, +1, +1, +1).
回転角オプションとは,タイトルを描くときの回転角を90度が
1単位の整数値で指定するものである.
(たとえば90度のとき1, -90度のとき-1と指定する.)
- c. 文字列のセンタリングオプション <引き数>
引き数で指定してあるセンタリングオプションを
使ってタイトルを描く.
センタリングオプションとは,ラベルを描くときに左よせ(-1)するか,
センタリング(0)するか,右よせ(+1)するかを指定するものである.
- d. 文字列を描く線のラインインデクス <ISLCT>
内部変数'INDEXLi'で指定してあるラインインデクスを用いて文字を描く
(初期値は,不定,3, 3).
Latex Source
地球流体電脳倶楽部 : 95/6/9 (Version 5.0)
NUMAGUTI Atusi <a1n@gfdl.gov>
Last Modified: Thu Aug 31 13:10:15 EDT 1995