プログラミング言語 PG0.5
ライブラリ リファレンス
--
■はじめに
PG0はプログラミング学習を目的としたプログラミング言語です。
PG0.5はPG0を拡張したプログラミング言語です。

以下のライブラリのリファレンスになります。
・画面描画API (screen.pg0)
・数値処理API (math.pg0)
・文字列API (string.pg0)
・入出力API (io.pg0)

■制限事項
本ライブラリには以下の制限があります。
・動作環境はPG0(Web版)のみです。
・デバイスやWebブラウザによって動作速度、描画速度が異なる場合があります。
・サウンド再生についてはiOSではセキュリティ制限のため機能しない場合があります。
・各APIの仕様は今後変更される可能性があります。

■画面描画API (screen.pg0)

以下のインポート文により利用することができます。
#import("lib/screen.pg0")

startScreen(width, height, option)
	[説明]
		スクリーンを開始します。
		Webブラウザ上に指定したサイズのスクリーンを表示します。
	[引数]
		width - 画面の幅(数値)
		height - 画面の高さ(数値)
		option - オプションを連想配列で指定します。
					{"color": 16進数のカラーコード(文字列), "fit": 画面サイズに合わせるかのフラグ(数値)}
	[戻り値]
		0

sleep(time)
	[説明]
		一定時間処理を停止します。
	[引数]
		time - 停止する時間をミリ秒を数値で指定します。
	[戻り値]
		0

time()
	[説明]
		現在時刻(UTC)を取得します。
	[引数]
		なし
	[戻り値]
		1970年1月1日 00:00:00からの経過ミリ秒を数値で返します。

timeString(time)
	[説明]
		時間を日時文字列にフォーマットします。
	[引数]
		time - 1970年1月1日 00:00:00からの経過ミリ秒を数値
		format - 日時フォーマット。省略時はロケールに従った文字列にフォーマットされます。
					YYYY - 年
					MM or M - 月
					DD or D - 日
					hh or h - 時
					mm or m - 分
					ss or s - 秒
	[戻り値]
		日時文字列

startOffscreen()
	[説明]
		オフスクリーンを開始して、画面表示をオフスクリーンに描画します。
	[引数]
		なし
	[戻り値]
		0

endOffscreen()
	[説明]
		オフスクリーンを終了して、オフスクリーンの内容を画面に描画します。
	[引数]
		なし
	[戻り値]
		0

clearRect(x, y, width, height)
	[説明]
		指定領域の描画を透明化します。
	[引数]
		x - 左上の水平座標(数値)
		y - 左上の垂直座標(数値)
		width - 幅(数値)
		height - 高さ(数値)
	[戻り値]
		0

drawLine(x1, y1, x2, y2, option)
	[説明]
		直線を描画します。
	[引数]
		x1 - 開始の水平座標(数値)
		y1 - 開始の垂直座標(数値)
		x2 - 終了の水平座標(数値)
		x2 - 終了の垂直座標(数値)
		option - オプションを連想配列で指定します。
					{"width": 線幅(数値), "color": 16進数のカラーコード(文字列)}
	[戻り値]
		0

drawRect(x, y, width, height, option)
	[説明]
		四角を描画します。
	[引数]
		x - 左上の水平座標(数値)
		y - 左上の垂直座標(数値)
		width - 幅(数値)
		height - 高さ(数値)
		option - オプションを連想配列で指定します。
					{"width": 線幅(数値), "color": 16進数のカラーコード(文字列), "fill": 塗りつぶし(数値)}
					塗りつぶしに1を設定すると指定された色で四角を塗りつぶします。
	[戻り値]
		0

drawCircle(x, y, radiusX, option)
	[説明]
		円を描画します。
	[引数]
		x - 円の中心の水平座標(数値)
		y - 円の中心の垂直座標(数値)
		radiusX - 長辺の半径(数値)
		option - オプションを連想配列で指定します。
					{"width": 線幅(数値), "color": 16進数のカラーコード(文字列), "fill": 塗りつぶし(数値), "radius_y": 短辺の半径(数値), "rotation": 円の傾き(数値), "start": 円が始まるX軸から時計回りの角度(数値), "end": 円の終わるX軸から時計回りの角度(数値)}
					塗りつぶしに1を設定すると指定された色で円を塗りつぶします。
	[戻り値]
		0

