summaryrefslogtreecommitdiffstats
path: root/src/legend/legendmarkeritem.cpp
diff options
context:
space:
mode:
authorTitta Heikkala <titta.heikkala@digia.com>2014-07-01 07:10:00 +0300
committerTitta Heikkala <titta.heikkala@theqtcompany.com>2014-10-14 13:04:52 +0300
commitc544258484ff4fd5d2b88402fbaa5d154b89a3a2 (patch)
tree7659625abb566dec55d3783ed820b928542d9b2b /src/legend/legendmarkeritem.cpp
parent76339f714f088645e911cee65bdb66055fe029aa (diff)
Qt Charts project file structure change
Charts repository structure is changed to follow the structure of a Qt Add-On module. The task includes following changes: - All macros and definitions named 'commercial' have been renamed. - Compile errors related to QString and qSort usage have been fixed. - Old demos are moved under examples. The QML examples now support only Qt Quick 2.0, the support for Qt Quick 1 is removed. - The QML examples with multiple views are updated so that they are usable also with touch devices. - Unnecessary version checks are removed from examples. - The build stamp has been removed as it was only meant for Charts development purposes and it's no longer needed. Also development build related debug prints are removed as __DATE__ can't be used for all OS thus it doesn't make much sense. - Documentation structure has been updated based on the new module structure. The raw HTML files have been removed. Demos are combined to examples. - Unnecessary .qdocinc files are no longer needed. The content is moved to the corresponding .cpp files. - The Charts widget designer plugin is updated according to the module change. - The test cases updated according to the project structure change. Tests are added also for version 2.0. - cmake modules generation is not needed with Qt 5.4 and Qt Charts so it's disabled. - The new module name and version are updated to the plugin.qmltypes file. Task-number: QTRD-2844, QTRD-3217, QTRD-3218, QTRD-3277, QTRD-3228, QTRD-2526, QTRD-3233, QTRD-3222 Change-Id: Ib7fb26057cde710ffaf6bc780c8bf52a16f45160 Reviewed-by: Miikka Heikkinen <miikka.heikkinen@theqtcompany.com>
Diffstat (limited to 'src/legend/legendmarkeritem.cpp')
-rw-r--r--src/legend/legendmarkeritem.cpp191
1 files changed, 0 insertions, 191 deletions
diff --git a/src/legend/legendmarkeritem.cpp b/src/legend/legendmarkeritem.cpp
deleted file mode 100644
index 6fa53417..00000000
--- a/src/legend/legendmarkeritem.cpp
+++ /dev/null
@@ -1,191 +0,0 @@
-/****************************************************************************
- **
- ** Copyright (C) 2014 Digia Plc
- ** All rights reserved.
- ** For any questions to Digia, please use contact form at http://qt.digia.com
- **
- ** This file is part of the Qt Enterprise Charts Add-on.
- **
- ** $QT_BEGIN_LICENSE$
- ** Licensees holding valid Qt Enterprise licenses may use this file in
- ** accordance with the Qt Enterprise License Agreement provided with the
- ** Software or, alternatively, in accordance with the terms contained in
- ** a written agreement between you and Digia.
- **
- ** If you have questions regarding the use of this file, please use
- ** contact form at http://qt.digia.com
- ** $QT_END_LICENSE$
- **
- ****************************************************************************/
-
-#include <QPainter>
-#include <QGraphicsSceneEvent>
-#include <QGraphicsTextItem>
-#include <QTextDocument>
-
-#include "qlegend.h"
-#include "qlegend_p.h"
-#include "qlegendmarker.h"
-#include "qlegendmarker_p.h"
-#include "legendmarkeritem_p.h"
-#include "chartpresenter_p.h"
-
-QTCOMMERCIALCHART_BEGIN_NAMESPACE
-
-LegendMarkerItem::LegendMarkerItem(QLegendMarkerPrivate *marker, QGraphicsObject *parent) :
- QGraphicsObject(parent),
- m_marker(marker),
- m_markerRect(0,0,10.0,10.0),
- m_boundingRect(0,0,0,0),
- m_textItem(new QGraphicsTextItem(this)),
- m_rectItem(new QGraphicsRectItem(this)),
- m_margin(3),
- m_space(4),
- m_hovering(false),
- m_pressPos(0, 0)
-{
- m_rectItem->setRect(m_markerRect);
- m_textItem->document()->setDocumentMargin(ChartPresenter::textMargin());
- setAcceptHoverEvents(true);
-}
-
-LegendMarkerItem::~LegendMarkerItem()
-{
- if (m_hovering) {
- emit m_marker->q_ptr->hovered(false);
- }
-}
-
-void LegendMarkerItem::setPen(const QPen &pen)
-{
- m_rectItem->setPen(pen);
-}
-
-QPen LegendMarkerItem::pen() const
-{
- return m_rectItem->pen();
-}
-
-void LegendMarkerItem::setBrush(const QBrush &brush)
-{
- m_rectItem->setBrush(brush);
-}
-
-QBrush LegendMarkerItem::brush() const
-{
- return m_rectItem->brush();
-}
-
-void LegendMarkerItem::setFont(const QFont &font)
-{
- m_textItem->setFont(font);
- QFontMetrics fn(font);
- m_markerRect = QRectF(0,0,fn.height()/2,fn.height()/2);
- updateGeometry();
-}
-
-QFont LegendMarkerItem::font() const
-{
- return m_textItem->font();
-}
-
-void LegendMarkerItem::setLabel(const QString label)
-{
- m_label = label;
- updateGeometry();
-}
-
-QString LegendMarkerItem::label() const
-{
- return m_label;
-}
-
-void LegendMarkerItem::setLabelBrush(const QBrush &brush)
-{
- m_textItem->setDefaultTextColor(brush.color());
-}
-
-QBrush LegendMarkerItem::labelBrush() const
-{
- return QBrush(m_textItem->defaultTextColor());
-}
-
-void LegendMarkerItem::setGeometry(const QRectF &rect)
-{
- qreal width = rect.width();
- qreal x = m_margin + m_markerRect.width() + m_space + m_margin;
- QRectF truncatedRect;
-
- m_textItem->setHtml(ChartPresenter::truncatedText(m_textItem->font(), m_label, qreal(0.0),
- width - x, rect.height(), truncatedRect));
- m_textItem->setTextWidth(truncatedRect.width());
-
- qreal y = qMax(m_markerRect.height() + 2 * m_margin, truncatedRect.height() + 2 * m_margin);
-
- const QRectF &textRect = m_textItem->boundingRect();
-
- m_textItem->setPos(x - m_margin, y / 2 - textRect.height() / 2);
- m_rectItem->setRect(m_markerRect);
- // The textMargin adjustments to position are done to make default case rects less blurry with anti-aliasing
- m_rectItem->setPos(m_margin - ChartPresenter::textMargin(), y / 2.0 - m_markerRect.height() / 2.0 + ChartPresenter::textMargin());
-
- prepareGeometryChange();
- m_boundingRect = QRectF(0, 0, x + textRect.width() + m_margin, y);
-}
-
-QRectF LegendMarkerItem::boundingRect() const
-{
- return m_boundingRect;
-}
-
-void LegendMarkerItem::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget)
-{
- Q_UNUSED(option)
- Q_UNUSED(widget)
- Q_UNUSED(painter)
-}
-
-QSizeF LegendMarkerItem::sizeHint(Qt::SizeHint which, const QSizeF& constraint) const
-{
- Q_UNUSED(constraint)
-
- QSizeF sh;
-
- switch (which) {
- case Qt::MinimumSize: {
- QRectF labelRect = ChartPresenter::textBoundingRect(m_textItem->font(), "...");
- sh = QSizeF(labelRect.width() + (2.0 * m_margin) + m_space + m_markerRect.width(),
- qMax(m_markerRect.height(), labelRect.height()) + (2.0 * m_margin));
- break;
- }
- case Qt::PreferredSize: {
- QRectF labelRect = ChartPresenter::textBoundingRect(m_textItem->font(), m_label);
- sh = QSizeF(labelRect.width() + (2.0 * m_margin) + m_space + m_markerRect.width(),
- qMax(m_markerRect.height(), labelRect.height()) + (2.0 * m_margin));
- break;
- }
- default:
- break;
- }
-
- return sh;
-}
-
-void LegendMarkerItem::hoverEnterEvent(QGraphicsSceneHoverEvent *event)
-{
- Q_UNUSED(event)
- m_hovering = true;
- emit m_marker->q_ptr->hovered(true);
-}
-
-void LegendMarkerItem::hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
-{
- Q_UNUSED(event)
- m_hovering = false;
- emit m_marker->q_ptr->hovered(false);
-}
-
-
-#include "moc_legendmarkeritem_p.cpp"
-
-QTCOMMERCIALCHART_END_NAMESPACE