kde-workspace/kscreensaver/kdesavers/gravity.cpp
Ivailo Monev 7f4caa8dda generic: stop using obsolete code paths
Signed-off-by: Ivailo Monev <xakepa10@gmail.com>
2015-10-27 18:39:22 +02:00

430 lines
12 KiB
C++

//-----------------------------------------------------------------------------
//
// kgravity - Partical Gravity Screen Saver for KDE 2
//
// Copyright (c) Ian Reinhart Geiser 2001
//
// KConfig code and KScreenSaver "Setup..." improvements by
// Nick Betcher <nbetcher@usinternet.com> 2001
//
#include <stdlib.h>
#include <qlabel.h>
#include <qlayout.h>
#include <kapplication.h>
#include <klocale.h>
#include <kconfig.h>
#include <kcolordialog.h>
#include <kcolorbutton.h>
#include "gravity.h"
#include "moc_gravity.cpp"
#include <GL/glu.h>
#include <GL/gl.h>
#include <qimage.h>
#include <kdebug.h>
#include <qpainter.h>
#include <qradiobutton.h>
#include <qspinbox.h>
#include <kstandarddirs.h>
#include <math.h>
#include <kmessagebox.h>
#include <krandom.h>
// libkscreensaver interface
class KGravitySaverInterface : public KScreenSaverInterface
{
public:
virtual KAboutData* aboutData() {
return new KAboutData( "kgravity.kss", "klock", ki18n( "Particle Gravity Screen Saver" ), "2.2.0", ki18n( "Particle Gravity Screen Saver" ) );
}
virtual KScreenSaver* create( WId id )
{
return new KGravitySaver( id );
}
virtual QDialog* setup()
{
return new KGravitySetup();
}
};
int main( int argc, char *argv[] )
{
KGravitySaverInterface kss;
return kScreenSaverMain( argc, argv, kss );
}
//-----------------------------------------------------------------------------
// dialog to setup screen saver parameters
//
KGravitySetup::KGravitySetup( QWidget *parent )
: KDialog(parent)
{
setCaption(i18n( "Gravity Setup" ));
setButtons(Ok|Cancel|Help);
setDefaultButton(Ok);
setModal(true);
setButtonText( Help, i18n( "A&bout" ) );
QWidget *main = new QWidget(this);
setMainWidget(main);
cfg = new GravityWidget(main);
connect(this,SIGNAL(okClicked()),this,SLOT(slotOkPressed()));
connect(this,SIGNAL(helpClicked()),this,SLOT(aboutPressed()));
readSettings();
cfg->preview->setFixedSize( 220, 170 );
{
QPalette palette;
palette.setColor( cfg->preview->backgroundRole(), Qt::black );
cfg->preview->setPalette( palette );
cfg->preview->setAutoFillBackground(true);
}
#ifdef Q_WS_X11
cfg->preview->show(); // otherwise saver does not get correct size
#endif
saver = new KGravitySaver( cfg->preview->winId() );
;
connect( cfg->SpinBox1, SIGNAL(valueChanged(int)), saver, SLOT(updateSize(int)));
connect( cfg->RadioButton1, SIGNAL(toggled(bool)), saver, SLOT(doStars(bool)));
}
KGravitySetup::~KGravitySetup()
{
delete saver;
}
// read settings from config file
void KGravitySetup::readSettings()
{
KConfig config(QLatin1String( "kssgravityrc" ), KConfig::NoGlobals);
KConfigGroup grp = config.group( "Settings" );
bool boolval = grp.readEntry( "Stars", false );
if (boolval) {
cfg->RadioButton1->setChecked(true);
} else {
cfg->RadioButton1_2->setChecked(true);
}
int starammount = grp.readEntry("StarSize", 75);
cfg->SpinBox1->setValue(starammount);
}
// Ok pressed - save settings and exit
void KGravitySetup::slotOkPressed()
{
KConfig _config(QLatin1String( "kssgravityrc" ), KConfig::NoGlobals);
KConfigGroup config(&_config, "Settings" );
if (cfg->RadioButton1->isChecked())
{
config.writeEntry( "Stars", true );
} else {
if (cfg->RadioButton1_2->isChecked() == true)
{
config.writeEntry( "Stars", false );
}
}
config.writeEntry( "StarSize", cfg->SpinBox1->value() );
config.sync();
accept();
}
void KGravitySetup::aboutPressed()
{
KMessageBox::about(this,
i18n("<h3>Gravity</h3>\n<p>Particle Gravity Screen Saver for KDE</p>\nCopyright (c) Ian Reinhart Geiser 2001<br>\n\n<p>KConfig code and KScreenSaver \"Setup...\" improvements by Nick Betcher <nbetcher@usinternet.com> 2001</p>"));
}
//-----------------------------------------------------------------------------
KGravitySaver::KGravitySaver( WId id ) : KScreenSaver( id )
{
kDebug() << "Blank";
timer = new QTimer( this );
timer->setSingleShot(true);
timer->start( 25);
{
QPalette palette;
palette.setColor( backgroundRole(), Qt::black );
setPalette( palette );
}
update();
gravity = new Gravity();
embed(gravity);
#ifdef Q_WS_X11
gravity->show();
#endif
connect( timer, SIGNAL(timeout()), this, SLOT(blank()) );
}
KGravitySaver::~KGravitySaver()
{
}
// read configuration settings from config file
void KGravitySaver::readSettings()
{
// Please remove me
}
void KGravitySaver::blank()
{
// Play gravity
gravity->updateGL();
timer->setSingleShot(true);
timer->start( 25);
}
Gravity::Gravity( QWidget * parent ) : QGLWidget (parent)
{
rainbow=true;
slowdown=2.0f;
zoom=-50.0f;
index=0;
size = 3.95f;
// obj = gluNewQuadric();
// This has to be here because you can't update the gravity until 'gravity' is created!
KConfig _config(QLatin1String( "kssgravityrc" ), KConfig::NoGlobals);
KConfigGroup config(&_config, "Settings" );
bool boolval = config.readEntry( "Stars", false );
setStars(boolval);
int starammount = config.readEntry("StarSize", 75);
float passvalue = (starammount / 100.0);
setSize(passvalue);
}
Gravity::~Gravity()
{
glDeleteTextures( 1, &texture[0] );
gluDeleteQuadric(obj);
}
/** load the particle file */
bool Gravity::loadParticle()
{
/* Status indicator */
bool Status = true;
QImage buf;
kDebug() << "Loading: " << KStandardDirs::locate("data", QLatin1String( "kscreensaver/particle.png" ));
if (buf.load( KStandardDirs::locate("data", QLatin1String( "kscreensaver/particle.png" )) ) )
{
tex = convertToGLFormat(buf); // flipped 32bit RGBA
kDebug() << "Texture loaded: " << tex.byteCount ();
}
else
{
QImage dummy( 32, 32, QImage::Format_RGB32 );
dummy.fill( Qt::white );
buf = dummy;
tex = convertToGLFormat( buf );
}
/* Set the status to true */
//Status = true;
glGenTextures(1, &texture[0]); /* create three textures */
glBindTexture(GL_TEXTURE_2D, texture[0]);
/* use linear filtering */
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
/* actually generate the texture */
glTexImage2D(GL_TEXTURE_2D, 0, 4, tex.width(), tex.height(), 0,
GL_RGBA, GL_UNSIGNED_BYTE, tex.bits());
return Status;
}
/** setup the GL environment */
void Gravity::initializeGL ()
{
kDebug() << "InitGL";
if (loadParticle()) // Jump To Texture Loading Routine
{
/* Enable smooth shading */
glShadeModel( GL_SMOOTH );
/* Set the background black */
glClearColor( 0.0f, 0.0f, 0.0f, 0.0f );
/* Depth buffer setup */
glClearDepth( 1.0f );
/* Enables Depth Testing */
glDisable( GL_DEPTH_TEST );
/* Enable Blending */
glEnable( GL_BLEND );
/* Type Of Blending To Perform */
glBlendFunc( GL_SRC_ALPHA, GL_ONE );
/* Really Nice Perspective Calculations */
glHint( GL_PERSPECTIVE_CORRECTION_HINT, GL_NICEST );
/* Really Nice Point Smoothing */
glHint( GL_POINT_SMOOTH_HINT, GL_NICEST );
/* Enable Texture Mapping */
glEnable( GL_TEXTURE_2D );
/* Select Our Texture */
glBindTexture( GL_TEXTURE_2D, texture[0] );
for (loop=0;loop<MAX_PARTICLES;loop++) // Initials All The Textures
{
buildParticle(loop);
}
}
else
exit(0);
}
/** resize the gl view */
void Gravity::resizeGL ( int width, int height )
{
kDebug() << "ResizeGL " << width << "," <<height;
if (height==0) // Prevent A Divide By Zero By
{
height=1; // Making Height Equal One
}
glViewport(0,0,width,height); // Reset The Current Viewport
glMatrixMode(GL_PROJECTION); // Select The Projection Matrix
glLoadIdentity(); // Reset The Projection Matrix
// Calculate The Aspect Ratio Of The Window
gluPerspective(45.0f,(GLfloat)width/(GLfloat)height,0.1f,100.0f);
glMatrixMode(GL_MODELVIEW); // Select The Modelview Matrix
glLoadIdentity();
}
/** paint the GL view */
void Gravity::paintGL ()
{
//kDebug() << "PaintGL";
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); // Clear Screen And Depth Buffer
glLoadIdentity();
// Reset The ModelView Matrix
transIndex++;
//glRotatef(transIndex, 1,0,0);
//glRotatef(transIndex, 0,1,0);
//glRotatef(transIndex, 0,0,1);
float xmax = 5.0;
float ymax = 5.0;
glTranslatef( GLfloat(xmax*sin(3.14*transIndex/360)-xmax),
GLfloat(ymax*cos(3.14*transIndex/360)-ymax),
0.0 );
//glRotatef(transIndex, 0,GLfloat(zmax*cos(3.14*transIndex/360000)), GLfloat(zmax*cos(3.14*transIndex/360000)));
for (loop=0;loop<MAX_PARTICLES;loop++) // Loop Through All The Particles
{
if (particle[loop].active) // If The Particle Is Active
{
float x=particle[loop].x; // Grab Our Particle X Position
float y=particle[loop].y; // Grab Our Particle Y Position
float z=particle[loop].z+zoom; // Particle Z Pos + Zoom
/* Select Our Texture */
/* Draw The Particle Using Our RGB Values,
* Fade The Particle Based On It's Life
*/
particle[loop].life=(particle[loop].index/particle[loop].indexo)*2.0f;
glColor4f( particle[loop].r,
particle[loop].g,
particle[loop].b,
particle[loop].life );
/* Build Quad From A Triangle Strip */
if( !stars )
glBegin( GL_TRIANGLE_STRIP );
else
glBegin( GL_TRIANGLE_FAN );
/* Top Right */
glTexCoord2d( 1, 1 );
glVertex3f( x + particle[loop].size, y + particle[loop].size, z );
/* Top Left */
glTexCoord2d( 0, 1 );
glVertex3f( x - particle[loop].size, y + particle[loop].size, z );
/* Bottom Right */
glTexCoord2d( 1, 0 );
glVertex3f( x + particle[loop].size, y - particle[loop].size, z );
/* Bottom Left */
glTexCoord2d( 0, 0 );
glVertex3f( x - particle[loop].size, y - particle[loop].size, z );
glEnd( );
particle[loop].x=(particle[loop].xo*sin(particle[loop].index))*pow((double) particle[loop].index/particle[loop].indexo,(double) 8.0);
particle[loop].y=(particle[loop].yo*sin(particle[loop].index))*pow((double) particle[loop].index/particle[loop].indexo,(double) 8.0);
particle[loop].z=(particle[loop].zo*sin(particle[loop].index))*pow((double) particle[loop].index/particle[loop].indexo,(double) 8.0);
particle[loop].index-=0.05;
if (particle[loop].index<0.0f ) // If Particle Is Burned Out
{
buildParticle(loop);
}
// Lets stir some things up
}
}
glFlush();
}
void Gravity::setSize( float newSize )
{
size = newSize;
}
void Gravity::setStars( bool doStars )
{
stars = doStars;
}
void KGravitySaver::updateSize(int newSize)
{
gravity->setSize(newSize/100);
}
void KGravitySaver::doStars(bool starState)
{
gravity->setStars(starState);
}
void Gravity::buildParticle(int loop)
{
GLfloat colors[12][3]=
{{1.0f,0.5f,0.5f},{1.0f,0.75f,0.5f},{1.0f,1.0f,0.5f},{0.75f,1.0f,0.5f},
{0.5f,1.0f,0.5f},{0.5f,1.0f,0.75f},{0.5f,1.0f,1.0f},{0.5f,0.75f,1.0f},
{0.5f,0.5f,1.0f},{0.75f,0.5f,1.0f},{1.0f,0.5f,1.0f},{1.0f,0.5f,0.75f}};
col = ( col + 1 ) % 12;
particle[loop].active=true;
particle[loop].index=KRandom::random()%100;
particle[loop].indexo=particle[loop].index;
particle[loop].fade=float(KRandom::random()%100)/1000.0f+0.003f; // Random Fade Value
particle[loop].r=colors[col][0]; // Select Red From Color Table
particle[loop].g=colors[col][1]; // Select Green From Color Table
particle[loop].b=colors[col][2]; // Select Blue From Color Table
particle[loop].size=size;
particle[loop].x = float(KRandom::random()%100-50)*4.0;
particle[loop].y = float(KRandom::random()%20-10)*4.0;
particle[loop].z = float(KRandom::random()%100-50)*4.0;
particle[loop].xo = particle[loop].x;
if ((1+(KRandom::random() % 10) > 5))
particle[loop].yo = particle[loop].y;
else
particle[loop].yo = 0.0;
particle[loop].zo = particle[loop].z;
}