drawPolyline(coordinates, option)
	[説明]
		いくつかの座標で繋がった一連の直線を描画します。
	[引数]
		coordinates - 座標の配列
						例) drawPolyline({{100, 100}, {200, 100}, {150, 50}}, {"close": 1}) // 三角形
		option - オプションを連想配列で指定します。
					{"width": 線幅(数値), "color": 16進数のカラーコード(文字列), "fill": 塗りつぶし(数値), "close": 1の場合は最後の線と最初の線を繋げる(数値)}
	[戻り値]
		0

drawFill(x, y, color)
	[説明]
		指定座標の色を指定の色で塗りつぶします。
		隣接するピクセルを辿って指定の色で塗りつぶします。
	[引数]
		x - 塗りつぶしを開始する水平座標(数値)
		y - 塗りつぶしを開始する垂直座標(数値)
		color - 16進数のカラーコード(文字列)
	[戻り値]
		0

drawScroll(x, y)
	[説明]
		画面をスクロールします。
		画面からはみ出た領域は逆側に表示されます。
	[引数]
		x - スクロールする水平の移動量(数値)
		y - スクロールする垂直の移動量(数値)
	[戻り値]
		0

createImage(x, y, width, height, option)
	[説明]
		指定領域の画像を作成します。
		戻り値を使ってdrawImage()で描画することができます。
	[引数]
		x - 左上の水平座標(数値)
		y - 左上の垂直座標(数値)
		width - 幅(数値)
		height - 高さ(数値)
		option - オプションを連想配列で指定します。
					{"id": 既存のイメージID(数値)}
					idを指定した場合は既存の画像を置き換えます。
	[戻り値]
		イメージID

drawImage(id, x, y, option)
	[説明]
		指定イメージIDの画像を描画します。
	[引数]
		id - イメージID
		x - 左上の水平座標(数値)
		y - 左上の垂直座標(数値)
		option - オプションを連想配列で指定します。
					{"width": 幅(数値), "height": 高さ(数値), "angle": 角度(数値), "alpha": 透明度(数値)}
					幅と高さは片方のみの指定はできません。
					透明度は0.0~1.0の間で指定します。
	[戻り値]
		0

drawText(text, x, y, option)
	[説明]
		テキストを描画します。
	[引数]
		text - 描画するテキスト(文字列)
		x - 開始の水平座標(数値)
		y - 開始の垂直座標(数値)
		option - オプションを連想配列で指定します。
					{"width": 線幅(数値), "color": 16進数のカラーコード(文字列), "fill": 塗りつぶし(数値), "fontstyle": フォントスタイル(文字列), "fontsize": フォントサイズ(数値), "fontface": フォント(文字列)}
					fillはデフォルトは1で、0を指定すると中抜き文字の描画になります。
					フォントスタイルはnormal、bold、italic、obliqueのいずれかを指定します。
	[戻り値]
		0

measureText(text, option)
	[説明]
		テキストの描画サイズを取得します。
	[引数]
		text - テキスト(文字列)
		option - オプションを連想配列で指定します。
					{"fontstyle": フォントスタイル(文字列), "fontsize": フォントサイズ(数値), "fontface": フォント(文字列)}
					フォントスタイルはnormal、bold、italic、obliqueのいずれかを指定します。
	[戻り値]
		描画サイズ
		{"width": 幅, "height": 高さ}

rgbToPoint(x, y)
	[説明]
		指定座標の色を取得します。
	[引数]
		x - 水平座標(数値)
		y - 垂直座標(数値)
	[戻り値]
		RGBの配列
		{"R": 赤を示す255までの数値, "G": 緑を示す255までの数値, "B": 青を示す255までの数値}

rgbToHex(rgb)
	[説明]
		RGBの配列を16進数のカラーコードに変換します。
	[引数]
		rgb - RGBの配列
				{"R": 赤を示す255までの数値, "G": 緑を示す255までの数値, "B": 青を示す255までの数値}
	[戻り値]
		16進数のカラーコード(文字列)

