コマンドライン引数の取得
今回はアプリケーションの機能の中でも比較的細部の実装に使用するAPIを取り上げます。まずはアプリケーションの起動時に渡されるパラメータの受け取り方についてです。
アプリケーションの起動時にはInvokeEvent.
NativeApplication.nativeApplication.addEventListener(InvokeEvent.INVOKE, invokeHandler);
private function invokeHandler(event:InvokeEvent):void {
trace(event.arguments);
trace(event.currentDirectory.nativePath);
}
イベントハンドラに渡されるInvokeEventオブジェクトは、argumentsプロパティとcurrentDirectoryプロパティを持っています。argumentsプロパティは、起動時に空白区切りで渡されたパラメータを配列として保持しています。currentDirectoryプロパティは、コマンドラインで起動されたときのカレントディレクトリを示すFileオブジェクトです。
関連付けされたファイルをダブルクリックするなどしてアプリケーションが呼び出されたときは、argumentsプロパティの1要素としてファイルのパスが渡されます。この場合のパスはFileオブジェクトではなく文字列です。
ファイルタイプの関連付け
特定のファイルタイプにアプリケーションを関連付けたい場合、アプリケーション記述ファイルで宣言することで関連付けが可能です。ただし、既にそのファイルタイプに対するデフォルトアプリケーションが設定されている場合にはそちらが優先されます。NativeApplicationクラスには、この設定を調べたり変更したりするメソッドが用意されています。
メソッド | 機能 |
---|---|
isSetAsDefaultApplication() | 指定のファイルタイプとの関連付けがなされているかどうかをブール値で返します。 |
getDefaultApplication() | 指定のファイルタイプに現在関連付けされているアプリケーションのパスを文字列で返します。 |
setAsDefaultApplication() | 指定のファイルタイプとの関連付けを行います。 |
removeAsDefaultApplication() | 指定のファイルタイプとの関連付けを解除します。 |
これらのメソッドはいずれもパラメータに拡張子
ログイン時に起動させる
ユーザーがログインしたときに自動的にアプリケーションを起動したい場合は、NativeApplicationクラスのstartAtLoginプロパティを使います。このプロパティもNativeApplication.
try {
NativeApplication.nativeApplication.startAtLogin = true;
} catch (e:IllegalOperationError) {
trace(e.message);
}
この設定はカレントユーザーに対してのみ有効です。また、実際に設定を行うにはアプリケーションがインストールされている必要があるため、ADLでのデバッグ時には例外がスローされます。Windowsでは既に同じ名前の別アプリケーションが自動起動するように設定されていた場合もエラーとなります。
ユーザーの不在状況を確認
ユーザーからのマウス/
var app:NativeApplication = NativeApplication.nativeApplication;
app.idleThreshold = 60;
app.addEventListener(Event.USER_IDLE, userIdleHandler);
app.addEventListener(Event.USER_PRESENT, userPresentHandler);
private function userIdleHandler(event:Event):void {
trace("退席中です");
}
private function userPresentHandler(event:Event):void {
trace("仕事中です");
}
最後にユーザー入力があってから経過した秒数はNativeApplicationクラスのlastUserInputプロパティで調べられます。