Files
ThirdParty-6/ParaView-5.0.1/Plugins/PointSprite/Qvis/QvisSpectrumBar.h

174 lines
6.8 KiB
C++

/*****************************************************************************
*
* Copyright (c) 2000 - 2007, The Regents of the University of California
* Produced at the Lawrence Livermore National Laboratory
* All rights reserved.
*
* This file is part of VisIt. For details, see http://www.llnl.gov/visit/. The
* full copyright notice is contained in the file COPYRIGHT located at the root
* of the VisIt distribution or at http://www.llnl.gov/visit/copyright.html.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* - Redistributions of source code must retain the above copyright notice,
* this list of conditions and the disclaimer below.
* - Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the disclaimer (as noted below) in the
* documentation and/or materials provided with the distribution.
* - Neither the name of the UC/LLNL nor the names of its contributors may be
* used to endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OF THE UNIVERSITY OF
* CALIFORNIA, THE U.S. DEPARTMENT OF ENERGY OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*
*****************************************************************************/
#ifndef QVIS_SPECTRUM_BAR_H
#define QVIS_SPECTRUM_BAR_H
#include <qwidget.h>
#include "vtkQvisModule.h" // needed for export
// Forward declarations.
class ControlPointList;
class QPainter;
class QPixmap;
class QTimer;
// ****************************************************************************
// Class: QvisSpectrumBar
//
// Purpose:
// This class is the spectrum bar widget which is a widget used for editing
// color tables. The color table is composed of colored control points that
// can be moved to alter the appearance of the color table.
//
// Notes:
//
// Programmer: Brad Whitlock
// Creation: Wed Jan 3 09:58:26 PDT 2001
//
// Modifications:
// Brad Whitlock, Fri Sep 7 12:45:57 PDT 2001
// Added override of the paletteChange method.
//
// Brad Whitlock, Wed Mar 13 08:43:40 PDT 2002
// Added internal drawBox and drawArrow methods. Also consolidated the
// widget's pixmaps into a single pixmap so I can set it as the widget's
// background to reduce flicker.
//
// ****************************************************************************
class VTKQVIS_EXPORT QvisSpectrumBar : public QWidget
{
Q_OBJECT
public:
typedef enum {HorizontalTop,
HorizontalBottom,
VerticalLeft,
VerticalRight} ControlOrientation;
QvisSpectrumBar(QWidget *parent, const char *name = 0);
virtual ~QvisSpectrumBar();
virtual QSize sizeHint() const;
virtual QSizePolicy sizePolicy() const;
void addControlPoint(const QColor &color, float position = -1);
bool continuousUpdate() const;
QColor controlPointColor(int index) const;
float controlPointPosition(int index) const;
bool equalSpacing() const;
int numControlPoints() const;
int activeControlPoint() const;
bool suppressUpdates() const;
void setSuppressUpdates(bool val);
void setOrientation(ControlOrientation orient);
void setContinuousUpdate(bool val);
void setControlPointColor(int index, const QColor &color);
void setControlPointPosition(int index, float position);
bool smoothing() const;
unsigned char *getRawColors(int range);
void setRawColors(unsigned char *colors, int ncolors);
public slots:
void alignControlPoints();
void setEqualSpacing(bool val);
void setSmoothing(bool val);
void removeControlPoint();
void setEditMode(bool val);
signals:
void activeControlPointChanged(int index);
void selectColor(int index);
void selectColor(int index, const QPoint &pos);
void controlPointAdded(int index, const QColor &c, float position);
void controlPointColorChanged(int index, const QColor &c);
void controlPointMoved(int index, float position);
void controlPointRemoved(int index, const QColor &c, float position);
protected:
virtual void keyPressEvent(QKeyEvent *e);
virtual void keyReleaseEvent(QKeyEvent *e);
virtual void mousePressEvent(QMouseEvent *e);
virtual void mouseMoveEvent(QMouseEvent *e);
virtual void mouseReleaseEvent(QMouseEvent *e);
virtual void paintEvent(QPaintEvent *e);
virtual void resizeEvent(QResizeEvent *e);
virtual void paletteChange(const QPalette &);
QPoint controlPointLocation(int index) const;
void updateControlPoints();
void colorSelected(int index);
void deletePixmap();
void drawControls();
void drawControlPoint(QPainter *paint, const QBrush &top,
const QBrush &bottom, const QBrush &fore,
const QColor &sel, const QColor &cpt, int x, int y,
int w, int h, int shadow_thick,
ControlOrientation orient,
bool selected);
void drawBox(QPainter *paint, const QRect &r, const QColor &light,
const QColor &dark, int lw = 2);
void drawArrow(QPainter *p, bool down, int x, int y, int w, int h,
const QPalette &g);
void drawSpectrum();
void updateEntireWidget();
void moveControlPoint(int changeType);
void moveControlPointRedraw(int index, float pos, bool redrawSpectrum);
private slots:
void handlePaging();
private:
QPixmap *pixmap;
QTimer *timer;
ControlOrientation orientation;
int margin;
QRect spectrumArea;
QRect controlsArea;
QRect slider;
bool b_smoothing;
bool b_equalSpacing;
bool b_sliding;
bool b_continuousUpdate;
bool b_suppressUpdates;
int paging_mode;
bool shiftApplied;
ControlPointList *controlPoints;
};
#endif