hexToRgb(hex)
	[説明]
		16進数のカラーコードをRGBの配列に変換します。
	[引数]
		hex - 16進数のカラーコード(文字列)
	[戻り値]
		RGBの配列
		{"R": 赤を示す255までの数値, "G": 緑を示す255までの数値, "B": 青を示す255までの数値}

inTouch()
	[説明]
		タッチ位置を返します。
	[引数]
		なし
	[戻り値]
		タッチ状態
		{"x": 水平座標, "y": 垂直座標, "touch": タッチ状態, "button": ボタン, "pos": {{水平座標, 垂直座標}, ...}}
		タッチ状態が0の場合は現在はタッチされておらず、最終のタッチ座標になります。
		buttonは0が左クリック、1が真ん中(ホイール)クリック、2が右クリックになります。
		posはマルチタッチの座標が入ります。

inKey()
	[説明]
		キーボード入力を返します。
	[引数]
		key - 押されているか確認するキー文字列を指定します。
				配列で指定した場合は配列内のすべてのキー文字列が押されているか確認します。
				キー文字列はJavaScriptのKeyboardEvent.keyと同値になります。
	[戻り値]
		引数が指定されていない場合は、押されているキー文字列の配列を返します。
		引数が文字列で指定されている場合は、キーが押されている場合は1を返し、押されていない場合は0を返します。
		引数が配列で指定された場合はすべてのキーが押されている場合は1を返し、押されていないキーがある場合は0を返します。

playSound(note, start, end)
	[説明]
		指定された周波数を指定した時間再生します。
	[引数]
		note - 周波数(数値)
				文字列を指定した場合は対応する周波数に変換されます。後ろに数字を入れるとオクターブになります。
				'C', 'C#', 'D', 'D#', 'E', 'F', 'F#', 'G', 'G#', 'A', 'A#', 'B'
					例) playSound("C4", 0, 500)
		start - 開始時間のミリ秒(数値)
		end - 終了時間のミリ秒(数値)
		volume - ボリューム、省略時は1(数値)
	[戻り値]
		0

playMusic(notes, option)
	[説明]
		複数の周波数を連続で再生します。
	[引数]
		notes - noteの配列
				{note, length, volume}
				noteを文字列で指定した場合は対応する周波数に変換されます。後ろに数字を入れるとオクターブになります。
				'C', 'C#', 'D', 'D#', 'E', 'F', 'F#', 'G', 'G#', 'A', 'A#', 'B'
					例) playMusic({{"C4", 500}, {"D4", 500}, {"E4", 500}})
				volumeは省略可能です。

				配列に以下のキーと値を設定すると特別な意味になります。
				start: 開始位置、複数の音を同時に鳴らす場合には開始位置を0にして別の音を設定します。
					例) playMusic({{"C4", 800}, {"start": 0}, {"E4", 800}, {"start": 0}, {"G4", 800}})
				volume: これより後のボリューム
		option - オプションを連想配列で指定します。
					{"repeat": 繰り返しフラグ(数値)}
	[戻り値]
		0

stopSound()
	[説明]
		再生されているサウンドをすべて停止します。
	[引数]
		なし
	[戻り値]
		0

■数値処理API (math.pg0)

以下のインポート文により利用することができます。
#import("lib/math.pg0")

abs(num)
	[説明]
		絶対値を返します。
	[引数]
		num - 変換する数値
	[戻り値]
		絶対値

atan(num)
	[説明]
		アークタンジェントをラジアン単位で返します。
	[引数]
		num - 変換する数値
	[戻り値]
		引数のアークタンジェント

cos(num)
	[説明]
		コサインを返します。
	[引数]
		num - 数値
	[戻り値]
		引数のコサイン

exp(num)
	[説明]
		自然対数の底を返します。
	[引数]
		num - 数値
	[戻り値]
		自然対数の底

log(num)
	[説明]
		自然対数を返します。
	[引数]
		num - 数値
	[戻り値]
		自然対数

random()
	[説明]
		乱数を返します。
	[引数]
		なし
	[戻り値]
		0以上1未満の乱数

