Control orientation of labels in NewLabelDialog.

This commit is contained in:
Jim Evins
2013-11-17 12:12:36 -05:00
parent 64a9076b18
commit d4541d396e
4 changed files with 69 additions and 43 deletions
+18
View File
@@ -55,6 +55,9 @@ namespace gLabels
connect( pageSizeOtherRadio, SIGNAL(toggled(bool)), this, SLOT(pageSizeRadioToggled(bool)) );
connect( templatePicker, SIGNAL(itemSelectionChanged()), this, SLOT(templatePickerSelectionChanged()) );
connect( orientationNormalRadio, SIGNAL(toggled(bool)), this, SLOT(orientationRadioToggled(bool)) );
connect( orientationRotatedRadio, SIGNAL(toggled(bool)), this, SLOT(orientationRadioToggled(bool)) );
}
@@ -81,6 +84,8 @@ namespace gLabels
void NewLabelDialog::templatePickerSelectionChanged()
{
orientationNormalRadio->setChecked( true );
QList<QListWidgetItem *> selectedItems = templatePicker->selectedItems();
if ( selectedItems.isEmpty() )
@@ -97,6 +102,7 @@ namespace gLabels
const libglabels::Frame *frame = tmplate->frames().first();
simplePreview->setTemplate( tmplate );
simplePreview->setRotate( false );
const libglabels::Vendor *vendor = libglabels::Db::lookupVendorFromName( tmplate->brand() );
if ( (vendor != NULL) && (vendor->url() != NULL) )
@@ -148,7 +154,19 @@ namespace gLabels
}
similarBrowser->setText( similarListString );
}
orientationGroupBox->setEnabled( frame->w() != frame->h() );
}
}
void NewLabelDialog::orientationRadioToggled( bool checked )
{
if ( checked )
{
simplePreview->setRotate( orientationRotatedRadio->isChecked() );
}
}
}
+1
View File
@@ -38,6 +38,7 @@ namespace gLabels
void searchEntryTextChanged( const QString &text );
void pageSizeRadioToggled( bool checked );
void templatePickerSelectionChanged();
void orientationRadioToggled( bool checked );
};
+13 -9
View File
@@ -39,10 +39,10 @@ namespace
const QColor labelOutlineColor( 128, 128, 255 );
const double labelOutlineWidthPixels = 2;
const QColor arrowColor( 224, 224, 255 );
const QColor arrowColor( 192, 192, 255, 128 );
const double arrowScale = 0.35;
const QColor upColor( 224, 224, 255 );
const QColor upColor( 192, 192, 255, 128 );
const double upScale = 0.15;
const QString upFontFamily( "Sans" );
}
@@ -166,8 +166,6 @@ namespace gLabels
double w = frame->w();
double h = frame->h();
if ( w != h )
{
double min = ( w < h ) ? w : h;
QPen pen( arrowColor );
@@ -191,22 +189,28 @@ namespace gLabels
QGraphicsPathItem *arrowItem = new QGraphicsPathItem( path );
arrowItem->setPen( pen );
arrowItem->setPos( x0+w/2, y0+h/2 );
if ( mRotateFlag )
{
arrowItem->setRotation( 90 );
}
QGraphicsSimpleTextItem *upItem = new QGraphicsSimpleTextItem( tr("Up") );
upItem->setBrush( brush );
upItem->setFont( QFont( upFontFamily, min*upScale, QFont::Bold ) );
upItem->setPos( x0+w/2, y0+h/2 );
QRectF rect = upItem->boundingRect();
upItem->setPos( x0+w/2-rect.width()/2, y0+h/2+min/8 );
if ( mRotateFlag )
{
arrowItem->setRotation( -90 );
upItem->setRotation( -90 );
upItem->setPos( upItem->x()-min/8, upItem->y()-rect.width()/2 );
upItem->setRotation( 90 );
}
else
{
upItem->setPos( upItem->x()-rect.width()/2, upItem->y()+min/8 );
}
mScene->addItem( arrowItem );
mScene->addItem( upItem );
}
}
}
+4 -1
View File
@@ -245,6 +245,9 @@
<property name="text">
<string notr="true">TextLabel</string>
</property>
<property name="wordWrap">
<bool>false</bool>
</property>
</widget>
</item>
<item row="3" column="0">
@@ -327,7 +330,7 @@
</layout>
</item>
<item>
<widget class="QGroupBox" name="groupBox_2">
<widget class="QGroupBox" name="orientationGroupBox">
<property name="sizePolicy">
<sizepolicy hsizetype="Preferred" vsizetype="Expanding">
<horstretch>0</horstretch>