Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
39 commits
Select commit Hold shift + click to select a range
ecb258f
First version of artwork tabs for the InstrumentTrackWindow.
Feb 12, 2016
91872f1
Second version of artwork tabs for the InstrumentTrackWindow.
Feb 16, 2016
e2e8369
Created artwork for the artwork tabs.
Feb 18, 2016
5dcc169
1st PoC for autosizeable artwork tabs.
Feb 21, 2016
46f1ef7
TabWidget is 20 pixels tall when it's going to display artwork tabs.
Feb 21, 2016
f91c3a7
Added tooltip support for the TabWidget class.
Feb 22, 2016
8790021
Imported artworks from RebeccaDeField
Feb 22, 2016
ccc1c55
Reverted to 12px tall TabWidget
Feb 22, 2016
a280816
Fine tuning for the positioning of artwork tabs: Take into account th…
Feb 22, 2016
21a1dfd
New artwork for the ENV/LFO tab (has now an ADSR-based look)
Feb 25, 2016
2b1923b
1) Tabs in TabWidget class have now a "tooltip" attribute. So that th…
Feb 25, 2016
9e1de4d
Fine tuning the positioning of highlighted artwork tabs.
Feb 25, 2016
71761f2
Fixed an issue in TabWidget's artwork tabs autosize function that mak…
Feb 25, 2016
e309f22
TabWidget is 17 pixels tall when it's going to display artwork tabs.
Feb 26, 2016
a9de81d
Removed underscore prefix for function parameters as coding conventio…
Apr 27, 2016
81a3fe0
Removed background gradient for TabWidget as LMMS is going to a more …
Apr 27, 2016
483f03f
Increased the graphical TabWidget's height by 2 pixels for eye-candy.
Apr 29, 2016
b4e2a4b
Removed gradient in GrouBox widgets as LMMS is going for a more flatt…
Apr 29, 2016
c52033c
Made the background of TabWidget themeable
May 12, 2016
2651622
The highlighting color for a TabWidget'selected tab is now themeable.
May 12, 2016
fd9e38b
Made TabWidget's Title text and tab text themeable.
May 13, 2016
eb97167
Added a darker background to the TabWidget's tab bar.
May 13, 2016
ad795d0
Further flatened the design of TabWidget
May 13, 2016
757d4c0
Flatened the design of the GroupBox widget
May 13, 2016
ef392b2
Fine tuning the placement of TabWidgets' highlighting background
May 19, 2016
70c8eda
Made the TabWidget's title background and borders themeable
May 19, 2016
ab66556
TabWidget - Artwork tabs: Do not change the icon color when it is hig…
May 19, 2016
9f4df3f
TabWidget: Made the artworks' color themeable
May 20, 2016
b16a087
Adapted format to follow LMMS coding conventions
Jul 15, 2016
b75c89d
Some more blank spaces to tabs translation to comply with LMMS coding…
Jul 27, 2016
1d57917
Some more blank spaces to tabs translation to comply with LMMS coding…
Aug 2, 2016
d280afa
Revert "TabWidget: Made the artworks' color themeable"
Sep 5, 2016
9b34722
Made GroupBox's background color themeable
Sep 5, 2016
f9f60d4
Update background color, only use one set of images
Umcaruje May 21, 2017
217a39b
Use name as tooltip, more descriptive names
Umcaruje May 21, 2017
cbf14df
Update icons and colors
Umcaruje May 21, 2017
b3b2586
more things
Umcaruje May 24, 2017
6aa15a4
formatting fixes
Umcaruje May 30, 2017
8706d52
Remove update() from constructor
Umcaruje May 31, 2017
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added data/themes/default/env_lfo_tab.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added data/themes/default/func_tab.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added data/themes/default/fx_tab.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added data/themes/default/midi_tab.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added data/themes/default/misc_tab.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added data/themes/default/plugin_tab.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
13 changes: 13 additions & 0 deletions data/themes/default/style.css
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,19 @@ PianoRoll {
qproperty-textShadow: #fff;
}

