// -*- Mode: c++; c-basic-offset: 4; indent-tabs-mode: nil; tab-width: 4; -*- /* This file is part of the KDE project Copyright (C) 1998, 1999 Reginald Stadlbauer <reggie@kde.org> This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library 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 Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. */ #include "KPrGradient.h" #include <tqpainter.h> #include <kpixmapeffect.h> #include <kdebug.h> #include <KoTextZoomHandler.h> KPrGradient::KPrGradient( const TQColor &_color1, const TQColor &_color2, BCType _bcType, bool _unbalanced, int _xfactor, int _yfactor ) : color1( _color1 ), color2( _color2 ), bcType( _bcType ), m_pixmap(), refCount( 0 ), xFactor( _xfactor ), yFactor( _yfactor ), unbalanced( _unbalanced ), m_bDirty( true ) { //m_pixmap.resize( _size ); } void KPrGradient::setParameters(const TQColor &c1, const TQColor &c2, BCType _type, bool _unbalanced, int xf, int yf) { color1=c1; color2=c2; bcType=_type; unbalanced=_unbalanced; xFactor=xf; yFactor=yf; m_bDirty = true; } void KPrGradient::addRef() { ++refCount; } bool KPrGradient::removeRef() { return ( --refCount == 0 ); } void KPrGradient::paint() { TQPainter painter; switch ( bcType ) { case BCT_PLAIN: painter.begin( &m_pixmap ); painter.setPen( TQt::NoPen ); painter.setBrush( color1 ); painter.drawRect( m_pixmap.rect() ); painter.end(); break; case BCT_GHORZ: { if ( !unbalanced ) KPixmapEffect::gradient( m_pixmap, color1, color2, KPixmapEffect::VerticalGradient ); else KPixmapEffect::unbalancedGradient( m_pixmap, color1, color2, KPixmapEffect::VerticalGradient, xFactor, yFactor ); } break; case BCT_GVERT: { if ( !unbalanced ) KPixmapEffect::gradient( m_pixmap, color1, color2, KPixmapEffect::HorizontalGradient ); else KPixmapEffect::unbalancedGradient( m_pixmap, color1, color2, KPixmapEffect::HorizontalGradient, xFactor, yFactor ); } break; case BCT_GDIAGONAL1: { if ( !unbalanced ) KPixmapEffect::gradient( m_pixmap, color1, color2, KPixmapEffect::DiagonalGradient ); else KPixmapEffect::unbalancedGradient( m_pixmap, color1, color2, KPixmapEffect::DiagonalGradient, xFactor, yFactor ); } break; case BCT_GDIAGONAL2: { if ( !unbalanced ) KPixmapEffect::gradient( m_pixmap, color1, color2, KPixmapEffect::CrossDiagonalGradient ); else KPixmapEffect::unbalancedGradient( m_pixmap, color1, color2, KPixmapEffect::CrossDiagonalGradient, xFactor, yFactor ); } break; case BCT_GCIRCLE: { if ( !unbalanced ) KPixmapEffect::gradient( m_pixmap, color1, color2, KPixmapEffect::EllipticGradient ); else KPixmapEffect::unbalancedGradient( m_pixmap, color1, color2, KPixmapEffect::EllipticGradient, xFactor, yFactor ); } break; case BCT_GRECT: { if ( !unbalanced ) KPixmapEffect::gradient( m_pixmap, color1, color2, KPixmapEffect::RectangleGradient ); else KPixmapEffect::unbalancedGradient( m_pixmap, color1, color2, KPixmapEffect::RectangleGradient, xFactor, yFactor ); } break; case BCT_GPIPECROSS: { if ( !unbalanced ) KPixmapEffect::gradient( m_pixmap, color1, color2, KPixmapEffect::PipeCrossGradient ); else KPixmapEffect::unbalancedGradient( m_pixmap, color1, color2, KPixmapEffect::PipeCrossGradient, xFactor, yFactor ); } break; case BCT_GPYRAMID: { if ( !unbalanced ) KPixmapEffect::gradient( m_pixmap, color1, color2, KPixmapEffect::PyramidGradient ); else KPixmapEffect::unbalancedGradient( m_pixmap, color1, color2, KPixmapEffect::PyramidGradient, xFactor, yFactor ); } break; } m_bDirty = false; } const TQPixmap& KPrGradient::pixmap() const { if ( m_bDirty ) const_cast<KPrGradient *>(this)->paint(); return m_pixmap; }