You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdebase/kicker/extensions/kasbar/kasresources.h

172 lines
5.2 KiB

// -*- c++ -*-
/* kasbar.h
**
** Copyright (C) 2001-2004 Richard Moore <rich@kde.org>
** Contributor: Mosfet
** All rights reserved.
**
** KasBar is dual-licensed: you can choose the GPL or the BSD license.
** Short forms of both licenses are included below.
*/
/*
** 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 2 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 in a file called COPYING; if not, write to
** the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
** MA 02110-1301, USA.
*/
/*
** Redistribution and use in source and binary forms, with or without
** modification, are permitted provided that the following conditions
** are met:
** 1. Redistributions of source code must retain the above copyright
** notice, this list of conditions and the following disclaimer.
** 2. Redistributions in binary form must reproduce the above copyright
** notice, this list of conditions and the following disclaimer in the
** documentation and/or other materials provided with the distribution.
**
** THIS SOFTWARE IS PROVIDED BY THE AUTHORS 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 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.
*/
/*
** Bug reports and questions can be sent to kde-devel@kde.org
*/
#ifndef KASRESOURCES_H
#define KASRESOURCES_H
#include <tqbitmap.h>
#include <tqcolor.h>
#include <tqbrush.h>
#include <tqpen.h>
#include <kpixmap.h>
#include <tqobject.h>
#include <tqvaluevector.h>
class KasBar;
/**
* Central class that holds the graphical resources for the bar.
*
* @author Richard Moore, rich@kde.org
*/
class KasResources : public TQObject
{
Q_OBJECT
public:
KasResources( KasBar *parent, const char *name=0 );
virtual ~KasResources();
TQColor labelPenColor() const { return labelPenColor_; }
TQColor labelBgColor() const { return labelBgColor_; }
TQColor inactivePenColor() const { return inactivePenColor_; }
TQColor inactiveBgColor() const { return inactiveBgColor_; }
TQColor activePenColor() const { return activePenColor_; }
TQColor activeBgColor() const { return activeBgColor_; }
TQColor progressColor() const { return progressColor_; }
TQColor attentionColor() const { return attentionColor_; }
/** Accessor for the min icon (singleton). */
TQBitmap minIcon();
/** Accessor for the max icon (singleton). */
TQBitmap maxIcon();
/** Accessor for the shade icon (singleton). */
TQBitmap shadeIcon();
/** Accessor for the attention icon (singleton). */
TQBitmap attentionIcon();
/** Accessor for the modified icon (singleton). */
TQPixmap modifiedIcon();
/** Accessor for the micro min icon (singleton). */
TQPixmap microMinIcon();
/** Accessor for the micro max icon (singleton). */
TQPixmap microMaxIcon();
/** Accessor for the micro shade icon (singleton). */
TQPixmap microShadeIcon();
/** Accessor used by items to get the active bg fill. */
KPixmap activeBg();
/** Accessor used by items to get the inactive bg fill. */
KPixmap inactiveBg();
TQValueVector<TQPixmap> startupAnimation();
public slots:
void setLabelPenColor( const TQColor &color );
void setLabelBgColor( const TQColor &color );
void setInactivePenColor( const TQColor &color );
void setInactiveBgColor( const TQColor &color );
void setActivePenColor( const TQColor &color );
void setActiveBgColor( const TQColor &color );
void setProgressColor( const TQColor &color );
void setAttentionColor( const TQColor &color );
void itemSizeChanged();
signals:
void changed();
private:
KasBar *kasbar;
TQBitmap minPix;
TQBitmap maxPix;
TQBitmap shadePix;
TQBitmap attentionPix;
TQPixmap modifiedPix;
TQPixmap microShadePix;
TQPixmap microMaxPix;
TQPixmap microMinPix;
TQColor labelPenColor_;
TQColor labelBgColor_;
TQColor activePenColor_;
TQColor activeBgColor_;
TQColor inactivePenColor_;
TQColor inactiveBgColor_;
TQColor progressColor_;
TQColor attentionColor_;
KPixmap actBg;
KPixmap inactBg;
TQValueVector<TQPixmap> startupFrames_;
};
#endif // KASRESOURCES_H