TabWidget {
background-color: #262b30;
qproperty-tabText: rgba(255, 255, 255, 180);
qproperty-tabTitleText: #fff;
qproperty-tabSelected: #323940;
qproperty-tabBackground: #181b1f;
qproperty-tabBorder: #181b1f;
}

GroupBox {
background-color: #262b30;
}

/* main toolbar oscilloscope - can have transparent bg now */

VisualizationWidget {
Expand Down
2 changes: 1 addition & 1 deletion include/GroupBox.h
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ class GroupBox : public QWidget, public BoolModelView

protected:
virtual void mousePressEvent( QMouseEvent * _me );
virtual void resizeEvent( QResizeEvent * _re );
virtual void paintEvent( QPaintEvent * _pe );


private:
Expand Down
50 changes: 41 additions & 9 deletions include/TabWidget.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,25 +29,47 @@
#include <QWidget>
#include <QtCore/QMap>

const int TEXT_TAB_HEIGHT = 14;
const int GRAPHIC_TAB_HEIGHT = 17;

class TabWidget : public QWidget
{
Q_OBJECT
public:
TabWidget( const QString & _caption, QWidget * _parent );
TabWidget( const QString & _caption, QWidget * _parent, bool usePixmap = false );
virtual ~TabWidget();

void addTab( QWidget * _w, const QString & _name, int _idx = -1 );
void addTab( QWidget * w, const QString & name, const char *pixmap = NULL, int idx = -1 );

void setActiveTab( int _idx );
void setActiveTab( int idx );

int findTabAtPos( const QPoint *pos );

inline int activeTab() const
{
return( m_activeTab );
}

// Themeability
Q_PROPERTY( QColor tabText READ tabText WRITE setTabText)
Q_PROPERTY( QColor tabTitleText READ tabTitleText WRITE setTabTitleText)
Q_PROPERTY( QColor tabSelected READ tabSelected WRITE setTabSelected)
Q_PROPERTY( QColor tabBackground READ tabBackground WRITE setTabBackground)
Q_PROPERTY( QColor tabBorder READ tabBorder WRITE setTabBorder)

QColor tabText() const;
void setTabText( const QColor & c );
QColor tabTitleText() const;
void setTabTitleText( const QColor & c );
QColor tabSelected() const;
void setTabSelected( const QColor & c );
QColor tabBackground() const;
void setTabBackground( const QColor & c );
QColor tabBorder() const;
void setTabBorder( const QColor & c );

protected:
virtual bool event( QEvent * event );
virtual void mousePressEvent( QMouseEvent * _me );
virtual void paintEvent( QPaintEvent * _pe );
virtual void resizeEvent( QResizeEvent * _re );
Expand All @@ -57,16 +79,26 @@ class TabWidget : public QWidget
private:
struct widgetDesc
{
QWidget * w; // ptr to widget
QString name; // name for widget
int nwidth; // width of name when painting
QWidget * w; // ptr to widget
const char * pixmap; // artwork for the widget
QString name; // name for widget
int nwidth; // width of name when painting (only valid for text tab)
} ;
typedef QMap<int, widgetDesc> widgetStack;

widgetStack m_widgets;
int m_activeTab;
QString m_caption;
quint8 m_tabheight;

int m_activeTab;
QString m_caption; // Tab caption, used as the tooltip text on icon tabs
quint8 m_tabbarHeight; // The height of the tab bar
quint8 m_tabheight; // The height of the tabs
bool m_usePixmap; // true if the tabs are to be displayed with icons. False for text tabs.

QColor m_tabText; // The color of the tabs' text.
QColor m_tabTitleText; // The color of the TabWidget's title text.
QColor m_tabSelected; // The highlighting color for the selected tab.
QColor m_tabBackground; // The TabWidget's background color.
QColor m_tabBorder; // The TabWidget's borders color.
} ;

#endif
2 changes: 1 addition & 1 deletion src/gui/widgets/EffectRackView.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ EffectRackView::EffectRackView( EffectChain* model, QWidget* parent ) :
ModelView( NULL, this )
{
QVBoxLayout* mainLayout = new QVBoxLayout( this );
mainLayout->setMargin( 0 );
mainLayout->setMargin( 5 );

m_effectsGroupBox = new GroupBox( tr( "EFFECTS CHAIN" ) );
mainLayout->addWidget( m_effectsGroupBox );
Expand Down
54 changes: 7 additions & 47 deletions src/gui/widgets/GroupBox.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,6 @@ GroupBox::GroupBox( const QString & _caption, QWidget * _parent ) :
m_caption( _caption ),
m_titleBarHeight( 11 )
{
updatePixmap();

m_led = new PixmapButton( this, _caption );
m_led->setCheckable( true );
m_led->move( 3, 0 );
Expand Down Expand Up @@ -84,60 +82,22 @@ void GroupBox::mousePressEvent( QMouseEvent * _me )



void GroupBox::resizeEvent( QResizeEvent * _ev )
void GroupBox::paintEvent( QPaintEvent * pe )
{
updatePixmap();
QWidget::resizeEvent( _ev );
}

QPainter p( this );


void GroupBox::updatePixmap()
{
QColor bg_color = QApplication::palette().color( QPalette::Active,
QPalette::Background );
QPixmap pm( size() );
pm.fill( bg_color/*.dark( 132 )*/ );

QPainter p( &pm );
// Draw background
p.fillRect( 0, 0, width() - 1, height() - 1, p.background() );

// outer rect
p.setPen( bg_color.dark( 150 ) );
p.setPen( p.background().color().dark( 150 ) );
p.drawRect( 0, 0, width() - 1, height() - 1 );

// brighter line at bottom/right
p.setPen( bg_color.light( 150 ) );
p.drawLine( width() - 1, 0, width() - 1, height() - 1 );
p.drawLine( 0, height() - 1, width() - 1, height() - 1 );

// draw groupbox-titlebar
QLinearGradient g( 0, 0, 0, m_titleBarHeight );
g.setColorAt( 0, bg_color.darker( 250 ) );
g.setColorAt( 0.1, bg_color.lighter( 120 ) );
g.setColorAt( 1, bg_color.darker( 250 ) );
p.fillRect( 2, 2, width() - 4, m_titleBarHeight, g );

// draw line below titlebar
p.setPen( bg_color.dark( 400 ) );
p.drawLine( 1, m_titleBarHeight + 1, width() - 3, m_titleBarHeight + 1 );

// black inner rect
p.drawRect( 1, 1, width() - 3, height() - 3 );
p.fillRect( 1, 1, width() - 2, m_titleBarHeight + 1, p.background().color().darker( 150 ) );


//p.setPen( QColor( 255, 255, 255 ) );
// draw text
p.setPen( palette().color( QPalette::Active, QPalette::Text ) );
p.setFont( pointSize<8>( font() ) );
p.drawText( 22, m_titleBarHeight, m_caption );

QPalette pal = palette();
pal.setBrush( backgroundRole(), QBrush( pm ) );
setPalette( pal );
}







3 changes: 2 additions & 1 deletion src/gui/widgets/InstrumentSoundShapingView.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,8 @@ InstrumentSoundShapingView::InstrumentSoundShapingView( QWidget * _parent ) :
{
m_envLfoViews[i] = new EnvelopeAndLfoView( m_targetsTabWidget );
m_targetsTabWidget->addTab( m_envLfoViews[i],
tr( InstrumentSoundShaping::targetNames[i][0].toUtf8().constData() ) );
tr( InstrumentSoundShaping::targetNames[i][0].toUtf8().constData() ),
NULL );
}


Expand Down
Loading