Skip to content

Commit

Permalink
Update collapsible groupbox with checkbox and styles
Browse files Browse the repository at this point in the history
  • Loading branch information
dakcarto committed Sep 11, 2012
1 parent 73ca04e commit 950f6a9
Show file tree
Hide file tree
Showing 6 changed files with 145 additions and 92 deletions.
2 changes: 2 additions & 0 deletions images/images.qrc
Expand Up @@ -169,10 +169,12 @@
<file>themes/default/mActionZoomToLayer.png</file>
<file>themes/default/mActionZoomToSelected.png</file>
<file>themes/default/mIconClose.png</file>
<file>themes/default/mIconCollapse.png</file>
<file>themes/default/mIconConnect.png</file>
<file>themes/default/mIconDbSchema.png</file>
<file>themes/default/mIconDelete.png</file>
<file>themes/default/mIconEditable.png</file>
<file>themes/default/mIconExpand.png</file>
<file>themes/default/mIconFavourites.png</file>
<file>themes/default/mIconFirst.png</file>
<file>themes/default/mIconGeometryLayer.png</file>
Expand Down
Binary file added images/themes/default/mIconCollapse.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added images/themes/default/mIconExpand.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
98 changes: 51 additions & 47 deletions src/gui/qgscollapsiblegroupbox.cpp
Expand Up @@ -20,33 +20,10 @@
#include "qgsapplication.h"
#include "qgslogger.h"

#include <QStyleOptionGroupBox>
#include <QStylePainter>
#include <QToolButton>
#include <QLayout>
#include <QProxyStyle>
#include <QStyle>

class QgsCollapsibleGroupBoxStyle : public QProxyStyle
{
public:
QgsCollapsibleGroupBoxStyle( QStyle * style = 0 ) : QProxyStyle( style ) {}

void drawPrimitive( PrimitiveElement element, const QStyleOption *option,
QPainter *painter, const QWidget *widget ) const
{
if ( element == PE_IndicatorCheckBox )
{
const QgsCollapsibleGroupBox* groupBox =
dynamic_cast<const QgsCollapsibleGroupBox*>( widget );
if ( groupBox )
{
return drawPrimitive( groupBox->isCollapsed() ?
PE_IndicatorArrowRight : PE_IndicatorArrowDown,
option, painter, widget );
}
}
return QProxyStyle::drawPrimitive( element, option, painter, widget );
}
};

QgsCollapsibleGroupBox::QgsCollapsibleGroupBox( QWidget *parent )
: QGroupBox( parent ), mCollapsed( false )
Expand All @@ -63,16 +40,54 @@ QgsCollapsibleGroupBox::QgsCollapsibleGroupBox( const QString &title,

void QgsCollapsibleGroupBox::init()
{
setStyle( new QgsCollapsibleGroupBoxStyle( QApplication::style() ) );
connect( this, SIGNAL( toggled( bool ) ), this, SLOT( setToggled( bool ) ) );

connect( this, SIGNAL( toggled( bool ) ), this, SLOT( checkboxToggled() ) );

QString ss;
ss += "QGroupBox {";
ss += " margin-top: 28px;"; // fix for non-checkbox-groupbox spacing
ss += "}";
ss += "QGroupBox::title {";
ss += " subcontrol-origin: margin;";
ss += " subcontrol-position: top left;";
ss += " margin-left: 24px;"; // offset for disclosure triangle
ss += " margin-top: 10px;"; // offset to match extra top margin
ss += "}";
setStyleSheet( ss );

mDisclosure = new QToolButton( this );
mDisclosureName = QString( "grpboxDisclosure" );
mDisclosure->setObjectName( mDisclosureName );
mDisclosure->setFixedSize( 16, 16 );
mDisclosure->move( 0, 10 ); // match title offset
mDisclosure->setIconSize( QSize( 16, 16 ) );

// get rid of toolbutton background
QString ssd;
ssd += QString( "QToolButton#%1 {" ).arg( mDisclosureName );
ssd += " background-color: rgba(255, 255, 255, 0);";
ssd += "}";
mDisclosure->setStyleSheet( ssd );

connect( mDisclosure, SIGNAL( clicked() ), this, SLOT( toggleCollapsed() ) );
}


void QgsCollapsibleGroupBox::showEvent( QShowEvent * event )
{
QGroupBox::showEvent( event );
// collapse if needed - any calls to setCollapsed() before have no effect
if ( isCheckable() && ! isChecked() && ! isCollapsed() )
setCollapsed( true );
setCollapsed( true );
}

void QgsCollapsibleGroupBox::checkboxToggled()
{
mDisclosure->setEnabled( true ); // always keep enabled
}

void QgsCollapsibleGroupBox::toggleCollapsed()
{
setCollapsed( !mCollapsed );
}

void QgsCollapsibleGroupBox::setCollapsed( bool collapse )
Expand All @@ -82,41 +97,30 @@ void QgsCollapsibleGroupBox::setCollapsed( bool collapse )

mCollapsed = collapse;

// minimize layout margins and save for subsequent restore
if ( collapse )
{
if ( layout() )
{
mMargins = layout()->contentsMargins();
layout()->setContentsMargins( 1, 1, 1, 1 );
}
}
else
{
if ( layout() )
{
layout()->setContentsMargins( mMargins );
}
}
setFlat( collapse );
setMaximumHeight( collapse ? 36 : 16777215 );

// if we are collapsing, save hidden widgets in a list
if ( collapse )
{
mDisclosure->setIcon( QgsApplication::getThemeIcon( "/mIconExpand.png" ) );
mHiddenWidgets.clear();
foreach ( QWidget *widget, findChildren<QWidget*>() )
{
if ( widget->isHidden() )
if ( widget->isHidden() && widget->objectName() != mDisclosureName )
mHiddenWidgets << widget;
}
}

// show/hide widgets
foreach ( QWidget *widget, findChildren<QWidget*>() )
widget->setHidden( collapse );
if ( widget->objectName() != mDisclosureName )
widget->setHidden( collapse );

// if we are expanding, re-hide saved hidden widgets
if ( ! collapse )
{
mDisclosure->setIcon( QgsApplication::getThemeIcon( "/mIconCollapse.png" ) );
foreach ( QWidget *widget, mHiddenWidgets )
{
widget->setHidden( true );
Expand Down
7 changes: 6 additions & 1 deletion src/gui/qgscollapsiblegroupbox.h
Expand Up @@ -27,6 +27,8 @@

#include <QGroupBox>

class QToolButton;

class GUI_EXPORT QgsCollapsibleGroupBox : public QGroupBox
{
Q_OBJECT
Expand All @@ -42,7 +44,8 @@ class GUI_EXPORT QgsCollapsibleGroupBox : public QGroupBox
void expanded( QWidget* );

public slots:
void setToggled( bool toggled ) { setCollapsed( ! toggled ); }
void checkboxToggled();
void toggleCollapsed();
void setCollapsed( bool collapse );

protected:
Expand All @@ -53,6 +56,8 @@ class GUI_EXPORT QgsCollapsibleGroupBox : public QGroupBox
bool mCollapsed;
QMargins mMargins;
QList< QWidget* > mHiddenWidgets;
QToolButton* mDisclosure;
QString mDisclosureName;
};

#endif

0 comments on commit 950f6a9

Please sign in to comment.