〜 ソフトウェア 〜
セイバーが起動するまでの待ち時間を取得 (要USER32.DLL)

API関数のSystemParametersInfoは、デスクトップ項目関連のほか、
ユーザー補助、電力管理等、コントロールパネルで設定できる項目の設定と取得をするものであり、
取得及び設定のできる項目総数が150ほどあるので、このページだけで全てを紹介できません。
今回は「スクーンセイバーが起動するまでの時間を取得してみる」と言うことで、
取得に必要なSystemParametersInfoの設定パラメータのみを抜粋すると次のようになります。
uiActionuiParampvParam
SPI_GETSCREENSAVETIMEOUT(=0x000E)不使用(=0)受取先変数のポインタ
待ち時間を設定するにはコチラのやり方を参考にしてみてください。

spi アクション, 送信値, 一時変数, 更新
アクション実施するシステム情報の取得・設定内容を指定する。
送信値数値パラメータを指定する。
一時変数一時的に使用する変数のポインタを指定する。
更新設定時にユーザープロファイルの更新、ウィンドウへの通知を実施するか否かを指定する。

savergettime 格納変数
格納変数スクリーンセイバーの待ち時間を受け取る数値型変数を指定する。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
	ll_libload user, "user32.dll"
	ll_getproc SystemParametersInfo, "SystemParametersInfoA", user

#module
#deffunc spi int, int, int, int
	mref uiaction, 0 : mref uiparam, 1 : mref pvparam, 2 : mref fwinini, 3
	prm = uiaction, uiparam, pvparam, fwinini
	ll_callfunc prm, 4, SystemParametersInfo@
	return

#deffunc savergettime val
	mref time, 16
	ll_getptr time : ll_ret p
	spi 0x000E, 0, p, 0 // SPI_GETSCREENSAVETIMEOUT
	return
#global

	savergettime second
	pos 10, 10 : mes "セイバーの待ち時間は" + second + "秒です"
	stop

待ち時間 = savergettime( )
待ち時間取得したスクリーンセイバーが起動するまでの待ち時間の受取先を指定する。。
[パラメータなし]セイバーが起動するまでの待ち時間を取得するだけのため、パラメータは必要ない。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
#uselib  "user32.dll"
#func  global SystemParametersInfo "SystemParametersInfoA" int, int, var, int

#module
#defcfunc savergettime local i
	SystemParametersInfo 0x000E, 0, i // SPI_GETSCREENSAVETIMEOUT
	return i
#global

	pos 10, 10 : mes "セイバーの待ち時間は" + savergettime() + "秒です"