sign(num)
	[説明]
		数値の符号が正か負かを表すフラグを返します。
	[引数]
		num - 数値
	[戻り値]
		1 - 正
		-1 - 負
		0 - ゼロ

sin(num)
	[説明]
		サインを返します。
	[引数]
		num - 数値
	[戻り値]
		引数のサイン

sqrt(num)
	[説明]
		平方根を返します。
	[引数]
		num - 数値
	[戻り値]
		平方根

tan(num)
	[説明]
		タンジェントを返します。
	[引数]
		num - 数値
	[戻り値]
		引数のタンジェント

pow(base, exponent)
	[説明]
		数値を累乗した値を返します。
	[引数]
		base - 底となる数値
		exponent - 累乗する指数
	[戻り値]
		数値を累乗した値

■文字列API (string.pg0)

以下のインポート文により利用することができます。
#import("lib/string.pg0")

trim(str)
	[説明]
		文字列の前後をトリミングする。
		トリミング対象の文字は空白(" ")、タブ("\t")となる。
	[引数]
		str - トリミングする文字列
	[戻り値]
		トリミングされた文字列

to_lower(str)
	[説明]
		英文字列を小文字に変換する。
	[引数]
		str - 小文字に変換する文字列
	[戻り値]
		小文字に変換された文字列

to_upper(str)
	[説明]
		英文字列を大文字に変換する。
	[引数]
		str - 大文字に変換する文字列
	[戻り値]
		大文字に変換された文字列

str_match(ptn, str)
	[説明]
		ワイルドカードを使って、文字列を比較する。
		「*」で任意の複数文字列に一致し、「?」で任意の一文字に一致する。
	[引数]
		ptn - 比較元のパターン(こちらにワイルドカードを指定する)
		str - 比較する文字列
	[戻り値]
		一致した場合は1を返し、一致しない場合は0を返す。

substring(str, begin, length = -1)
	[説明]
		文字列から部分文字列を抽出する。
	[引数]
		str - 抽出対象の文字列
		begin - 開始インデックス
			(負数は文字列の末尾からのインデックスとなる)
		length - 抽出する長さ(負数は末尾までの長さとなる)
	[戻り値]
		抽出された部分文字列

in_string(str, search, from = 0)
	[説明]
		文字列内の指定文字列の位置を検索する。
	[引数]
		str - 検索対象の文字列
		search - 検索する文字列
		from - 検索を開始するインデックス
	[戻り値]
		見つかった文字列のインデックスを返す。
		見つからない場合は -1 を返す。

split(str, separator)
	[説明]
		区切り文字列で文字列を分割する。
	[引数]
		str - 分割対象の文字列
		search - 区切り文字列
	[戻り値]
		分割した文字列が入った配列

■入出力API (io.pg0)

以下のインポート文により利用することができます。
#import("lib/io.pg0")

println(line)
	[説明]
		標準出力に一行出力
	[引数]
		line - 出力文字列
	[戻り値]
		0

saveValue(key, value)
	[説明]
		値を保存します。
		保存する値には数値、文字列、配列を指定します。
		値はWebブラウザに保存されます。
		スクリプトの保存場所を変更すると値は初期化されます。
		・新規ファイル - 共通領域
		・ローカルファイル - ローカルファイル名をキーとして保存
		・オンラインファイル - オンラインのcidをキーとして保存
	[引数]
		key - キー
		value - 保存する値
	[戻り値]
		0

loadValue(key)
	[説明]
		保存した値を読み出します。
	[引数]
		key - キー
	[戻り値]
		保存した値

removeValue(key)
	[説明]
		保存した値を削除します。
	[引数]
		key - キー
	[戻り値]
		0

get_clipboard()
	[説明]
		クリップボードのテキストを取得する。
	[引数]
		なし
	[戻り値]
		クリップボードのテキスト

set_clipboard(text)
	[説明]
		クリップボードにテキストを設定する。
	[引数]
		text - テキスト
	[戻り値]
		成功すると1、失敗すると0を返す。

--
Copyright (C) 1996-2024 by Ohno Tomoaki. All rights reserved.
    WEB SITE: https://nakka.com/
    E-MAIL: nakka@nakka.com