void WVuMeter::setup(QDomNode node, const SkinContext& context) { // Set pixmaps bool bHorizontal = context.hasNode(node, "Horizontal") && context.selectString(node, "Horizontal") == "true"; // Set background pixmap if available if (context.hasNode(node, "PathBack")) { setPixmapBackground(context.getSkinPath(context.selectString(node, "PathBack"))); } setPixmaps(context.getSkinPath(context.selectString(node, "PathVu")), bHorizontal); m_iPeakHoldSize = context.selectInt(node, "PeakHoldSize"); if (m_iPeakHoldSize < 0 || m_iPeakHoldSize > 100) m_iPeakHoldSize = DEFAULT_HOLDSIZE; m_iPeakFallStep = context.selectInt(node, "PeakFallStep"); if (m_iPeakFallStep < 1 || m_iPeakFallStep > 1000) m_iPeakFallStep = DEFAULT_FALLSTEP; m_iPeakHoldTime = context.selectInt(node, "PeakHoldTime"); if (m_iPeakHoldTime < 1 || m_iPeakHoldTime > 3000) m_iPeakHoldTime = DEFAULT_HOLDTIME; m_iPeakFallTime = context.selectInt(node, "PeakFallTime"); if (m_iPeakFallTime < 1 || m_iPeakFallTime > 1000) m_iPeakFallTime = DEFAULT_FALLTIME; }
void WSliderComposed::setup(QDomNode node, const SkinContext& context) { // Setup pixmaps unsetPixmaps(); if (context.hasNode(node, "Slider")) { PixmapSource sourceSlider = context.getPixmapSource(context.selectNode(node, "Slider")); setSliderPixmap(sourceSlider); } PixmapSource sourceHandle = context.getPixmapSource(context.selectNode(node, "Handle")); bool h = context.selectBool(node, "Horizontal", false); setHandlePixmap(h, sourceHandle); if (context.hasNode(node, "EventWhileDrag")) { if (context.selectString(node, "EventWhileDrag").contains("no")) { m_bEventWhileDrag = false; } } if (!m_connections.isEmpty()) { ControlParameterWidgetConnection* defaultConnection = m_connections.at(0); if (defaultConnection) { if (defaultConnection->getEmitOption() & ControlParameterWidgetConnection::EMIT_DEFAULT) { // ON_PRESS means here value change on mouse move during press defaultConnection->setEmitOption( ControlParameterWidgetConnection::EMIT_ON_PRESS_AND_RELEASE); } } } }
void WStatusLight::setup(QDomNode node, const SkinContext& context) { // Number of states. Add one to account for the background. setNoPos(context.selectInt(node, "NumberPos") + 1); // Set pixmaps for (int i = 0; i < m_pixmaps.size(); ++i) { // Accept either PathStatusLight or PathStatusLight1 for value 1, QString nodeName = QString("PathStatusLight%1").arg(i); if (context.hasNode(node, nodeName)) { QString mode = context.selectAttributeString( context.selectElement(node, nodeName), "sizemode", "FIXED"); setPixmap(i, context.getSkinPath(context.selectString(node, nodeName)), SizeModeFromString(mode)); } else if (i == 0 && context.hasNode(node, "PathBack")) { QString mode = context.selectAttributeString( context.selectElement(node, "PathBack"), "sizemode", "FIXED"); setPixmap(i, context.getSkinPath(context.selectString(node, "PathBack")), SizeModeFromString(mode)); } else if (i == 1 && context.hasNode(node, "PathStatusLight")) { QString mode = context.selectAttributeString( context.selectElement(node, "PathStatusLight"), "sizemode", "FIXED"); setPixmap(i, context.getSkinPath(context.selectString(node, "PathStatusLight")), SizeModeFromString(mode)); } else { m_pixmaps[i].clear(); } } }
void WLabel::setup(QDomNode node, const SkinContext& context) { // Colors QPalette pal = palette(); //we have to copy out the palette to edit it since it's const (probably for threadsafety) if (context.hasNode(node, "BgColor")) { m_qBgColor.setNamedColor(context.selectString(node, "BgColor")); pal.setColor(this->backgroundRole(), WSkinColor::getCorrectColor(m_qBgColor)); setAutoFillBackground(true); } m_qFgColor.setNamedColor(context.selectString(node, "FgColor")); pal.setColor(this->foregroundRole(), WSkinColor::getCorrectColor(m_qFgColor)); setPalette(pal); // Text if (context.hasNode(node, "Text")) m_qsText = context.selectString(node, "Text"); setText(m_qsText); // Font size if (context.hasNode(node, "FontSize")) { int fontsize = 9; fontsize = context.selectString(node, "FontSize").toInt(); setFont( QFont("Helvetica",fontsize,QFont::Normal) ); } // Alignment if (context.hasNode(node, "Alignment")) { if (context.selectString(node, "Alignment") == "right") { setAlignment(Qt::AlignRight | Qt::AlignVCenter); } else if (context.selectString(node, "Alignment") == "center") { setAlignment(Qt::AlignHCenter | Qt::AlignVCenter); } else if (context.selectString(node, "Alignment") == "left") { setAlignment(Qt::AlignLeft | Qt::AlignVCenter); } } }
void WDisplay::setup(QDomNode node, const SkinContext& context) { // Set background pixmap if available if (context.hasNode(node, "BackPath")) { setPixmapBackground(context.getSkinPath( context.selectString(node, "BackPath"))); } // Number of states setPositions(context.selectInt(node, "NumberStates")); // Load knob pixmaps QString path = context.selectString(node, "Path"); for (int i = 0; i < m_pixmaps.size(); ++i) { setPixmap(&m_pixmaps, i, context.getSkinPath(path.arg(i))); } // See if disabled images is defined, and load them... if (context.hasNode(node, "DisabledPath")) { QString disabledPath = context.selectString(node, "DisabledPath"); for (int i = 0; i < m_disabledPixmaps.size(); ++i) { setPixmap(&m_disabledPixmaps, i, context.getSkinPath(disabledPath.arg(i))); } m_bDisabledLoaded = true; } }
void WTime::setTimeFormat(QDomNode node, const SkinContext& context) { // if a custom format is defined, all other formatting flags are ignored if (!context.hasNode(node, "CustomFormat")) { // check if seconds should be shown QString secondsFormat = context.selectString(node, "ShowSeconds"); if(secondsFormat == "true" || secondsFormat == "yes") { m_sTimeFormat = "h:mm:ss"; m_iInterval = s_iSecondInterval; } else { m_sTimeFormat = "h:mm"; m_iInterval = s_iMinuteInterval; } // check if 24 hour format or 12 hour format is selected QString clockFormat = context.selectString(node, "ClockFormat"); if (clockFormat == "24" || clockFormat == "24hrs") { } else if (clockFormat == "12" || clockFormat == "12hrs" || clockFormat == "12ap") { m_sTimeFormat += " ap"; } else if (clockFormat == "12AP") { m_sTimeFormat += " AP"; } else { qDebug() << "WTime: Unknown clock format: " << clockFormat; } } else { // set the time format to the custom format m_sTimeFormat = context.selectString(node, "CustomFormat"); } }
void WWidgetGroup::setup(QDomNode node, const SkinContext& context) { setContentsMargins(0, 0, 0, 0); // Set background pixmap if available if (context.hasNode(node, "BackPath")) { setPixmapBackground(context.getSkinPath(context.selectString(node, "BackPath"))); } QLayout* pLayout = NULL; if (context.hasNode(node, "Layout")) { QString layout = context.selectString(node, "Layout"); if (layout == "vertical") { pLayout = new QVBoxLayout(); pLayout->setSpacing(0); pLayout->setContentsMargins(0, 0, 0, 0); pLayout->setAlignment(Qt::AlignCenter); } else if (layout == "horizontal") { pLayout = new QHBoxLayout(); pLayout->setSpacing(0); pLayout->setContentsMargins(0, 0, 0, 0); pLayout->setAlignment(Qt::AlignCenter); } } if (pLayout && context.hasNode(node, "SizeConstraint")) { QMap<QString, QLayout::SizeConstraint> constraints; constraints["SetDefaultConstraint"] = QLayout::SetDefaultConstraint; constraints["SetFixedSize"] = QLayout::SetFixedSize; constraints["SetMinimumSize"] = QLayout::SetMinimumSize; constraints["SetMaximumSize"] = QLayout::SetMaximumSize; constraints["SetMinAndMaxSize"] = QLayout::SetMinAndMaxSize; constraints["SetNoConstraint"] = QLayout::SetNoConstraint; QString sizeConstraintStr = context.selectString(node, "SizeConstraint"); if (constraints.contains(sizeConstraintStr)) { pLayout->setSizeConstraint(constraints[sizeConstraintStr]); } else { qDebug() << "Could not parse SizeConstraint:" << sizeConstraintStr; } } if (pLayout) { setLayout(pLayout); } }
void WNumber::setup(QDomNode node, const SkinContext& context) { WLabel::setup(node, context); // Number of digits after the decimal. if (context.hasNode(node, "NumberOfDigits")) { m_iNoDigits = context.selectInt(node, "NumberOfDigits"); } setValue(0.); }
void WSearchLineEdit::setup(QDomNode node, const SkinContext& context) { // Background color QColor bgc(255,255,255); if (context.hasNode(node, "BgColor")) { bgc.setNamedColor(context.selectString(node, "BgColor")); setAutoFillBackground(true); } QPalette pal = palette(); pal.setBrush(backgroundRole(), WSkinColor::getCorrectColor(bgc)); // Foreground color m_fgc = QColor(0,0,0); if (context.hasNode(node, "FgColor")) { m_fgc.setNamedColor(context.selectString(node, "FgColor")); } bgc = WSkinColor::getCorrectColor(bgc); m_fgc = QColor(255 - bgc.red(), 255 - bgc.green(), 255 - bgc.blue()); pal.setBrush(foregroundRole(), m_fgc); setPalette(pal); }
void WSplitter::setup(QDomNode node, const SkinContext& context) { // Default orientation is horizontal. if (context.hasNode(node, "Orientation")) { QString layout = context.selectString(node, "Orientation"); if (layout == "vertical") { setOrientation(Qt::Vertical); } else if (layout == "horizontal") { setOrientation(Qt::Horizontal); } } }
void WKnobComposed::setup(QDomNode node, const SkinContext& context) { clear(); // Set background pixmap if available if (context.hasNode(node, "BackPath")) { setPixmapBackground(context.getSkinPath(context.selectString(node, "BackPath"))); } // Set background pixmap if available if (context.hasNode(node, "Knob")) { setPixmapKnob(context.getSkinPath(context.selectString(node, "Knob"))); } if (context.hasNode(node, "MinAngle")) { m_dMinAngle = context.selectDouble(node, "MinAngle"); } if (context.hasNode(node, "MaxAngle")) { m_dMaxAngle = context.selectDouble(node, "MaxAngle"); } }
void WNumber::setup(QDomNode node, const SkinContext& context) { WLabel::setup(node, context); // Number of digits // TODO(rryan): This has been unused for a long time yet our skins specify // this value all over the place. m_iNoDigits = context.selectInt(node, "NumberOfDigits"); // Constant factor if (context.hasNode(node, "ConstFactor")) { m_dConstFactor = context.selectString(node, "ConstFactor").toDouble(); } setValue(0.); }
void WVuMeter::setup(QDomNode node, const SkinContext& context) { // Set pixmaps bool bHorizontal = context.hasNode(node, "Horizontal") && context.selectString(node, "Horizontal") == "true"; // Set background pixmap if available if (context.hasNode(node, "PathBack")) { QDomElement backPathNode = context.selectElement(node, "PathBack"); // The implicit default in <1.12.0 was FIXED so we keep it for backwards // compatibility. setPixmapBackground(context.getPixmapSource(backPathNode), context.selectScaleMode(backPathNode, Paintable::FIXED)); } QDomElement vuNode = context.selectElement(node, "PathVu"); // The implicit default in <1.12.0 was FIXED so we keep it for backwards // compatibility. setPixmaps(context.getPixmapSource(vuNode), bHorizontal, context.selectScaleMode(vuNode, Paintable::FIXED)); m_iPeakHoldSize = context.selectInt(node, "PeakHoldSize"); if (m_iPeakHoldSize < 0 || m_iPeakHoldSize > 100) m_iPeakHoldSize = DEFAULT_HOLDSIZE; m_iPeakFallStep = context.selectInt(node, "PeakFallStep"); if (m_iPeakFallStep < 1 || m_iPeakFallStep > 1000) m_iPeakFallStep = DEFAULT_FALLSTEP; m_iPeakHoldTime = context.selectInt(node, "PeakHoldTime"); if (m_iPeakHoldTime < 1 || m_iPeakHoldTime > 3000) m_iPeakHoldTime = DEFAULT_HOLDTIME; m_iPeakFallTime = context.selectInt(node, "PeakFallTime"); if (m_iPeakFallTime < 1 || m_iPeakFallTime > 1000) m_iPeakFallTime = DEFAULT_FALLTIME; }
void WKnobComposed::setup(QDomNode node, const SkinContext& context) { clear(); // Set background pixmap if available if (context.hasNode(node, "BackPath")) { QString mode_str = context.selectAttributeString( context.selectElement(node, "BackPath"), "scalemode", "TILE"); setPixmapBackground(context.getPixmapPath(context.selectNode(node, "BackPath")), Paintable::DrawModeFromString(mode_str)); } // Set background pixmap if available if (context.hasNode(node, "Knob")) { setPixmapKnob(context.getPixmapPath(context.selectNode(node, "Knob"))); } if (context.hasNode(node, "MinAngle")) { m_dMinAngle = context.selectDouble(node, "MinAngle"); } if (context.hasNode(node, "MaxAngle")) { m_dMaxAngle = context.selectDouble(node, "MaxAngle"); } }
void WComboBox::setup(QDomNode node, const SkinContext& context) { // Load pixmaps for associated states QDomNode state = context.selectNode(node, "State"); while (!state.isNull()) { if (state.isElement() && state.nodeName() == "State") { if (!context.hasNode(state, "Number")) { qDebug() << "WComboBox ignoring <State> without <Number> node."; continue; } int iState = context.selectInt(state, "Number"); QString text = context.selectString(state, "Text"); QString icon = context.selectString(state, "Icon"); addItem(QIcon(icon), text, QVariant(iState)); } state = state.nextSibling(); } }
void WTime::setTimeFormat(QDomNode node, const SkinContext& context) { // if a custom format is defined, all other formatting flags are ignored if (!context.hasNode(node, "CustomFormat")) { // check if seconds should be shown QString secondsFormat = context.selectString(node, "ShowSeconds"); // long format is equivalent to showing seconds QLocale::FormatType format; if(secondsFormat == "true" || secondsFormat == "yes") { format = QLocale::LongFormat; m_iInterval = s_iSecondInterval; } else { format = QLocale::ShortFormat; m_iInterval = s_iMinuteInterval; } m_sTimeFormat = QLocale().timeFormat(format); } else { // set the time format to the custom format m_sTimeFormat = context.selectString(node, "CustomFormat"); } }
void WBattery::setup(QDomNode node, const SkinContext& context) { if (context.hasNode(node, "BackPath")) { QString mode_str = context.selectAttributeString( context.selectElement(node, "BackPath"), "scalemode", "TILE"); setPixmap(&m_pPixmapBack, context.getPixmapSource(context.selectNode(node, "BackPath")), Paintable::DrawModeFromString(mode_str)); } if (context.hasNode(node, "PixmapUnknown")) { QString mode_str = context.selectAttributeString( context.selectElement(node, "PixmapUnknown"), "scalemode", "TILE"); setPixmap(&m_pPixmapUnknown, context.getPixmapSource(context.selectNode(node, "PixmapUnknown")), Paintable::DrawModeFromString(mode_str)); } if (context.hasNode(node, "PixmapCharged")) { QString mode_str = context.selectAttributeString( context.selectElement(node, "PixmapCharged"), "scalemode", "TILE"); setPixmap(&m_pPixmapCharged, context.getPixmapSource(context.selectNode(node, "PixmapCharged")), Paintable::DrawModeFromString(mode_str)); } int numberStates = context.selectInt(node, "NumberStates"); if (numberStates < 0) { numberStates = 0; } m_chargingPixmaps.resize(numberStates); m_dischargingPixmaps.resize(numberStates); if (context.hasNode(node, "PixmapsCharging")) { // TODO(XXX) inline SVG support via context.getPixmapSource. QString chargingPath = context.selectString(node, "PixmapsCharging"); Paintable::DrawMode mode = Paintable::DrawModeFromString( context.selectAttributeString( context.selectElement(node, "PixmapsCharging"), "scalemode", "TILE")); for (int i = 0; i < m_chargingPixmaps.size(); ++i) { PixmapSource source(chargingPath.arg(i)); setPixmap(&m_chargingPixmaps[i], source, mode); } } if (context.hasNode(node, "PixmapsDischarging")) { // TODO(XXX) inline SVG support via context.getPixmapSource. QString dischargingPath = context.selectString(node, "PixmapsDischarging"); Paintable::DrawMode mode = Paintable::DrawModeFromString( context.selectAttributeString( context.selectElement(node, "PixmapsDischarging"), "scalemode", "TILE")); for (int i = 0; i < m_dischargingPixmaps.size(); ++i) { PixmapSource source(dischargingPath.arg(i)); setPixmap(&m_dischargingPixmaps[i], source, mode); } } if (m_pBattery) { m_pBattery->update(); } }
void WPushButton::setup(QDomNode node, const SkinContext& context) { // Number of states int iNumStates = context.selectInt(node, "NumberStates"); setStates(iNumStates); // Set background pixmap if available if (context.hasNode(node, "BackPath")) { QString mode_str = context.selectAttributeString( context.selectElement(node, "BackPath"), "scalemode", "TILE"); setPixmapBackground(context.getSkinPath(context.selectString(node, "BackPath")), Paintable::DrawModeFromString(mode_str)); } // Load pixmaps for associated states QDomNode state = context.selectNode(node, "State"); while (!state.isNull()) { if (state.isElement() && state.nodeName() == "State") { int iState = context.selectInt(state, "Number"); if (iState < m_iNoStates) { if (context.hasNode(state, "Pressed")) { setPixmap(iState, true, context.getSkinPath(context.selectString(state, "Pressed"))); } if (context.hasNode(state, "Unpressed")) { setPixmap(iState, false, context.getSkinPath(context.selectString(state, "Unpressed"))); } m_text.replace(iState, context.selectString(state, "Text")); } } state = state.nextSibling(); } ControlParameterWidgetConnection* leftConnection = NULL; if (m_leftConnections.isEmpty()) { if (!m_connections.isEmpty()) { // If no left connection is set, the this is the left connection leftConnection = m_connections.at(0); } } else { leftConnection = m_leftConnections.at(0); } if (leftConnection) { bool leftClickForcePush = context.selectBool(node, "LeftClickIsPushButton", false); m_leftButtonMode = ControlPushButton::PUSH; if (!leftClickForcePush) { const ConfigKey& configKey = leftConnection->getKey(); ControlPushButton* p = dynamic_cast<ControlPushButton*>( ControlObject::getControl(configKey)); if (p) { m_leftButtonMode = p->getButtonMode(); } } if (leftConnection->getEmitOption() & ControlParameterWidgetConnection::EMIT_DEFAULT) { switch (m_leftButtonMode) { case ControlPushButton::PUSH: case ControlPushButton::LONGPRESSLATCHING: case ControlPushButton::POWERWINDOW: leftConnection->setEmitOption( ControlParameterWidgetConnection::EMIT_ON_PRESS_AND_RELEASE); break; default: leftConnection->setEmitOption( ControlParameterWidgetConnection::EMIT_ON_PRESS); break; } } if (leftConnection->getDirectionOption() & ControlParameterWidgetConnection::DIR_DEFAULT) { if (m_pDisplayConnection == leftConnection) { leftConnection->setDirectionOption(ControlParameterWidgetConnection::DIR_FROM_AND_TO_WIDGET); } else { leftConnection->setDirectionOption(ControlParameterWidgetConnection::DIR_FROM_WIDGET); if (m_pDisplayConnection->getDirectionOption() & ControlParameterWidgetConnection::DIR_DEFAULT) { m_pDisplayConnection->setDirectionOption(ControlParameterWidgetConnection::DIR_TO_WIDGET); } } } } if (!m_rightConnections.isEmpty()) { ControlParameterWidgetConnection* rightConnection = m_rightConnections.at(0); bool rightClickForcePush = context.selectBool(node, "RightClickIsPushButton", false); m_rightButtonMode = ControlPushButton::PUSH; if (!rightClickForcePush) { const ConfigKey configKey = rightConnection->getKey(); ControlPushButton* p = dynamic_cast<ControlPushButton*>( ControlObject::getControl(configKey)); if (p) { m_rightButtonMode = p->getButtonMode(); if (m_rightButtonMode != ControlPushButton::PUSH) { qWarning() << "WPushButton::setup: Connecting a Pushbutton not in PUSH mode is not implemented\n" << "Please set <RightClickIsPushButton>true</RightClickIsPushButton>"; } } } if (rightConnection->getEmitOption() & ControlParameterWidgetConnection::EMIT_DEFAULT) { switch (m_rightButtonMode) { case ControlPushButton::PUSH: case ControlPushButton::LONGPRESSLATCHING: case ControlPushButton::POWERWINDOW: leftConnection->setEmitOption( ControlParameterWidgetConnection::EMIT_ON_PRESS_AND_RELEASE); break; default: leftConnection->setEmitOption( ControlParameterWidgetConnection::EMIT_ON_PRESS); break; } } if (rightConnection->getDirectionOption() & ControlParameterWidgetConnection::DIR_DEFAULT) { rightConnection->setDirectionOption(ControlParameterWidgetConnection::DIR_FROM_WIDGET); } } }