QGIS API Documentation  2.18.21-Las Palmas (9fba24a)
qgsclassificationwidgetwrapper.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgsclassificationwidgetwrapper.cpp
3  --------------------------------------
4  Date : 5.1.2014
5  Copyright : (C) 2014 Matthias Kuhn
6  Email : matthias at opengis dot ch
7  ***************************************************************************
8  * *
9  * This program is free software; you can redistribute it and/or modify *
10  * it under the terms of the GNU General Public License as published by *
11  * the Free Software Foundation; either version 2 of the License, or *
12  * (at your option) any later version. *
13  * *
14  ***************************************************************************/
15 
17 
19 #include "qgsvectorlayer.h"
20 
22  : QgsEditorWidgetWrapper( vl, fieldIdx, editor, parent )
23  , mComboBox( nullptr )
24 {
25 }
26 
28 {
29  return mComboBox->itemData( mComboBox->currentIndex() );
30 }
31 
33 {
34  whileBlocking( mComboBox )->setCurrentIndex( -1 );
35 }
36 
38 {
39  return new QComboBox( parent );
40 }
41 
43 {
44  mComboBox = qobject_cast<QComboBox*>( editor );
45 
46  if ( mComboBox )
47  {
48  const QgsCategorizedSymbolRendererV2 *csr = dynamic_cast<const QgsCategorizedSymbolRendererV2 *>( layer()->rendererV2() );
49  if ( csr )
50  {
51  const QgsCategoryList categories = csr->categories();
52  for ( int i = 0; i < categories.size(); i++ )
53  {
54  QString label = categories[i].label();
55  QString value = categories[i].value().toString();
56  if ( label.isEmpty() )
57  label = value;
58 
59  mComboBox->addItem( label, value );
60  }
61  }
62 
63  connect( mComboBox, SIGNAL( currentIndexChanged( int ) ), this, SLOT( valueChanged() ) );
64  }
65 }
66 
68 {
69  return mComboBox;
70 }
71 
73 {
74  mComboBox->setCurrentIndex( mComboBox->findData( value ) );
75 }
const QgsCategoryList & categories() const
void valueChanged()
Will call the value() method to determine the emitted value.
QWidget * createWidget(QWidget *parent) override
This method should create a new widget with the provided parent.
Manages an editor widget Widget and wrapper share the same parent.
QgsClassificationWidgetWrapper(QgsVectorLayer *vl, int fieldIdx, QWidget *editor=nullptr, QWidget *parent=nullptr)
QVariant value() const override
Will be used to access the widget&#39;s value.
int size() const
T value(int i) const
void initWidget(QWidget *editor) override
This method should initialize the editor widget with runtime data.
void addItem(const QString &text, const QVariant &userData)
void showIndeterminateState() override
Sets the widget to display in an indeterminate "mixed value" state.
QgsFeatureRendererV2 * rendererV2()
Return renderer V2.
bool isEmpty() const
bool valid() const override
Return true if the widget has been properly initialized.
QVariant itemData(int index, int role) const
QgsSignalBlocker< Object > whileBlocking(Object *object)
Temporarily blocks signals from a QObject while calling a single method from the object.
Definition: qgis.h:333
int findData(const QVariant &data, int role, QFlags< Qt::MatchFlag > flags) const
void setValue(const QVariant &value) override
QgsVectorLayer * layer() const
Access the QgsVectorLayer, you are working on.
bool connect(const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type)
QObject * parent() const
Represents a vector layer which manages a vector based data sets.