summaryrefslogtreecommitdiffstats
path: root/examples/desktop
diff options
context:
space:
mode:
authorTimothy Pearson <kb9vqf@pearsoncomputing.net>2011-07-10 15:24:15 -0500
committerTimothy Pearson <kb9vqf@pearsoncomputing.net>2011-07-10 15:24:15 -0500
commitbd0f3345a938b35ce6a12f6150373b0955b8dd12 (patch)
tree7a520322212d48ebcb9fbe1087e7fca28b76185c /examples/desktop
downloadqt3-bd0f3345a938b35ce6a12f6150373b0955b8dd12.tar.gz
qt3-bd0f3345a938b35ce6a12f6150373b0955b8dd12.zip
Add Qt3 development HEAD version
Diffstat (limited to 'examples/desktop')
-rw-r--r--examples/desktop/README12
-rw-r--r--examples/desktop/desktop.cpp347
-rw-r--r--examples/desktop/desktop.doc20
-rw-r--r--examples/desktop/desktop.pro10
4 files changed, 389 insertions, 0 deletions
diff --git a/examples/desktop/README b/examples/desktop/README
new file mode 100644
index 0000000..dcbb7a1
--- /dev/null
+++ b/examples/desktop/README
@@ -0,0 +1,12 @@
+The desktop demo contains three routines, each of which draws simple
+shapes on the desktop.
+
+"desktop -rotate" rotates a shaded square. Some nice color work.
+
+"desktop -poly" draws qix-like moving shapes.
+
+"desktop -shadetext" and "-troll" draw pretty shaded text on the
+desktop; "-shadewidget" and "-trollwidget" use the background as a
+widget. The latter can be used to make animated background widgets
+that work efficiently, which is very cool but possibly not very
+useful.
diff --git a/examples/desktop/desktop.cpp b/examples/desktop/desktop.cpp
new file mode 100644
index 0000000..2b6fb30
--- /dev/null
+++ b/examples/desktop/desktop.cpp
@@ -0,0 +1,347 @@
+/****************************************************************************
+**
+** Copyright (C) 1992-2008 Trolltech ASA. All rights reserved.
+**
+** This file is part of an example program for Qt. This example
+** program may be used, distributed and modified without limitation.
+**
+*****************************************************************************/
+
+#include <qimage.h>
+#include <qbitmap.h>
+#include <qpainter.h>
+#include <qapplication.h>
+#include <qdropsite.h>
+#include <qdragobject.h>
+#include <stdio.h>
+
+
+static double seed = 0.353535353535;
+static const int KINDA_RAND_MAX = 32767;
+
+static int kindaRand()
+{
+ seed = seed*147;
+ seed = seed - (double) ((int) seed);
+ return (int) ( seed*(KINDA_RAND_MAX + 1) );
+}
+
+static int velocity( int i ) // change velocity
+{
+ const int velmax = 15;
+ const int velmin = 4;
+ if ( i == 1 || i == 2 )
+ i = (kindaRand()&0x7fff % velmax)/3 + velmin;
+ else
+ i = (kindaRand()&0x7fff % velmax) + velmin;
+ return i;
+}
+
+//
+// Draw polygon on desktop.
+//
+
+void poly()
+{
+ QWidget *d = QApplication::desktop();
+ d->setBackgroundColor( Qt::white ); // white desktop
+
+ const int maxpoints = 5;
+ const int maxcurves = 8;
+ static int xvel[maxpoints];
+ static int yvel[maxpoints];
+ int head = 0;
+ int tail = -maxcurves + 2;
+ QPointArray *a = new QPointArray[ maxcurves ];
+ register QPointArray *p;
+ QRect r = d->rect(); // desktop rectangle
+
+ int i;
+ for ( i=0; i<maxcurves; i++ )
+ a[i].resize( maxpoints );
+ p = &a[0];
+ for ( i=0; i<maxpoints; i++ ) { // setup first polygon points
+ p->setPoint( i, (kindaRand()&0x7fff) % r.width(),
+ (kindaRand()&0x7fff) % r.height() );
+ xvel[i] = velocity(i);
+ yvel[i] = velocity(i);
+ }
+
+ QPainter paint;
+ paint.begin( d ); // start painting desktop
+
+ for ( int ntimes=0; ntimes<2000; ntimes++ ) {
+ paint.setBrush( QColor(kindaRand()%360, 180, 255, QColor::Hsv) );
+ paint.drawPolygon( a[head] );
+ if ( ++tail >= maxcurves )
+ tail = 0;
+
+ int minx=r.left(), maxx=r.right();
+ int miny=r.top(), maxy=r.bottom();
+ int x, y;
+ p = &a[head];
+ if ( ++head >= maxcurves )
+ head = 0;
+ for ( i=0; i<maxpoints; i++ ) { // calc new curve
+ p->point( i, &x, &y );
+ x += xvel[i];
+ y += yvel[i];
+ if ( x >= maxx ) {
+ x = maxx - (x - maxx + 1);
+ xvel[i] = -velocity(i);
+ }
+ if ( x <= minx ) {
+ x = minx + (minx - x + 1);
+ xvel[i] = velocity(i);
+ }
+ if ( y >= maxy ) {
+ y = maxy - (y - maxy + 1);
+ yvel[i] = -velocity(i);
+ }
+ if ( y <= miny ) {
+ y = miny + (miny - y + 1);
+ yvel[i] = velocity(i);
+ }
+ a[head].setPoint( i, x, y );
+ }
+ }
+ paint.end(); // painting done
+ delete[] a;
+}
+
+
+//
+// Rotate pattern on desktop.
+//
+
+void rotate()
+{
+ int i;
+ const int w = 64;
+ const int h = 64;
+ QImage image( w, h, 8, 128 ); // create image
+ for ( i=0; i<128; i++ ) // build color table
+ image.setColor( i, qRgb(i,0,0) );
+ for ( int y=0; y<h; y++ ) { // set image pixels
+ uchar *p = image.scanLine(y);
+ for ( int x=0; x<w; x++ )
+ *p++ = (x+y)%128;
+ }
+
+ QPixmap pm;
+ pm = image; // convert image to pixmap
+ pm.setOptimization( QPixmap::BestOptim ); // rotation will be faster
+
+ QWidget *d = QApplication::desktop(); // w = desktop widget
+
+ for ( i=0; i<=360; i += 2 ) {
+ QWMatrix m;
+ m.rotate( i ); // rotate coordinate system
+ QPixmap rpm = pm.xForm( m ); // rpm = rotated pixmap
+ d->setBackgroundPixmap( rpm ); // set desktop pixmap
+ d->update(); // repaint desktop
+ }
+}
+
+//
+// Generates a marble-like pattern in pm.
+//
+
+void generateStone( QPixmap *pm,
+ const QColor &c1, const QColor &c2, const QColor &c3 )
+{
+ QPainter p;
+ QPen p1 ( c1, 0 );
+ QPen p2 ( c2, 0 );
+ QPen p3 ( c3, 0 );
+
+ p.begin( pm );
+ for( int i = 0 ; i < pm->width() ; i++ )
+ for( int j = 0 ; j < pm->height() ; j++ ) {
+ int r = kindaRand();
+ if ( r < KINDA_RAND_MAX / 3 )
+ p.setPen( p1 );
+ else if ( r < KINDA_RAND_MAX / 3 * 2 )
+ p.setPen( p2 );
+ else
+ p.setPen( p3 );
+ p.drawPoint( i,j );
+ }
+ p.end();
+}
+
+void drawShadeText( QPainter *p, int x, int y, const char *text,
+ const QColor &topColor, const QColor &bottomColor,
+ int sw = 2 )
+{
+ if ( !p->isActive() )
+ return;
+
+ p->setPen( bottomColor );
+ p->drawText( x+sw, y+sw, text );
+ p->setPen( topColor );
+ p->drawText( x, y, text );
+}
+
+// NOTE: desktop drag/drop is experimental
+
+class DesktopWidget : public QWidget, private QDropSite
+{
+public:
+ DesktopWidget( const char *s, QWidget *parent=0, const char *name=0 );
+ ~DesktopWidget();
+ void paintEvent( QPaintEvent * );
+
+ void dragEnterEvent( QDragEnterEvent *e )
+ {
+ if ( QImageDrag::canDecode(e) )
+ e->accept();
+ }
+
+ void dragLeaveEvent( QDragLeaveEvent * )
+ {
+ }
+
+ void dragMoveEvent( QDragMoveEvent *e )
+ {
+ e->accept();
+ }
+
+ void dropEvent( QDropEvent * e )
+ {
+ QPixmap pmp;
+ if ( QImageDrag::decode( e, pmp ) ) {
+ setBackgroundPixmap( pmp );
+ update();
+ }
+ }
+
+private:
+ QPixmap *pm;
+ QString text;
+};
+
+DesktopWidget::DesktopWidget( const char *s, QWidget *parent, const char *name )
+ : QWidget( parent, name, WType_Desktop | WPaintDesktop),
+ QDropSite(this)
+{
+ text = s;
+ pm = 0;
+}
+
+DesktopWidget::~DesktopWidget()
+{
+ delete pm;
+}
+
+void DesktopWidget::paintEvent( QPaintEvent * )
+{
+ QColor c1 = backgroundColor();
+ QColor c2 = c1.light(104);
+ QColor c3 = c1.dark(106);
+ if ( !pm ) {
+ pm = new QPixmap( 64, 64 );
+ generateStone( pm, c1, c2, c3 );
+ setBackgroundPixmap( *pm );
+ update();
+ }
+ QRect br = fontMetrics().boundingRect( text );
+ QPixmap offscreen( br.width(), br.height() );
+ int x = width()/2 - br.width()/2;
+ int y = height()/2 - br.height()/2;
+ offscreen.fill( this, x, y );
+ QPainter p;
+ p.begin( &offscreen );
+ drawShadeText( &p, -br.x(), -br.y(), text, c2, c3, 3 );
+ p.end();
+ bitBlt( this, x, y, &offscreen );
+}
+
+void desktopWidget( const char *s = "Trolltech" )
+{
+ DesktopWidget *t = new DesktopWidget(s);
+ t->update();
+ qApp->exec();
+ delete t;
+}
+
+void desktopText( const char *s = "Trolltech" )
+{
+ const int border = 20;
+
+ QColor c1 = qApp->palette().inactive().background();
+ QColor c2 = c1.light(104);
+ QColor c3 = c1.dark(106);
+
+ QPixmap pm(10,10);
+
+ QPainter p;
+ p.begin( &pm );
+ QRect r = p.fontMetrics().boundingRect( s );
+ p.end();
+
+ int appWidth = qApp->desktop()->width();
+ int appHeight = qApp->desktop()->height();
+ if ( r.width() > appWidth - border*2 )
+ r.setWidth( appWidth - border*2 );
+ if ( r.height() > appHeight - border*2 )
+ r.setHeight( appHeight - border*2 );
+
+ pm.resize( r.size() + QSize( border*2, border*2 ) );
+ generateStone( &pm, c1, c2, c3 );
+ p.begin( &pm );
+ drawShadeText( &p, -r.x() + border, -r.y() + border, s, c2, c3 );
+ p.end();
+
+ qApp->desktop()->setBackgroundPixmap( pm );
+}
+
+//
+// The program starts here.
+//
+
+int main( int argc, char **argv )
+{
+ QApplication app( argc, argv );
+
+ if ( argc > 1 ) {
+ QFont f( "charter", 96, QFont::Black );
+ f.setStyleHint( QFont::Times );
+ app.setFont( f );
+ }
+
+ bool validOptions = FALSE;
+
+ if ( argc == 2 ) {
+ validOptions = TRUE;
+ if ( strcmp(argv[1],"-poly") == 0 )
+ poly();
+ else if ( strcmp(argv[1],"-rotate") == 0 )
+ rotate();
+ else if ( strcmp(argv[1],"-troll") == 0 )
+ desktopText();
+ else if ( strcmp(argv[1],"-trollwidget") == 0 )
+ desktopWidget();
+ else
+ validOptions = FALSE;
+ }
+ if ( argc == 3 ) {
+ validOptions = TRUE;
+ if ( strcmp(argv[1],"-shadetext") == 0 )
+ desktopText( argv[2] );
+ else if ( strcmp(argv[1],"-shadewidget") == 0 )
+ desktopWidget( argv[2] );
+ else
+ validOptions = FALSE;
+ }
+ if ( !validOptions ) {
+ fprintf( stderr, "Usage:\n\tdesktop -poly"
+ "\n\tdesktop -rotate"
+ "\n\tdesktop -troll"
+ "\n\tdesktop -trollwidget"
+ "\n\tdesktop -shadetext <text>"
+ "\n\tdesktop -shadewidget <text>\n" );
+ rotate();
+ }
+ return 0;
+}
diff --git a/examples/desktop/desktop.doc b/examples/desktop/desktop.doc
new file mode 100644
index 0000000..3a7df64
--- /dev/null
+++ b/examples/desktop/desktop.doc
@@ -0,0 +1,20 @@
+
+/*
+*/
+/*! \page desktop-example.html
+
+ \ingroup examples
+ \title Painting on the Desktop
+
+ The desktop demo contains three routines, each of which draws
+ something on the desktop. It does some nice stuff with QPainter,
+ and also demonstrates how one can treat the desktop as a widget like
+ any other.
+
+ <hr>
+
+ Implementation:
+
+ \include desktop/desktop.cpp
+*/
+
diff --git a/examples/desktop/desktop.pro b/examples/desktop/desktop.pro
new file mode 100644
index 0000000..8514010
--- /dev/null
+++ b/examples/desktop/desktop.pro
@@ -0,0 +1,10 @@
+TEMPLATE = app
+TARGET = desktop
+
+CONFIG += qt warn_on release
+DEPENDPATH = ../../include
+
+REQUIRES = full-config
+
+HEADERS =
+SOURCES = desktop.cpp