/** ****************************************************************************** * * @file mixercurvewidget.cpp * @author Edouard Lafargue Copyright (C) 2010. * @addtogroup GCSPlugins GCS Plugins * @{ * @addtogroup ConfigPlugin Config Plugin * @{ * @brief A widget which displays an adjustable mixer curve *****************************************************************************/ /* * This program 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. * * This program 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 this program; if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "mixercurvewidget.h" #include "mixercurveline.h" #include "mixercurvepoint.h" #include #include /* * Initialize the widget */ MixerCurveWidget::MixerCurveWidget(QWidget *parent) : QGraphicsView(parent) { // Create a layout, add a QGraphicsView and put the SVG inside. // The Mixer Curve widget looks like this: // |--------------------| // | | // | | // | Graph | // | | // | | // | | // |--------------------| setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff); setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff); setRenderHint(QPainter::Antialiasing); QGraphicsScene *scene = new QGraphicsScene(this); QSvgRenderer *renderer = new QSvgRenderer(); plot = new QGraphicsSvgItem(); renderer->load(QString(":/configgadget/images/curve-bg.svg")); plot->setSharedRenderer(renderer); //plot->setElementId("map"); scene->addItem(plot); plot->setZValue(-1); scene->setSceneRect(plot->boundingRect()); setScene(scene); } MixerCurveWidget::~MixerCurveWidget() { } /** Init curve: create a (flat) curve with a specified number of points. If a curve exists already, resets it. Points should be between 0 and 1. */ void MixerCurveWidget::initCurve(QList points) { if (points.length() < 2) return; // We need at least 2 points on a curve! // First of all, reset the list // TODO: one edge might not get deleted properly, small mem leak maybe... foreach (Node *node, nodeList ) { QList edges = node->edges(); foreach(Edge *edge, edges) { if (scene()->items().contains(edge)) scene()->removeItem(edge); else delete edge; } scene()->removeItem(node); delete node; } nodeList.clear(); // Create the nodes qreal w = plot->boundingRect().width()/(points.length()-1); qreal h = plot->boundingRect().height(); for (int i=0; iaddItem(node); nodeList.append(node); double val = points.at(i); if (val>1) val=1; if (val<0) val=0; node->setPos(w*i,h-val*h); node->verticalMove(true); } // ... and link them together: for (int i=0; i<(points.length()-1); i++) { scene()->addItem(new Edge(nodeList.at(i),nodeList.at(i+1))); } } /** Returns the current curve settings */ QList MixerCurveWidget::getCurve() { QList list; qreal h = plot->boundingRect().height(); foreach(Node *node, nodeList) { list.append((h-node->pos().y())/h); } return list; } void MixerCurveWidget::showEvent(QShowEvent *event) { Q_UNUSED(event) // Thit fitInView method should only be called now, once the // widget is shown, otherwise it cannot compute its values and // the result is usually a ahrsbargraph that is way too small. fitInView(plot, Qt::KeepAspectRatio); } void MixerCurveWidget::resizeEvent(QResizeEvent* event) { Q_UNUSED(event); fitInView(plot, Qt::KeepAspectRatio); } void MixerCurveWidget::itemMoved(double itemValue) { QList list = getCurve(); emit curveUpdated(list, itemValue); }