123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- /*=========================================================================
- Library: CTK
-
- Copyright (c) 2010 Kitware Inc.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.commontk.org/LICENSE
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
-
- =========================================================================*/
- #ifndef __ctkTransferFunctionScene_h
- #define __ctkTransferFunctionScene_h
- /// Qt includes
- #include <QGraphicsScene>
- /// CTK includes
- #include "ctkPimpl.h"
- #include "ctkTransferFunction.h"
- #include "CTKWidgetsExport.h"
- //class ctkTransferFunction;
- class ctkTransferFunctionScenePrivate;
- //class ctkControlPoint;
- //class ctkPoint;
- //-----------------------------------------------------------------------------
- class CTK_WIDGETS_EXPORT ctkTransferFunctionScene: public QGraphicsScene
- {
- Q_OBJECT;
- public:
- ctkTransferFunctionScene(QObject* parent = 0);
- ctkTransferFunctionScene(ctkTransferFunction* transferFunction, QObject* parent = 0);
- virtual ~ctkTransferFunctionScene();
- void setTransferFunction(ctkTransferFunction* transferFunction);
- ctkTransferFunction* transferFunction()const;
- inline qreal posX(const ctkControlPoint* cp)const;
- inline qreal posY(const ctkControlPoint* cp)const;
- inline QColor color(const ctkControlPoint* cp) const;
- inline qreal posX(const ctkPoint& point)const;
- inline qreal posY(const ctkPoint& point)const;
- inline QColor color(const ctkPoint& point) const;
- qreal posX(const qreal& tfX)const;
- qreal posY(const QVariant& tfV)const;
- QColor color(const QVariant& tfV) const;
-
- QPointF mapPointToScreen(const ctkControlPoint* cp)const;
- QPointF mapPointToScreen(const ctkPoint& point)const;
-
- qreal mapXToScreen(qreal posX)const;
- qreal mapYToScreen(qreal posY)const;
- qreal mapXFromScreen(qreal screenPosX)const;
- qreal mapYFromScreen(qreal screenPosY)const;
- QList<ctkPoint> bezierParams(ctkControlPoint* start, ctkControlPoint* end) const;
- QList<ctkPoint> nonLinearPoints(ctkControlPoint* start, ctkControlPoint* end) const;
- const QPainterPath& curve()const;
- const QList<QPointF>& points()const;
- const QGradient& gradient()const;
- void computeCurve();
- void computeGradient();
- protected slots:
- virtual void onTransferFunctionChanged();
- protected:
- qreal computeRangeXDiff(const QRectF& rect, qreal rangeX[2]);
- qreal computeRangeXOffset(qreal rangeX[2]);
- qreal computeRangeYDiff(const QRectF& rect, const QVariant rangeY[2]);
- qreal computeRangeYOffset(const QVariant rangeY[2]);
- private:
- CTK_DECLARE_PRIVATE(ctkTransferFunctionScene);
- };
- qreal ctkTransferFunctionScene::posX(const ctkControlPoint* cp)const
- {
- return this->posX(cp->x());
- }
- qreal ctkTransferFunctionScene::posY(const ctkControlPoint* cp)const
- {
- return this->posY(cp->value());
- }
- QColor ctkTransferFunctionScene::color(const ctkControlPoint* cp) const
- {
- return this->color(cp->value());
- }
- qreal ctkTransferFunctionScene::posX(const ctkPoint& point)const
- {
- return this->posX(point.X);
- }
- qreal ctkTransferFunctionScene::posY(const ctkPoint& point)const
- {
- return this->posY(point.Value);
- }
- QColor ctkTransferFunctionScene::color(const ctkPoint& point) const
- {
- return this->color(point.Value);
- }
- #endif
|