puObject *
FGDialog::makeObject (SGPropertyNode * props, int parentWidth, int parentHeight)
{
+ if (props->getBoolValue("hide"))
+ return 0;
+
bool presetSize = props->hasValue("width") && props->hasValue("height");
int width = props->getIntValue("width", parentWidth);
int height = props->getIntValue("height", parentHeight);
FGDialog::setColor(puObject * object, SGPropertyNode * props, int which)
{
string type = props->getName();
- FGColor c(_gui->getColor("background"));
- c.merge(_gui->getColor(type));
- c.merge(props->getNode("color"));
- if (c.isValid())
- object->setColourScheme(c.red(), c.green(), c.blue(), c.alpha());
+ if (type == "")
+ type = "dialog";
+
+ FGColor *c = new FGColor(_gui->getColor("background"));
+ c->merge(_gui->getColor(type));
+ c->merge(props->getNode("color"));
+ if (c->isValid())
+ object->setColourScheme(c->red(), c->green(), c->blue(), c->alpha());
const int numcol = 6;
const struct {
const char *name;
const char *cname;
} pucol[numcol] = {
- BACKGROUND, PUCOL_BACKGROUND, "background", "color-background",
- FOREGROUND, PUCOL_FOREGROUND, "foreground", "color-foreground",
- HIGHLIGHT, PUCOL_HIGHLIGHT, "highlight", "color-highlight",
- LABEL, PUCOL_LABEL, "label", "color-label",
- LEGEND, PUCOL_LEGEND, "legend", "color-legend",
- MISC, PUCOL_MISC, "misc", "color-misc",
+ { BACKGROUND, PUCOL_BACKGROUND, "background", "color-background" },
+ { FOREGROUND, PUCOL_FOREGROUND, "foreground", "color-foreground" },
+ { HIGHLIGHT, PUCOL_HIGHLIGHT, "highlight", "color-highlight" },
+ { LABEL, PUCOL_LABEL, "label", "color-label" },
+ { LEGEND, PUCOL_LEGEND, "legend", "color-legend" },
+ { MISC, PUCOL_MISC, "misc", "color-misc" }
};
for (int i = 0; i < numcol; i++) {
bool dirty = false;
- c.clear();
- c.setAlpha(1.0);
+ c->clear();
+ c->setAlpha(1.0);
- dirty |= c.merge(_gui->getColor(type + '-' + pucol[i].name));
+ dirty |= c->merge(_gui->getColor(type + '-' + pucol[i].name));
if (which & pucol[i].mask)
- dirty |= c.merge(props->getNode("color"));
+ dirty |= c->merge(props->getNode("color"));
- if ((pucol[i].mask == LABEL) && !c.isValid())
- dirty |= c.merge(_gui->getColor("label"));
+ if ((pucol[i].mask == LABEL) && !c->isValid())
+ dirty |= c->merge(_gui->getColor("label"));
- if (c.isValid() && dirty)
- object->setColor(pucol[i].id, c.red(), c.green(), c.blue(), c.alpha());
+ if (c->isValid() && dirty)
+ object->setColor(pucol[i].id, c->red(), c->green(), c->blue(), c->alpha());
}
}