Таблица стилей Qt в производном классе в пространстве имен C++ (селектор)

Я хочу использовать мою глобальную таблицу стилей qss с производным классом. Я понимаю, что мне нужно переопределить paintEvent (ссылку на таблицу стилей, или здесь).

void CustomWidget::paintEvent(QPaintEvent *) {
     QStyleOption opt;
     opt.init(this); // tried initFrom too, same result=>not working
     QPainter p(this);
     style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this);
 }

Однако, похоже, это не работает. С CDerived:QWidget и следующими строками таблиц стилей я сталкиваюсь:

CDerived { background-color: black; } // no effect
QWidget {  background-color: black; } // works

CDerived реализует paintEvent как указано выше. Что-нибудь еще мне нужно сделать?

-- Изменить/решение-

Благодаря подсказке JK я понял это. Мой приведенный выше пример на самом деле неправильно отражает мой сценарий. Мой реальный класс находится в пространстве имен C++ (моя ошибка, я пропустил это). Поэтому мне нужно написать MyNamespace--CDerived в qss. См. "Виджеты внутри пространств имен C++"

После того, как я попробовал здесь простой пример JK, я внезапно понял свою ошибку!

Правильный:

MyNamespace--CDerived { background-color: black; } // works, use -- for ::

Примечания: Связанный вопрос SO (a,b), но без ответа на этот конкретный вопрос. Мой производный класс находится в пространстве имен C++.


person Horst Walter    schedule 05.10.2014    source источник
comment
Не знаю, я ли это, но я не могу найти opt.init() здесь: qt-project.org/doc/qt-5/qstyleoption.html   -  person msrd0    schedule 06.10.2014
comment
Также см. пример использования таблиц стилей Qt здесь: qt-project.org/doc/ qt-5/stylesheet-examples.html   -  person msrd0    schedule 06.10.2014


Ответы (1)


Странно... у меня нормально работает:

без названия.pro:

#-------------------------------------------------
#
# Project created by QtCreator 2014-10-07T11:34:54
#
#-------------------------------------------------

QT       += core gui

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

TARGET = untitled
TEMPLATE = app


SOURCES += main.cpp\
        mainwindow.cpp \
    mywidget.cpp

HEADERS  += mainwindow.h \
    mywidget.h

FORMS    += mainwindow.ui

главное окно.ч:

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    explicit MainWindow(QWidget *parent = 0);
    ~MainWindow();

private:
    Ui::MainWindow *ui;
};

#endif // MAINWINDOW_H

главное окно.cpp:

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
}

MainWindow::~MainWindow()
{
    delete ui;
}

mainwindow.ui:

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>MainWindow</class>
 <widget class="QMainWindow" name="MainWindow">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>400</width>
    <height>300</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>MainWindow</string>
  </property>
  <property name="styleSheet">
   <string notr="true"/>
  </property>
  <widget class="QWidget" name="centralWidget">
   <widget class="MyWidget" name="widget" native="true">
    <property name="geometry">
     <rect>
      <x>70</x>
      <y>30</y>
      <width>201</width>
      <height>121</height>
     </rect>
    </property>
    <property name="styleSheet">
     <string notr="true"/>
    </property>
    <widget class="QPushButton" name="pushButton">
     <property name="geometry">
      <rect>
       <x>30</x>
       <y>20</y>
       <width>75</width>
       <height>23</height>
      </rect>
     </property>
     <property name="text">
      <string>PushButton</string>
     </property>
    </widget>
   </widget>
  </widget>
  <widget class="QMenuBar" name="menuBar">
   <property name="geometry">
    <rect>
     <x>0</x>
     <y>0</y>
     <width>400</width>
     <height>21</height>
    </rect>
   </property>
  </widget>
  <widget class="QToolBar" name="mainToolBar">
   <attribute name="toolBarArea">
    <enum>TopToolBarArea</enum>
   </attribute>
   <attribute name="toolBarBreak">
    <bool>false</bool>
   </attribute>
  </widget>
  <widget class="QStatusBar" name="statusBar"/>
 </widget>
 <layoutdefault spacing="6" margin="11"/>
 <customwidgets>
  <customwidget>
   <class>MyWidget</class>
   <extends>QWidget</extends>
   <header>mywidget.h</header>
   <container>1</container>
  </customwidget>
 </customwidgets>
 <resources/>
 <connections/>
</ui>

мой виджет.h:

#ifndef MYWIDGET_H
#define MYWIDGET_H

#include <QWidget>

class MyWidget : public QWidget
{
    Q_OBJECT
public:
    explicit MyWidget(QWidget *parent = 0);

protected:
    void paintEvent(QPaintEvent *e);

};

#endif // MYWIDGET_H

мой виджет.cpp:

#include "mywidget.h"

#include <QStyleOption>
#include <QPainter>

MyWidget::MyWidget(QWidget *parent) :
    QWidget(parent)
{
}

void MyWidget::paintEvent(QPaintEvent *e)
{
    Q_UNUSED(e)

    QStyleOption opt;
    opt.init(this); // tried initFrom too, same result=>not working
    QPainter p(this);
    style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this);
}

основной.cpp:

#include "mainwindow.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    a.setStyleSheet("MyWidget { background-color: red; }");

    MainWindow w;
    w.show();

    return a.exec();
}
person Jacob Krieg    schedule 07.10.2014
comment
Да странно, тестирую на Win 7, Qt 5.3. Тем не менее, вы можете сделать краткую перекрестную проверку. Если вы закомментируете функцию MyWidget::paintEvent(), удалит ли она красный цвет? Позже сегодня я протестирую и такой простой пример, хорошая идея. - person Horst Walter; 07.10.2014
comment
@HorstWalter Да, я пытался, если вы закомментируете событие paintEvent, красный цвет будет удален. - person Jacob Krieg; 07.10.2014
comment
Благодаря вашей тонкой подсказке я понял это. Это была проблема с пространством имен. Я пропустил, что а) мой класс находится в пространстве имен и б) :: должен быть заменен на --. - person Horst Walter; 07.10.2014