- 追加された行はこの色です。
- 削除された行はこの色です。
[[Nasal スクリプト集]]
* 概要 [#u198638b]
rocking_nimitz.nas は空母 Nimitz のピッチ方向/ロール方向の揺れを再現することで、揺れる空母上での離着陸を体験する為のスクリプトです。あくまでも疑似体験的なものであるため、天候にはまったく左右されませんし、機体が甲板上に沈み込む等リアリティーに欠ける部分もありますが、とりあえず楽しんでみてください。
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 max_pitch = 0.4;
var limit_pitch = 0.45;
var limit_roll = 1.0;
var wind_threshold = 40;
var max_pitch = 0.45;
var max_roll = 0.9;
var pitch_interval = 3;
var roll_interval = 4;
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_interval * 3.14) * max_pitch;
var roll = math.sin(sec / roll_interval * 3.14 ) * max_roll;
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(); });