/* FrameCd.cpp * * Copyright (C) 2013-2016 Jim Evins * * This file is part of gLabels-qt. * * gLabels-qt is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * gLabels-qt is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with gLabels-qt. If not, see . */ #include "FrameCd.h" #include #include "StrUtil.h" #include "privateConstants.h" #include namespace libglabels { FrameCd::FrameCd( const Distance& r1, const Distance& r2, const Distance& w, const Distance& h, const Distance& waste, const QString& id ) : mR1(r1), mR2(r2), mW(w), mH(h), mWaste(waste), Frame(id) { Distance wReal = (mW == 0) ? 2*mR1 : mW; Distance hReal = (mH == 0) ? 2*mR1 : mH; /* * Construct outer subpath (may be clipped if it's a business card CD) */ QPainterPath outerPath; outerPath.addEllipse( (wReal/2 - r1).pt(), (hReal/2 - r1).pt(), 2*r1.pt(), 2*r1.pt() ); QPainterPath clipPath; clipPath.addRect( 0, 0, wReal.pt(), hReal.pt() ); mPath.addPath( outerPath & clipPath ); mPath.closeSubpath(); /* * Add inner subpath */ mPath.addEllipse( (wReal/2 - r2).pt(), (hReal/2 - r2).pt(), 2*r2.pt(), 2*r2.pt() ); } FrameCd::FrameCd( const FrameCd& other ) : mR1(other.mR1), mR2(other.mR2), mW(other.mW), mH(other.mH), mWaste(other.mWaste), mPath(other.mPath), Frame(other) { } Frame* FrameCd::dup() const { return new FrameCd( *this ); } Distance FrameCd::w() const { return (mW == 0) ? 2*mR1 : mW; } Distance FrameCd::h() const { return (mH == 0) ? 2*mR1 : mH; } const QString FrameCd::sizeDescription( Distance::Units units ) const { if ( units == Distance::Units::IN ) { QString dStr = StrUtil::formatFraction( 2 * mR1.in() ); return QString().sprintf( "%s %s %s", qPrintable(dStr), qPrintable(Distance::toTrName(units)), qPrintable(tr("diameter")) ); } else { return QString().sprintf( "%.5g %s %s", 2 * mR1.inUnits(units), qPrintable(Distance::toTrName(units)), qPrintable(tr("diameter")) ); } } bool FrameCd::isSimilarTo( Frame* other ) const { if ( FrameCd *otherCd = dynamic_cast(other) ) { if ( (fabs( mW - otherCd->mW ) <= Constants::EPSILON) && (fabs( mH - otherCd->mH ) <= Constants::EPSILON) && (fabs( mR1 - otherCd->mR1 ) <= Constants::EPSILON) && (fabs( mR2 - otherCd->mR2 ) <= Constants::EPSILON) ) { return true; } } return false; } const QPainterPath& FrameCd::path() const { return mPath; } QPainterPath FrameCd::marginPath( const Distance& size ) const { Distance wReal = (mW == 0) ? 2*mR1 : mW; Distance hReal = (mH == 0) ? 2*mR1 : mH; Distance r1 = mR1 - size; Distance r2 = mR2 + size; QPainterPath path; /* * Construct outer subpath (may be clipped if it's a business card CD) */ QPainterPath outerPath; outerPath.addEllipse( (wReal/2 - r1).pt(), (hReal/2 - r1).pt(), 2*r1.pt(), 2*r1.pt() ); QPainterPath clipPath; clipPath.addRect( size.pt(), size.pt(), (wReal-2*size).pt(), (hReal-2*size).pt() ); path.addPath( outerPath & clipPath ); path.closeSubpath(); /* * Add inner subpath */ path.addEllipse( (wReal/2 - r2).pt(), (hReal/2 - r2).pt(), 2*r2.pt(), 2*r2.pt() ); return path; } }