summaryrefslogtreecommitdiffstats
path: root/kdefx/kdrawutil.h
diff options
context:
space:
mode:
Diffstat (limited to 'kdefx/kdrawutil.h')
-rw-r--r--kdefx/kdrawutil.h180
1 files changed, 180 insertions, 0 deletions
diff --git a/kdefx/kdrawutil.h b/kdefx/kdrawutil.h
new file mode 100644
index 000000000..f16a7ab02
--- /dev/null
+++ b/kdefx/kdrawutil.h
@@ -0,0 +1,180 @@
+/* This file is part of the KDE libraries
+ Copyright (C) 1999 Daniel M. Duley <mosfet@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 version 2 as published by the Free Software Foundation.
+
+ 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.
+*/
+#ifndef __KDRAWUTIL_H
+#define __KDRAWUTIL_H
+
+#include <qnamespace.h>
+#include <qpainter.h>
+#include <qbitmap.h>
+#include <qpalette.h>
+
+#include <kdelibs_export.h>
+
+/*
+ * Various drawing routines. Also see Qt's qdrawutil.h for some more routines
+ * contained in Qt.
+ *
+ * (C) Daniel M. Duley <mosfet@kde.org>
+ */
+
+/**
+ * @relates KStyle
+ * @c \#include @c <kdrawutil.h>
+ *
+ * Draws a Next-style button (solid black shadow with light and midlight highlight).
+ *
+ * @param p The painter to use for drawing the button.
+ * @param r Specifies the rect in which to draw the button.
+ * @param g Specifies the shading colors.
+ * @param sunken Whether to draw the button as sunken (pressed) or not.
+ * @param fill The brush to use for filling the interior of the button.
+ * Pass @a null to prevent the button from being filled.
+ */
+KDEFX_EXPORT void kDrawNextButton(QPainter *p, const QRect &r, const QColorGroup &g,
+ bool sunken=false, const QBrush *fill=0);
+
+/**
+ * @relates KStyle
+ * @overload
+ */
+KDEFX_EXPORT void kDrawNextButton(QPainter *p, int x, int y, int w, int h,
+ const QColorGroup &g, bool sunken=false,
+ const QBrush *fill=0);
+
+/**
+ * @relates KStyle
+ * @c \#include @c <kdrawutil.h>
+ *
+ * Draws a Be-style button.
+ *
+ * @param p The painter to use for drawing the button.
+ * @param r Specifies the rect in which to draw the button.
+ * @param g Specifies the shading colors.
+ * @param sunken Whether to draw the button as sunken (pressed) or not.
+ * @param fill The brush to use for filling the interior of the button.
+ * Pass @a null to prevent the button from being filled.
+ */
+KDEFX_EXPORT void kDrawBeButton(QPainter *p, QRect &r, const QColorGroup &g,
+ bool sunken=false, const QBrush *fill=0);
+
+/**
+ * @relates KStyle
+ * @c \#include @c <kdrawutil.h>
+ * @overload
+ */
+KDEFX_EXPORT void kDrawBeButton(QPainter *p, int x, int y, int w, int h,
+ const QColorGroup &g, bool sunken=false,
+ const QBrush *fill=0);
+
+/**
+ * @relates KStyle
+ * @c \#include @c <kdrawutil.h>
+ *
+ * Draws a rounded oval button. This function doesn't fill the button.
+ * See kRoundMaskRegion() for setting masks for fills.
+ *
+ * @param p The painter to use for drawing the button.
+ * @param r Specifies the rect in which to draw the button.
+ * @param g Specifies the shading colors.
+ * @param sunken Whether to draw the button as sunken (pressed) or not.
+ */
+KDEFX_EXPORT void kDrawRoundButton(QPainter *p, const QRect &r, const QColorGroup &g,
+ bool sunken=false);
+
+/**
+ * @relates KStyle
+ * @overload
+ */
+KDEFX_EXPORT void kDrawRoundButton(QPainter *p, int x, int y, int w, int h,
+ const QColorGroup &g, bool sunken=false);
+
+/**
+ * @relates KStyle
+ * @c \#include @c <kdrawutil.h>
+ *
+ * Sets a region to the pixels covered by a round button of the given
+ * size. You can use this to set clipping regions.
+ *
+ * @param r Reference to the region to set.
+ * @param x The X coordinate of the button.
+ * @param y The Y coordinate of the button.
+ * @param w The width of the button.
+ * @param h The height of the button.
+ *
+ * @see kDrawRoundButton() and kDrawRoundMask()
+ */
+KDEFX_EXPORT void kRoundMaskRegion(QRegion &r, int x, int y, int w, int h);
+
+/**
+ * @relates KStyle
+ * @c \#include @c <kdrawutil.h>
+ *
+ * Paints the pixels covered by a round button of the given size with
+ * Qt::color1. This function is useful in QStyle::drawControlMask().
+ *
+ * @param p The painter to use for drawing the button.
+ * @param x The X coordinate of the button.
+ * @param y The Y coordinate of the button.
+ * @param w The width of the button.
+ * @param h The height of the button.
+ * @param clear Whether to clear the rectangle specified by @p (x, y, w, h) to
+ * Qt::color0 before drawing the mask.
+ */
+KDEFX_EXPORT void kDrawRoundMask(QPainter *p, int x, int y, int w, int h, bool clear=false);
+
+/**
+ * @relates KStyle
+ * @c \#include @c <kdrawutil.h>
+ *
+ * Paints the provided bitmaps in the painter, using the supplied colorgroup for
+ * the foreground colors. There's one bitmap for each color. If you want to skip
+ * a color, pass @a null for the corresponding bitmap.
+ *
+ * @note The bitmaps will be self-masked automatically if not masked
+ * prior to calling this routine.
+ *
+ * @param p The painter to use for drawing the bitmaps.
+ * @param g Specifies the shading colors.
+ * @param x The X coordinate at which to draw the bitmaps.
+ * @param y The Y coordinate at which to draw the bitmaps.
+ * @param lightColor The bitmap to use for the light part.
+ * @param midColor The bitmap to use for the mid part.
+ * @param midlightColor The bitmap to use for the midlight part.
+ * @param darkColor The bitmap to use for the dark part.
+ * @param blackColor The bitmap to use for the black part.
+ * @param whiteColor The bitmap to use for the white part.
+ *
+ * @see QColorGroup
+ */
+KDEFX_EXPORT void kColorBitmaps(QPainter *p, const QColorGroup &g, int x, int y,
+ QBitmap *lightColor=0, QBitmap *midColor=0,
+ QBitmap *midlightColor=0, QBitmap *darkColor=0,
+ QBitmap *blackColor=0, QBitmap *whiteColor=0);
+
+/**
+ * @relates KStyle
+ * @c \#include @c <kdrawutil.h>
+ * @overload
+ */
+ KDEFX_EXPORT void kColorBitmaps(QPainter *p, const QColorGroup &g, int x, int y, int w,
+ int h, bool isXBitmaps=true, const uchar *lightColor = 0,
+ const uchar *midColor=0, const uchar *midlightColor=0,
+ const uchar *darkColor=0, const uchar *blackColor=0,
+ const uchar *whiteColor=0);
+
+#endif