〜 メディア 〜
ムービーの表示位置・サイズを取得

MCIを使用するとムービー毎に設定されている等倍(デフォルト)サイズを取得することができます。
また初期値は0となりますが、表示位置を移動させている時に有用な表示基点も同時に取得します。 
取得とは逆に、再生位置・サイズを設定するやり方についてはコチラをご覧ください。
尚、同時再生しないので、モジュール命令のパラメータ「バッファ番号」は不要なのですが、
複数読込に対応しているコチラの共通のMCIモジュールを使用しているために当サンプルでも定義してます。
また、HSPウィンドウのサイズを変更して、読み込むためにコチラのモジュールも利用しています。
	

mciload ファイルパス, 番号
ファイルパス再生するファイルパスを指定する。
尚、"1"ならA、"2"ならB、"26"ならZドライブとしたCDオーディオ形式でロードする。
番号割り当てるバッファ番号を指定する。
尚、当命令を実行すると、自動的に指定番号が操作対象バッファとなる。

mciplay 開始位置, 終了位置, 繰り返し
開始位置省略可能(省略時は空文字""を指定すること)。再生開始位置を指定する。
尚、指定は数値文字列、現在のフォーマット(初期はMSF"mm:ss:ff")で行う。
終了位置省略可能(省略時は空文字""を指定すること)。再生終了位置を指定する。
尚、指定は数値文字列、現在のフォーマット(初期はMSF"mm:ss:ff")で行う。
繰り返し最後まで再生したら自動的に初めから再生する(=1)か否(=0)かを指定する。

mciexit
[パラメータなし]全デバイスを解放するだけの為、パラメータは必要ない。
尚、終了時に自動的に呼び出されるので命令を実行する必要はない。

mciwinset ウィンドウID
ウィンドウID再生するHSPウィンドウのウィンドウIDを指定する。

mcigetrect 格納配列
格納配列位置・サイズを格納する要素4つ以上の数値型配列変数を指定する。

 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
#module
#deffunc mciload str, int
	mref file, 32 : mref no, 1
	cntno = no
	mci "close _" + cntno
	strmid i, file, , 2 : int i
	if i {
		file = "cdaudio!?"
		poke file, 8, i + 64
	}
	mci "open \"" + file + "\" alias _" + cntno
	return

#deffunc mciplay str, str, int
	mref start, 32 : mref finish, 33 : mref re, 2
	if start ! "" : s = " from " + start : else : s = ""
	if finish ! "" : s += " to " + finish
	if re : s += " repeat"
	mci "play _" + cntno + s
	return

#deffunc mciend onexit
	mci "stop all"
	mci "close all"
	return

#deffunc mciwinset int
	mref id, 0
	mref bmscr, 96 + id
	mci "window _" + cntno + " handle " + bmscr.13
	return

#deffunc mcigetrect val
	mref rect, 48
	mci "where _" + cntno + " source"
	s = refstr
	i = 0
	repeat 4
		getstr s2, s, i, ' '
		i += strsize
		rect.cnt = 0 + s2
	loop
	return
#global

	dim r, 4
	dialog "", 16
	if stat = 0 : end
	mciload refstr
	mcigetrect r
	screen 0, r.2, r.3 + 20
	mciwinset
	mciplay "", ""
	pos 0, r.3 : mes "動画情報 横幅:" + r.2 + " 高さ:" +r.3
	stop

mciload ファイルパス, 番号
ファイルパス再生するファイルパスを指定する。
尚、"1"ならA、"2"ならB、"26"ならZドライブとしたCDオーディオ形式でロードする。
番号割り当てるバッファ番号を指定する。
尚、当命令を実行すると、自動的に指定番号が操作対象バッファとなる。

mciplay 開始位置, 終了位置, 繰り返し
開始位置省略可能(省略時は空文字""を指定すること)。再生開始位置を指定する。
尚、指定は数値文字列、現在のフォーマット(初期はMSF"mm:ss:ff")で行う。
終了位置省略可能(省略時は空文字""を指定すること)。再生終了位置を指定する。
尚、指定は数値文字列、現在のフォーマット(初期はMSF"mm:ss:ff")で行う。
繰り返し最後まで再生したら自動的に初めから再生する(=1)か否(=0)かを指定する。

mciexit
[パラメータなし]全デバイスを解放するだけの為、パラメータは必要ない。
尚、終了時に自動的に呼び出されるので命令を実行する必要はない。

mciwinset ウィンドウID
ウィンドウID再生するHSPウィンドウのウィンドウIDを指定する。

mcigetrect 格納配列
格納配列位置・サイズを格納する要素4つ以上の数値型配列変数を指定する。

 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
#module
#deffunc mciload str file, int no, local s
	cntno = no
	mci "close _" + cntno
	if int(file) {
		s = "cdaudio!?"
		poke s, 8, int(file) + 64
	} else {
		s = file
	}
	mci "open \"" + s + "\" alias _" + cntno
	return

#deffunc mciplay str start, str finish, int re, local s
	if start ! "" : s = " from " + start : else : s = ""
	if finish ! "" : s += " to " + finish
	if re : s += " repeat"
	mci "play _" + cntno + s
	return

#deffunc mciend onexit
	mci "stop all"
	mci "close all"
	return

#deffunc mciwinset int id
	mref bmscr, 96 + id
	mci "window _" + cntno + " handle " + bmscr.13
	return

#deffunc mcigetrect array rect, local s, local s2, local i
	mci "where _" + cntno + " source"
	s = refstr
	repeat 4
		getstr s2, s, i, ' '
		i += strsize
		rect.cnt = int(s2)
	loop
	return
#global

	dim r, 4
	dialog "", 16
	if stat = 0 : end
	mciload refstr
	mcigetrect r
	screen 0, r.2, r.3 + 20
	mciwinset
	mciplay "", ""
	pos 0, r.3 : mes "動画情報 横幅:" + r.2 + " 高さ:" +r.3