/******************************************************************* ** ** @file vpgraphicssheet.cpp ** @author Ronan Le Tiec ** @date 3 5, 2020 ** ** @brief ** @copyright ** This source code is part of the Valentina project, a pattern making ** program, whose allow create and modeling patterns of clothing. ** Copyright (C) 2020 Valentina project ** All Rights Reserved. ** ** Valentina 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. ** ** Valentina 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 Valentina. If not, see . ** *************************************************************************/ #include "vpgraphicssheet.h" #include "../layout/vplayout.h" #include "../layout/vpsheet.h" #include //--------------------------------------------------------------------------------------------------------------------- VPGraphicsSheet::VPGraphicsSheet(const VPLayoutPtr &layout, QGraphicsItem *parent): QGraphicsItem(parent), m_layout(layout), m_boundingRect(GetSheetRect()) {} //--------------------------------------------------------------------------------------------------------------------- void VPGraphicsSheet::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { Q_UNUSED(widget); Q_UNUSED(option); QPen pen(QColor(0,179,255), 1, Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin); pen.setCosmetic(true); QBrush noBrush(Qt::NoBrush); painter->setPen(pen); painter->setBrush(noBrush); QRectF sheetRect = GetSheetRect(); if(m_showMargin) { painter->drawRect(GetMarginsRect()); } if(m_showBorder) { pen.setColor(Qt::black); painter->setPen(pen); painter->drawRect(sheetRect); } VPLayoutPtr layout = m_layout.toStrongRef(); if(not layout.isNull() && layout->LayoutSettings().GetShowGrid()) { pen.setColor(QColor(204,204,204)); painter->setPen(pen); qreal colWidth = layout->LayoutSettings().GetGridColWidth(); if(colWidth > 0) { qreal colX = colWidth; while (colX < sheetRect.right()) { QLineF line = QLineF(colX, 0, colX, sheetRect.bottom()); painter->drawLine(line); colX += colWidth; } } qreal rowHeight = layout->LayoutSettings().GetGridRowHeight(); if(rowHeight > 0) { qreal rowY = rowHeight; while (rowY < sheetRect.bottom()) { QLineF line = QLineF(0, rowY, sheetRect.right(), rowY); painter->drawLine(line); rowY += rowHeight; } } } m_boundingRect = sheetRect; } //--------------------------------------------------------------------------------------------------------------------- auto VPGraphicsSheet::GetSheetRect() const -> QRectF { VPLayoutPtr layout = m_layout.toStrongRef(); if (layout.isNull()) { return {}; } VPSheetPtr sheet = layout->GetFocusedSheet(); if (sheet.isNull()) { return {}; } return sheet->GetSheetRect(); } //--------------------------------------------------------------------------------------------------------------------- auto VPGraphicsSheet::GetMarginsRect() const -> QRectF { VPLayoutPtr layout = m_layout.toStrongRef(); if (layout.isNull()) { return {}; } VPSheetPtr sheet = layout->GetFocusedSheet(); if (sheet.isNull()) { return {}; } return sheet->GetMarginsRect(); } //--------------------------------------------------------------------------------------------------------------------- void VPGraphicsSheet::SetShowMargin(bool value) { m_showMargin = value; } //--------------------------------------------------------------------------------------------------------------------- void VPGraphicsSheet::SetShowBorder(bool value) { m_showBorder = value; } //--------------------------------------------------------------------------------------------------------------------- auto VPGraphicsSheet::boundingRect() const -> QRectF { return m_boundingRect; }