1
0
Fork 0
fgdata/Nasal/local_weather/cloud_definitions.nas
2012-12-05 20:31:27 +00:00

885 lines
25 KiB
Text

########################################################
# routines to set up, transform and manage local weather
# Thorsten Renk, August 2011
########################################################
# function purpose
#
# select_cloud_model to define the cloud parameters, given the cloud type and subtype
###########################################################
# define various cloud models
###########################################################
var select_cloud_model = func(type, subtype) {
var rn = rand();
var path="Models/Weather/blank.ac";
if (type == "Cumulus (cloudlet)"){
cloudAssembly = local_weather.cloud.new(type, subtype);
if (subtype == "small")
{
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_sheet2.rgb";
cloudAssembly.n_sprites = 10;
cloudAssembly.min_width = 500.0;
cloudAssembly.max_width = 700.0;
cloudAssembly.min_height = 500.0;
cloudAssembly.max_height = 700.0;
cloudAssembly.min_cloud_width = 1300;
cloudAssembly.min_cloud_height = 750;
cloudAssembly.bottom_shade = 0.4;
}
else
{
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_sheet1.rgb";
cloudAssembly.n_sprites = 5;
cloudAssembly.min_width = 600.0;
cloudAssembly.max_width = 900.0;
cloudAssembly.min_height = 600.0;
cloudAssembly.max_height = 900.0;
cloudAssembly.min_cloud_width = 1300;
cloudAssembly.min_cloud_height = 950;
cloudAssembly.bottom_shade = 0.4;
}
# characterize the basic texture sheet
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.z_scale = 1.0;
#signal that new routines are used
path = "new";
}
else if (type == "Cu (volume)"){
cloudAssembly = local_weather.cloud.new(type, subtype);
if (subtype == "small")
{
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_sheet2.rgb";
cloudAssembly.n_sprites = 5;
cloudAssembly.min_width = 400.0;
cloudAssembly.max_width = 700.0;
cloudAssembly.min_height = 400.0;
cloudAssembly.max_height = 700.0;
cloudAssembly.min_cloud_width = 1000;
cloudAssembly.min_cloud_height = 1000;
cloudAssembly.bottom_shade = 0.4;
}
else
{
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_sheet1.rgb";
cloudAssembly.n_sprites = 5;
cloudAssembly.min_width = 800.0;
cloudAssembly.max_width = 1100.0;
cloudAssembly.min_height = 800.0;
cloudAssembly.max_height = 1100.0;
cloudAssembly.min_cloud_width = 1500;
cloudAssembly.min_cloud_height = 1150;
cloudAssembly.bottom_shade = 0.4;
}
# characterize the basic texture sheet
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.z_scale = 1.0;
#signal that new routines are used
path = "new";
}
else if (type == "Congestus"){
cloudAssembly = local_weather.cloud.new(type, subtype);
if (subtype == "small")
{
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
cloudAssembly.n_sprites = 5;
cloudAssembly.min_width = 600.0;
cloudAssembly.max_width = 900.0;
cloudAssembly.min_height = 600.0;
cloudAssembly.max_height = 900.0;
cloudAssembly.min_cloud_width = 1300;
cloudAssembly.min_cloud_height = 1000;
cloudAssembly.bottom_shade = 0.4;
}
else
{
if (rand() > 0.5)
{
cloudAssembly.texture_sheet = "/Models/Weather/congestus_sheet1.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 3;
cloudAssembly.min_width = 1300.0;
cloudAssembly.max_width = 2000.0;
cloudAssembly.min_height = 600.0;
cloudAssembly.max_height = 900.0;
}
else
{
cloudAssembly.texture_sheet = "/Models/Weather/congestus_sheet2.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 2;
cloudAssembly.min_width = 1200.0;
cloudAssembly.max_width = 1800.0;
cloudAssembly.min_height = 700.0;
cloudAssembly.max_height = 1000.0;
}
cloudAssembly.n_sprites = 3;
cloudAssembly.min_cloud_width = 2200.0;
cloudAssembly.min_cloud_height = 1200.0;
cloudAssembly.bottom_shade = 0.4;
}
cloudAssembly.z_scale = 1.0;
#signal that new routines are used
path = "new";
}
else if (type == "Stratocumulus"){
cloudAssembly = local_weather.cloud.new(type, subtype);
if (subtype == "small")
{
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
cloudAssembly.n_sprites = 7;
cloudAssembly.min_width = 600.0;
cloudAssembly.max_width = 900.0;
cloudAssembly.min_height = 600.0;
cloudAssembly.max_height = 900.0;
cloudAssembly.min_cloud_width = 1300;
cloudAssembly.min_cloud_height = 1300;
cloudAssembly.bottom_shade = 0.4;
}
else
{
if (rand() > 0.66)
{
cloudAssembly.texture_sheet = "/Models/Weather/congestus_sheet1.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 3;
cloudAssembly.min_width = 1900.0;
cloudAssembly.max_width = 2100.0;
cloudAssembly.min_height = 1000.0;
cloudAssembly.max_height = 1100.0;
cloudAssembly.n_sprites = 3;
cloudAssembly.bottom_shade = 0.5;
cloudAssembly.min_cloud_width = 3500.0;
cloudAssembly.min_cloud_height = 1600.0;
}
else if (rand() > 0.33)
{
cloudAssembly.texture_sheet = "/Models/Weather/congestus_sheet2.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 2;
cloudAssembly.min_width = 1900.0;
cloudAssembly.max_width = 2000.0;
cloudAssembly.min_height = 1000.0;
cloudAssembly.max_height = 1100.0;
cloudAssembly.n_sprites = 3;
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.min_cloud_width = 3500.0;
cloudAssembly.min_cloud_height = 1600.0;
}
else
{
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
cloudAssembly.min_width = 800.0;
cloudAssembly.max_width = 1000.0;
cloudAssembly.min_height = 800.0;
cloudAssembly.max_height = 1000.0;
cloudAssembly.n_sprites = 5;
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.min_cloud_width = 3000.0;
cloudAssembly.min_cloud_height = 1100.0;
}
}
cloudAssembly.z_scale = 1.0;
#signal that new routines are used
path = "new";
}
else if (type == "Cumulus (whisp)"){
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/altocumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.bottom_shade = 0.9;
cloudAssembly.n_sprites = 4;
cloudAssembly.min_width = 400.0 * mult;
cloudAssembly.max_width = 600.0 * mult;
cloudAssembly.min_height = 400.0 * mult;
cloudAssembly.max_height = 600.0 * mult;
cloudAssembly.min_cloud_width = 800;
cloudAssembly.min_cloud_height = 800;
cloudAssembly.z_scale = 1.0;
#signal that new routines are used
path = "new";
}
else if (type == "Cumulus bottom"){
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_bottom_sheet1.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 1;
#characterize the cloud
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.n_sprites = 4;
cloudAssembly.min_width = 600.0 * mult;
cloudAssembly.max_width = 800.0 * mult;
cloudAssembly.min_height = 600.0 * mult;
cloudAssembly.max_height = 800.0 * mult;
cloudAssembly.min_cloud_width = 1200 * mult * mult;
cloudAssembly.min_cloud_height = 800 * mult * mult;
cloudAssembly.z_scale = 0.6;
#signal that new routines are used
path = "new";
}
else if (type == "Congestus bottom"){
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_bottom_sheet1.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 1;
#characterize the cloud
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.n_sprites = 4;
cloudAssembly.min_width = 1100.0 * mult;
cloudAssembly.max_width = 1400.0 * mult;
cloudAssembly.min_height = 1100.0 * mult;
cloudAssembly.max_height = 1400.0 * mult;
cloudAssembly.min_cloud_width = 1600 * mult * mult;
cloudAssembly.min_cloud_height = 1200 * mult * mult;
cloudAssembly.z_scale = 0.4;
#signal that new routines are used
path = "new";
}
else if (type == "Stratocumulus bottom"){
cloudAssembly = local_weather.cloud.new(type, subtype);
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_bottom_sheet1.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 1;
#characterize the cloud
cloudAssembly.bottom_shade = 0.7;
cloudAssembly.n_sprites = 3;
cloudAssembly.min_width = 1200.0;
cloudAssembly.max_width = 1600.0;
cloudAssembly.min_height = 1200.0 ;
cloudAssembly.max_height = 1600.0;
cloudAssembly.min_cloud_width = 2000 ;
cloudAssembly.min_cloud_height = 1700;
cloudAssembly.z_scale = 0.4;
#signal that new routines are used
path = "new";
}
else if (type == "Cumulonimbus (cloudlet)"){
cloudAssembly = local_weather.cloud.new(type, subtype);
# characterize the basic texture sheet
cloudAssembly.num_tex_x = 2;
cloudAssembly.num_tex_y = 2;
if (rand() < 0.5)
{cloudAssembly.texture_sheet = "/Models/Weather/cumulonimbus_sheet2.rgb";}
else
{cloudAssembly.texture_sheet = "/Models/Weather/cumulonimbus_sheet1.rgb";}
var mult = 1.0;
if (subtype == "small") {mult = 0.7;}
#characterize the cloud
cloudAssembly.bottom_shade = 0.6;
cloudAssembly.n_sprites = 5;
cloudAssembly.min_width = 1700.0 * mult;
cloudAssembly.max_width = 2200.0 * mult;
cloudAssembly.min_height = 1700.0 * mult;
cloudAssembly.max_height = 2200.0 * mult;
cloudAssembly.min_cloud_width = 3500.0 * mult;
cloudAssembly.min_cloud_height = 3500.0 * mult;
cloudAssembly.z_scale = 1.0;
#signal that new routines are used
path = "new";
}
else if (type == "Altocumulus"){
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small") {mult = 0.7;}
else {mult = 1.0;}
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/altocumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.bottom_shade = 0.8;
cloudAssembly.n_sprites = 10;
cloudAssembly.min_width = 400.0 * mult;
cloudAssembly.max_width = 700.0 * mult;
cloudAssembly.min_height = 400.0 * mult;
cloudAssembly.max_height = 700.0 * mult;
cloudAssembly.min_cloud_width = 1200 * mult * mult;
cloudAssembly.min_cloud_height = 1200 * mult * mult;
cloudAssembly.z_scale = 0.8;
#signal that new routines are used
path = "new";
}
else if (type == "Stratus (structured)"){
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small") {mult = 0.7;}
else {mult = 1.0;}
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/altocumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.bottom_shade = 0.4;
# cloudAssembly.n_sprites = 25;
cloudAssembly.n_sprites = 12;
cloudAssembly.min_width = 1700.0 * mult;
cloudAssembly.max_width = 2500.0 * mult;
cloudAssembly.min_height = 1700.0 * mult;
cloudAssembly.max_height = 2500.0 * mult;
cloudAssembly.min_cloud_width = 3200.0 * mult * mult;
cloudAssembly.min_cloud_height = 500.0 * mult * mult + cloudAssembly.max_height;
cloudAssembly.z_scale = 0.3;
#signal that new routines are used
path = "new";
}
else if (type == "Altocumulus perlucidus"){
# new code
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small") {mult = 0.7;}
else {mult = 1.0;}
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/altocumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.bottom_shade = 0.8;
cloudAssembly.n_sprites = 25;
cloudAssembly.min_width = 1700.0 * mult;
cloudAssembly.max_width = 2500.0 * mult;
cloudAssembly.min_height = 1700.0 * mult;
cloudAssembly.max_height = 2500.0 * mult;
cloudAssembly.min_cloud_width = 3200.0 * mult * mult;
cloudAssembly.min_cloud_height = 500.0 * mult * mult + cloudAssembly.max_height;
cloudAssembly.z_scale = 0.2;
#signal that new routines are used
path = "new";
}
else if ((type == "Cumulonimbus") or (type == "Cumulonimbus (rain)")) {
if (subtype == "small") {
if (rn > 0.5) {path = "Models/Weather/cumulonimbus_small1.xml";}
else {path = "Models/Weather/cumulonimbus_small2.xml";}
}
else if (subtype == "large") {
if (rn > 0.5) {path = "Models/Weather/cumulonimbus_small1.xml";}
else {path = "Models/Weather/cumulonimbus_small2.xml";}
}
}
else if (type == "Cirrus") {
if (subtype == "large") {
if (rn > 0.916) {path = "Models/Weather/cirrus1.xml";}
else if (rn > 0.833) {path = "Models/Weather/cirrus2.xml";}
else if (rn > 0.75) {path = "Models/Weather/cirrus3.xml";}
else if (rn > 0.666) {path = "Models/Weather/cirrus4.xml";}
else if (rn > 0.583) {path = "Models/Weather/cirrus5.xml";}
else if (rn > 0.500) {path = "Models/Weather/cirrus6.xml";}
else if (rn > 0.416) {path = "Models/Weather/cirrus7.xml";}
else if (rn > 0.333) {path = "Models/Weather/cirrus8.xml";}
else if (rn > 0.250) {path = "Models/Weather/cirrus9.xml";}
else if (rn > 0.166) {path = "Models/Weather/cirrus10.xml";}
else if (rn > 0.083) {path = "Models/Weather/cirrus11.xml";}
else {path = "Models/Weather/cirrus12.xml";}
}
else if (subtype == "small") {
if (rn > 0.75) {path = "Models/Weather/cirrus_amorphous1.xml";}
else if (rn > 0.5) {path = "Models/Weather/cirrus_amorphous2.xml";}
else if (rn > 0.25) {path = "Models/Weather/cirrus_amorphous3.xml";}
else {path = "Models/Weather/cirrus_amorphous4.xml";}
}
}
else if (type == "Cirrocumulus") {
if (subtype == "small") {
if (rn > 0.5) {path = "Models/Weather/cirrocumulus1.xml";}
else {path = "Models/Weather/cirrocumulus2.xml";}
}
else if (subtype == "large") {
if (rn > 0.875) {path = "Models/Weather/cirrocumulus1.xml";}
else if (rn > 0.750){path = "Models/Weather/cirrocumulus4.xml";}
else if (rn > 0.625){path = "Models/Weather/cirrocumulus5.xml";}
else if (rn > 0.500){path = "Models/Weather/cirrocumulus6.xml";}
else if (rn > 0.385){path = "Models/Weather/cirrocumulus7.xml";}
else if (rn > 0.250){path = "Models/Weather/cirrocumulus8.xml";}
else if (rn > 0.125){path = "Models/Weather/cirrocumulus9.xml";}
else {path = "Models/Weather/cirrocumulus10.xml";}
}
}
else if (type == "Cirrocumulus (cloudlet)") {
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small") {mult = 0.6;}
else {mult = 1.0;}
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/cirrocumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.bottom_shade = 1.0;
cloudAssembly.n_sprites = 8;
cloudAssembly.min_width = 700.0 * mult;
cloudAssembly.max_width = 1200.0 * mult;
cloudAssembly.min_height = 700.0 * mult;
cloudAssembly.max_height = 1200.0 * mult;
cloudAssembly.min_cloud_width = 1500.0;
cloudAssembly.min_cloud_height = 1300.0 * mult;
cloudAssembly.z_scale = 0.3;
path = "new";
}
else if (type == "Cirrocumulus (new)") {
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small") {mult = 0.7;}
else {mult = 1.0;}
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/cirrocumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.bottom_shade = 1.0;
cloudAssembly.n_sprites = 2;
cloudAssembly.min_width = 200.0 * mult;
cloudAssembly.max_width = 300.0 * mult;
cloudAssembly.min_height = 200.0 * mult;
cloudAssembly.max_height = 300.0 * mult;
cloudAssembly.min_cloud_width = 400.0 * mult;
cloudAssembly.min_cloud_height = 400.0 * mult;
cloudAssembly.z_scale = 0.5;
#signal that new routines are used
path = "new";
}
else if (type == "Nimbus") {
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small") {mult = 0.7;}
else {mult = 1.0;}
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/nimbus_sheet1.rgb";
cloudAssembly.num_tex_x = 2;
cloudAssembly.num_tex_y = 3;
#characterize the cloud
cloudAssembly.bottom_shade = 0.6;
#cloudAssembly.n_sprites = 10;
cloudAssembly.n_sprites = 5;
cloudAssembly.min_width = 2700.0 * mult;
cloudAssembly.max_width = 3000.0 * mult;
cloudAssembly.min_height = 2700.0 * mult;
cloudAssembly.max_height = 3000.0 * mult;
cloudAssembly.min_cloud_width = 3500.0 * mult;
cloudAssembly.min_cloud_height = 3200.0 * mult;
cloudAssembly.z_scale = 0.4;
cloudAssembly.tracer_flag = 1;
#signal that new routines are used
path = "new";
}
else if (type == "Stratus") {
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small")
{
mult = 0.8;
cloudAssembly.texture_sheet = "/Models/Weather/cirrocumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
cloudAssembly.n_sprites = 10;
cloudAssembly.z_scale = 0.6;
}
else
{
mult = 1.0;
cloudAssembly.texture_sheet = "/Models/Weather/stratus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 2;
#cloudAssembly.n_sprites = 10;
cloudAssembly.n_sprites = 6;
cloudAssembly.z_scale = 0.4;
}
#characterize the cloud
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.min_width = 2000.0 * mult;
cloudAssembly.max_width = 2500.0 * mult;
cloudAssembly.min_height = 2000.0 * mult;
cloudAssembly.max_height = 2500.0 * mult;
cloudAssembly.min_cloud_width = 5000.0;
cloudAssembly.min_cloud_height = 2600 * mult; #1.1 * cloudAssembly.max_height;
#signal that new routines are used
path = "new";
}
else if (type == "Stratus (thin)") {
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small")
{
mult = 0.5;
cloudAssembly.texture_sheet = "/Models/Weather/cirrocumulus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 3;
# cloudAssembly.n_sprites = 20;
cloudAssembly.n_sprites = 10;
cloudAssembly.z_scale = 0.4;
}
else
{
mult = 1.0;
cloudAssembly.texture_sheet = "/Models/Weather/stratus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 2;
# cloudAssembly.n_sprites = 10;
cloudAssembly.n_sprites = 6;
cloudAssembly.z_scale = 0.3;
}
#characterize the cloud
cloudAssembly.bottom_shade = 0.8;
cloudAssembly.min_width = 1900.0 * mult;
cloudAssembly.max_width = 2400.0 * mult;
cloudAssembly.min_height = 1900.0 * mult;
cloudAssembly.max_height = 2400.0 * mult;
cloudAssembly.min_cloud_width = 4200.0;
cloudAssembly.min_cloud_height = 2500.0 * mult;
#signal that new routines are used
path = "new";
}
else if (type == "Cirrostratus") {
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small") {mult = 0.7;}
else {mult = 1.0;}
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/cirrostratus_sheet1.rgb";
cloudAssembly.num_tex_x = 2;
cloudAssembly.num_tex_y = 2;
#characterize the cloud
cloudAssembly.bottom_shade = 1.0;
cloudAssembly.n_sprites = 4;
cloudAssembly.min_width = 3500.0 * mult;
cloudAssembly.max_width = 4000.0 * mult;
cloudAssembly.min_height = 3500.0 * mult;
cloudAssembly.max_height = 4000.0 * mult;
cloudAssembly.min_cloud_width = 8000.0;
cloudAssembly.min_cloud_height = 50.0;
cloudAssembly.z_scale = 0.3;
#signal that new routines are used
path = "new";
}
else if (type == "Fog (thin)") {
if (subtype == "small") {
if (rn > 0.8) {path = "Models/Weather/stratus_thin1.xml";}
else if (rn > 0.6) {path = "Models/Weather/stratus_thin2.xml";}
else if (rn > 0.4) {path = "Models/Weather/stratus_thin3.xml";}
else if (rn > 0.2) {path = "Models/Weather/stratus_thin4.xml";}
else {path = "Models/Weather/stratus_thin5.xml";}
}
else if (subtype == "large") {
if (rn > 0.8) {path = "Models/Weather/stratus_thin1.xml";}
else if (rn > 0.6) {path = "Models/Weather/stratus_thin2.xml";}
else if (rn > 0.4) {path = "Models/Weather/stratus_thin3.xml";}
else if (rn > 0.2) {path = "Models/Weather/stratus_thin4.xml";}
else {path = "Models/Weather/stratus_thin5.xml";}
}
}
else if (type == "Fog (thick)") {
cloudAssembly = local_weather.cloud.new(type, subtype);
var mult = 1.0;
if (subtype == "small")
{
mult = 0.8;
cloudAssembly.texture_sheet = "/Models/Weather/stratus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 2;
cloudAssembly.n_sprites = 5;
cloudAssembly.z_scale = 1.0;
}
else
{
mult = 1.0;
cloudAssembly.texture_sheet = "/Models/Weather/stratus_sheet1.rgb";
cloudAssembly.num_tex_x = 3;
cloudAssembly.num_tex_y = 2;
cloudAssembly.n_sprites = 5;
cloudAssembly.z_scale = 1.0;
}
#characterize the cloud
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.min_width = 2000.0 * mult;
cloudAssembly.max_width = 2500.0 * mult;
cloudAssembly.min_height = 2000.0 * mult;
cloudAssembly.max_height = 2500.0 * mult;
cloudAssembly.min_cloud_width = 5000.0;
cloudAssembly.min_cloud_height = 1.1 * cloudAssembly.max_height;
#signal that new routines are used
path = "new";
}
else if (type == "Test") {path="Models/Weather/single_cloud.xml";}
else if (type == "Box_test") {
if (subtype == "standard") {
if (rn > 0.8) {path = "Models/Weather/cloudbox1.xml";}
else if (rn > 0.6) {path = "Models/Weather/cloudbox2.xml";}
else if (rn > 0.4) {path = "Models/Weather/cloudbox3.xml";}
else if (rn > 0.2) {path = "Models/Weather/cloudbox4.xml";}
else {path = "Models/Weather/cloudbox5.xml";}
}
else if (subtype == "core") {
if (rn > 0.8) {path = "Models/Weather/cloudbox_core1.xml";}
else if (rn > 0.6) {path = "Models/Weather/cloudbox_core2.xml";}
else if (rn > 0.4) {path = "Models/Weather/cloudbox_core3.xml";}
else if (rn > 0.2) {path = "Models/Weather/cloudbox_core4.xml";}
else {path = "Models/Weather/cloudbox_core5.xml";}
}
else if (subtype == "bottom") {
if (rn > 0.66) {path = "Models/Weather/cloudbox_bottom1.xml";}
else if (rn > 0.33) {path = "Models/Weather/cloudbox_bottom2.xml";}
else if (rn > 0.0) {path = "Models/Weather/cloudbox_bottom3.xml";}
}
}
else if (type == "Cb_box") {
cloudAssembly = local_weather.cloud.new(type, subtype);
if (subtype == "standard")
{
if (rand() > 0.5) # use a Congestus texture
{
if (rand() > 0.5)
{
cloudAssembly.texture_sheet = "/Models/Weather/congestus_sheet1.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 3;
cloudAssembly.min_width = 1300.0;
cloudAssembly.max_width = 2000.0;
cloudAssembly.min_height = 600.0;
cloudAssembly.max_height = 900.0;
}
else
{
cloudAssembly.texture_sheet = "/Models/Weather/congestus_sheet2.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 2;
cloudAssembly.min_width = 1200.0;
cloudAssembly.max_width = 1800.0;
cloudAssembly.min_height = 700.0;
cloudAssembly.max_height = 1000.0;
}
cloudAssembly.n_sprites = 3;
cloudAssembly.min_cloud_width = 2200.0;
cloudAssembly.min_cloud_height = 1200.0;
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.z_scale = 1.0;
}
else
{
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/cumulonimbus_sheet2.rgb";
cloudAssembly.num_tex_x = 2;
cloudAssembly.num_tex_y = 2;
#characterize the cloud
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.n_sprites = 6;
cloudAssembly.min_width = 800.0;
cloudAssembly.max_width = 1100.0;
cloudAssembly.min_height = 800.0;
cloudAssembly.max_height = 1100.0;
cloudAssembly.min_cloud_width = 3000.0;
cloudAssembly.min_cloud_height = 1500.0;
cloudAssembly.z_scale = 1.0;
}
}
else if (subtype == "core")
{
# characterize the basic texture sheet
cloudAssembly.texture_sheet = "/Models/Weather/cumulonimbus_sheet1.rgb";
cloudAssembly.num_tex_x = 2;
cloudAssembly.num_tex_y = 2;
#characterize the cloud
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.n_sprites = 10;
cloudAssembly.min_width = 1000.0;
cloudAssembly.max_width = 1500.0;
cloudAssembly.min_height = 1000.0;
cloudAssembly.max_height = 1500.0 ;
cloudAssembly.min_cloud_width = 3500.0;
cloudAssembly.min_cloud_height = 2000.0;
cloudAssembly.z_scale = 1.0;
}
else if (subtype == "bottom")
{
cloudAssembly.texture_sheet = "/Models/Weather/cumulus_bottom_sheet1.rgb";
cloudAssembly.num_tex_x = 1;
cloudAssembly.num_tex_y = 1;
#characterize the cloud
cloudAssembly.bottom_shade = 0.4;
cloudAssembly.n_sprites = 4;
cloudAssembly.min_width = 1100.0;
cloudAssembly.max_width = 1400.0;
cloudAssembly.min_height = 1100.0;
cloudAssembly.max_height = 1400.0;
cloudAssembly.min_cloud_width = 1600;
cloudAssembly.min_cloud_height = 1200;
cloudAssembly.z_scale = 0.4;
}
#signal that new routines are used
path = "new";
}
else {print("Cloud type ", type, " subtype ",subtype, " not available!");}
return path;
}
# hash for assembling hard-coded clouds
var cloudAssembly = {};