[[Nasal スクリプト集]] * 概要 [#u198638b] rocking_nimitz.nas は空母 Nimitz のピッチ方向/ロール方向の揺れを再現することで、揺れる空母上での離着陸を体験する為のスクリプトです。あくまでも疑似体験的なものであるため、機体が甲板上に沈み込む等リアリティーに欠ける部分もありますが、とりあえず楽しんでみてください。 * インストール方法 [#m8a16d88] 添付ファイルのソース (rocking_nimitz.nas) を ~/.fgfs/Nasal/rocking_nimitz.nas として保存してください (Windows の場合は C:/Documents and Settings/<ユーザ名>/Applciation Data/flightgear.org/Nasal/rokicing_nimitz.nas)。 あとは FlightGear を起動するだけで準備完了です。特に機体/空母側の変更は必要ありません。 * 使用方法 [#h83bb0cb] 空母に Nimitz を指定して FlightGear を起動すれば Nimitz の揺れが有効になります。 * 処理概要 [#jdd6021b] Nimitz のピッチ角度をピッチ周期 pitch_interval, ±最大ピッチ角 max_pitch のサインカーブで変化させます。 ロールも同様に 周期 roll_interval, 最大ピッチ ± max_roll のサインカーブで変化させます。1秒毎のタイマーで1秒後の角度を指定し、 interpolate で1秒間掛けてその角度に徐々に変化させるようにしています。最大ピッチを 0.5 以上にすると75%の確率で着陸時にクラッシュします。周期や最大角を変えてみるとどれだけ揺れるかが判ると思います。 風速に応じて Nimitz のピッチ角度をピッチ周期 pitch_interval, ±ピッチ角 max_pitch のサインカーブで変化させます。ロールも同様に 周期 roll_interval, ロール角 ±max_roll のサインカーブで変化させます。1秒毎のタイマーで1秒後の角度を指定し、 interpolate で1秒間掛けてその角度に徐々に変化させるようにしています。最大ピッチを 0.5 以上にすると75%の確率で着陸時にクラッシュします。周期や最大角(limit_pitch, limit_roll)を変えてみるとどれだけ揺れるかが判ると思います。 * 更新履歴 [#v331fa6d] - 2008/08/02: wind_threshold を 40 に変更 - 2008/07/31: 風速に応じて max_pitch, max_roll を計算する calc_angles を追加 - 2008/07/30 : 初版 * ソース [#f7a66927] このソースは参考に表示しているものです。ダウンロードは下の添付ファイルをクリックして保存してください。 ############################################################################### # rocking_nimitz.nas by Tatsuhiro Nishioka # - Simulates a brief pitching / rolling deck # # 2008/07/30 # Copyright (C) 2008 Tatsuhiro Nishioka (tat dot fgmacosx at gmail dot com) # This file is licensed under the GPL license version 2 or later. # ################################################################################ var limit_pitch = 0.45; var limit_roll = 1.0; var wind_threshold = 20; var wind_threshold = 40; var max_pitch = 0.45; var max_roll = 0.9; var pitch_cycle = 3; var roll_cycle = 4; var calc_angles = func { var wind_speed = getprop("/environment/wind-speed-kt"); if (wind_speed > wind_threshold) { wind_speed = wind_threshold; } max_pitch = wind_speed / wind_threshold * limit_pitch; max_roll = wind_speed / wind_threshold * limit_roll; } var rock_nimitz = func { calc_angles(); var sec = getprop("/sim/time/elapsed-sec"); var pitch = math.sin(sec / pitch_cycle * 3.14) * max_pitch; var roll = math.sin(sec / roll_cycle * 3.14 ) * max_roll; interpolate("/ai/models/carrier[0]/orientation/pitch-deg", pitch, 1); interpolate("/ai/models/carrier[0]/orientation/roll-deg", roll, 1); settimer(func { rock_nimitz(); }, 1 ); } _setlistener("/sim/signals/fdm-initialized", func { rock_nimitz(); });