/* FrameRect.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 "FrameRect.h" #include "Constants.h" #include "StrUtil.h" namespace glabels { FrameRect::FrameRect( const Distance& w, const Distance& h, const Distance& r, const Distance& xWaste, const Distance& yWaste, const QString& id ) : mW(w), mH(h), mR(r), mXWaste(xWaste), mYWaste(yWaste), Frame(id) { mPath.addRoundedRect( 0, 0, mW.pt(), mH.pt(), mR.pt(), mR.pt() ); mClipPath.addRoundedRect( -mXWaste.pt(), -mYWaste.pt(), mW.pt() + 2*mXWaste.pt(), mH.pt() + 2*mYWaste.pt(), mR.pt(), mR.pt() ); } FrameRect::FrameRect( const FrameRect &other ) : mW(other.mW), mH(other.mH), mR(other.mR), mXWaste(other.mXWaste), mYWaste(other.mYWaste), mPath(other.mPath), Frame(other) { // empty } Frame* FrameRect::dup() const { return new FrameRect( *this ); } Distance FrameRect::w() const { return mW; } Distance FrameRect::h() const { return mH; } Distance FrameRect::r() const { return mR; } Distance FrameRect::xWaste() const { return mXWaste; } Distance FrameRect::yWaste() const { return mYWaste; } QString FrameRect::sizeDescription( const Units& units ) const { if ( units.toEnum() == Units::IN ) { QString wStr = StrUtil::formatFraction( mW.in() ); QString hStr = StrUtil::formatFraction( mH.in() ); return QString().sprintf( "%s x %s %s", qPrintable(wStr), qPrintable(hStr), qPrintable(units.toTrName()) ); } else { return QString().sprintf( "%.5g x %.5g %s", mW.inUnits(units), mH.inUnits(units), qPrintable(units.toTrName()) ); } } bool FrameRect::isSimilarTo( Frame* other ) const { if ( FrameRect *otherRect = dynamic_cast(other) ) { if ( (fabs( mW - otherRect->mW ) <= EPSILON) && (fabs( mH - otherRect->mH ) <= EPSILON) ) { return true; } } return false; } const QPainterPath& FrameRect::path() const { return mPath; } const QPainterPath& FrameRect::clipPath() const { return mClipPath; } QPainterPath FrameRect::marginPath( const Distance& size ) const { Distance w = mW - 2*size; Distance h = mH - 2*size; Distance r = std::max( mR - size, Distance(0.0) ); QPainterPath path; path.addRoundedRect( size.pt(), size.pt(), w.pt(), h.pt(), r.pt(), r.pt() ); return path; } }