+
+ if ( postlabel == "blank" ) {
+ post_label_string = " ";
+ } else {
+ if ( postlabel == "NULL" ) {
+ post_label_string = NULL;
+ } else {
+ if ( postlabel == "units" ) {
+ post_label_string = units;
+ } else {
+ post_label_string = postlabel.c_str();
+ }
+ }
+ }
+
+#ifdef ENABLE_SP_FMDS
+ if ( loadfn== "aux1" ) {
+ load_fn = get_aux1;
+ } else if ( loadfn == "aux2" ) {
+ load_fn = get_aux2;
+ } else if ( loadfn == "aux3" ) {
+ load_fn = get_aux3;
+ } else if ( loadfn == "aux4" ) {
+ load_fn = get_aux4;
+ } else if ( loadfn == "aux5" ) {
+ load_fn = get_aux5;
+ } else if ( loadfn == "aux6" ) {
+ load_fn = get_aux6;
+ } else if ( loadfn == "aux7" ) {
+ load_fn = get_aux7;
+ } else if ( loadfn == "aux8" ) {
+ load_fn = get_aux8;
+ } else if ( loadfn == "aux9" ) {
+ load_fn = get_aux9;
+ } else if ( loadfn == "aux10" ) {
+ load_fn = get_aux10;
+ } else if ( loadfn == "aux11" ) {
+ load_fn = get_aux11;
+ } else if ( loadfn == "aux12" ) {
+ load_fn = get_aux12;
+ } else if ( loadfn == "aux13" ) {
+ load_fn = get_aux13;
+ } else if ( loadfn == "aux14" ) {
+ load_fn = get_aux14;
+ } else if ( loadfn == "aux15" ) {
+ load_fn = get_aux15;
+ } else if ( loadfn == "aux16" ) {
+ load_fn = get_aux16;
+ } else if ( loadfn == "aux17" ) {
+ load_fn = get_aux17;
+ } else if ( loadfn == "aux18" ) {
+ load_fn = get_aux18;
+ } else
+#endif
+ if ( loadfn == "ax" ) {
+ load_fn = get_Ax;
+ } else if ( loadfn == "speed" ) {
+ load_fn = get_speed;
+ } else if ( loadfn == "mach" ) {
+ load_fn = get_mach;
+ } else if ( loadfn == "altitude" ) {
+ load_fn = get_altitude;
+ } else if ( loadfn == "agl" ) {
+ load_fn = get_agl;
+ } else if ( loadfn == "framerate" ) {
+ load_fn = get_frame_rate;
+ } else if ( loadfn == "heading" ) {
+ load_fn = get_heading;
+ } else if ( loadfn == "fov" ) {
+ load_fn = get_fov;
+ } else if ( loadfn == "vfc_tris_culled" ) {
+ load_fn = get_vfc_tris_culled;
+ } else if ( loadfn == "vfc_tris_drawn" ) {
+ load_fn = get_vfc_tris_drawn;
+ } else if ( loadfn == "aoa" ) {
+ load_fn = get_aoa;
+ } else if ( loadfn == "latitude" ) {
+ load_fn = get_latitude;
+ } else if ( loadfn == "anzg" ) {
+ load_fn = get_anzg;
+ } else if ( loadfn == "longitude" ) {
+ load_fn = get_longitude;
+ } else if (loadfn=="throttleval") {
+ load_fn = get_throttleval;
+ }
+
+ p = (instr_item *) new instr_label ( x,
+ y,
+ width,
+ height,
+ load_fn,
+ label_format.c_str(),
+ pre_label_string,
+ post_label_string,
+ scaling,
+ options,
+ justification,
+ font_size,
+ blinking,
+ latitude,
+ longitude,
+ label_box, //hud
+ working,
+ digits); //suma
+
+ return p;
+} // end readLabel
+
+static instr_item *
+readTBI(const SGPropertyNode * node)
+{
+
+ instr_item *p;
+
+ name = node->getStringValue("name");
+ x = node->getIntValue("x");
+ y = node->getIntValue("y");
+ width = node->getIntValue("width");
+ height = node->getIntValue("height");
+ maxBankAngle = node->getFloatValue("maxBankAngle");
+ maxSlipAngle = node->getFloatValue("maxSlipAngle");
+ gap_width = node->getIntValue("gap_width");
+ working = node->getBoolValue("working");
+ tsi = node->getBoolValue("tsi"); //suma
+ rad = node->getFloatValue("rad"); //suma
+
+ SG_LOG(SG_INPUT, SG_INFO, "Done reading instrument " << name);
+
+
+ p = (instr_item *) new fgTBI_instr( x,
+ y,
+ width,
+ height,
+ get_roll,
+ get_sideslip,
+ maxBankAngle,
+ maxSlipAngle,
+ gap_width,
+ working,
+ tsi, //suma
+ rad); //suma
+
+ return p;
+} //end readTBI
+
+static instr_item *
+readRunway(const SGPropertyNode * node) {
+ name = node->getStringValue("name");
+ x = node->getIntValue("x");
+ y = node->getIntValue("y");
+ width = node->getIntValue("width");
+ height = node->getIntValue("height");
+ scaling = node->getDoubleValue("scale");
+ working = node->getBoolValue("working",true);
+ runway_instr *ri = new runway_instr(x,y,width,height,scaling,working);
+ double scale = node->getDoubleValue("arrow_scale",1.0);
+ ri->setDrawArrow((scale>0)?true:false);
+ ri->setDrawArrowAlways((scale>0)?node->getBoolValue("arrow_always"):false);
+ ri->setStippleOutline(node->getIntValue("outer_stipple",0xFFFF));
+ ri->setStippleCenterline(node->getIntValue("center_stipple",0xFFFF));
+ ri->setArrowRotationRadius(node->getDoubleValue("arrow_radius"));
+ ri->setArrowScale(scale);
+ ri->setLineScale(node->getDoubleValue("line_scale",1.0));
+ ri->setScaleDist(node->getDoubleValue("scale_dist_nm"));
+ SG_LOG(SG_INPUT, SG_INFO, "Done reading instrument " << name);
+ return (instr_item *) ri;