diff options
Diffstat (limited to 'ktux')
-rw-r--r-- | ktux/AUTHORS | 2 | ||||
-rw-r--r-- | ktux/Makefile.am | 38 | ||||
-rw-r--r-- | ktux/hi16-app-ktux.png | bin | 0 -> 628 bytes | |||
-rw-r--r-- | ktux/hi32-app-ktux.png | bin | 0 -> 1335 bytes | |||
-rw-r--r-- | ktux/ktux.desktop | 212 | ||||
-rw-r--r-- | ktux/sprite.cpp | 254 | ||||
-rw-r--r-- | ktux/sprite.h | 72 | ||||
-rw-r--r-- | ktux/spriteanim.cpp | 161 | ||||
-rw-r--r-- | ktux/spriteanim.h | 96 | ||||
-rw-r--r-- | ktux/spritemisc.cpp | 69 | ||||
-rw-r--r-- | ktux/spritemisc.h | 41 | ||||
-rw-r--r-- | ktux/spritepm.cpp | 176 | ||||
-rw-r--r-- | ktux/spritepm.h | 85 | ||||
-rw-r--r-- | ktux/sprites/Makefile.am | 8 | ||||
-rw-r--r-- | ktux/sprites/anim0001.png | bin | 0 -> 23517 bytes | |||
-rw-r--r-- | ktux/sprites/anim0002.png | bin | 0 -> 23245 bytes | |||
-rw-r--r-- | ktux/sprites/anim0003.png | bin | 0 -> 23646 bytes | |||
-rw-r--r-- | ktux/sprites/anim0004.png | bin | 0 -> 23725 bytes | |||
-rw-r--r-- | ktux/sprites/anim0005.png | bin | 0 -> 23541 bytes | |||
-rw-r--r-- | ktux/sprites/anim0006.png | bin | 0 -> 23573 bytes | |||
-rw-r--r-- | ktux/sprites/anim0007.png | bin | 0 -> 23537 bytes | |||
-rw-r--r-- | ktux/sprites/anim0008.png | bin | 0 -> 23680 bytes | |||
-rw-r--r-- | ktux/sprites/anim0009.png | bin | 0 -> 23642 bytes | |||
-rw-r--r-- | ktux/sprites/anim0010.png | bin | 0 -> 23257 bytes | |||
-rw-r--r-- | ktux/sprites/bg.png | bin | 0 -> 7799 bytes | |||
-rw-r--r-- | ktux/sprites/flare0001.png | bin | 0 -> 210 bytes | |||
-rw-r--r-- | ktux/sprites/flare0002.png | bin | 0 -> 325 bytes | |||
-rw-r--r-- | ktux/sprites/spriterc | 62 | ||||
-rw-r--r-- | ktux/sprites/star0001.png | bin | 0 -> 194 bytes | |||
-rw-r--r-- | ktux/sprites/star0002.png | bin | 0 -> 219 bytes |
30 files changed, 1276 insertions, 0 deletions
diff --git a/ktux/AUTHORS b/ktux/AUTHORS new file mode 100644 index 0000000..394a242 --- /dev/null +++ b/ktux/AUTHORS @@ -0,0 +1,2 @@ +Code: Martin Jones <[email protected]> +Graphics: Carlos Rego diff --git a/ktux/Makefile.am b/ktux/Makefile.am new file mode 100644 index 0000000..8a32552 --- /dev/null +++ b/ktux/Makefile.am @@ -0,0 +1,38 @@ +## Makefile.am for ktux + +# this has all of the subdirectories that make will recurse into. if +# there are none, comment this out +SUBDIRS = sprites + +# this is the program that gets installed. it's name is used for all +# of the other Makefile.am variables +bin_PROGRAMS = ktux + +# set the include path for X, qt and KDE +INCLUDES = $(all_includes) + +# the library search path. +ktux_LDFLAGS = $(all_libraries) $(KDE_RPATH) + +# the libraries to link against. +ktux_LDADD = $(LIB_KDEUI) -lkscreensaver + +# which sources should be compiled for ktux +ktux_SOURCES = spriteanim.cpp spritemisc.cpp spritepm.cpp sprite.cpp + +# these are the headers for your project +noinst_HEADERS = sprite.h spriteanim.h spritemisc.h spritepm.h + +# let automoc handle all of the meta source files (moc) +METASOURCES = AUTO + +# make messages.po. Move this one to ../po/ and "make merge" in po +# the -x is for skipping messages already translated in kdelibs +messages: + $(XGETTEXT) *.cpp -o $(podir)/ktux.pot + +KDE_ICON = ktux + +appsdir = $(kde_appsdir)/System/ScreenSavers +apps_DATA = ktux.desktop + diff --git a/ktux/hi16-app-ktux.png b/ktux/hi16-app-ktux.png Binary files differnew file mode 100644 index 0000000..e21db29 --- /dev/null +++ b/ktux/hi16-app-ktux.png diff --git a/ktux/hi32-app-ktux.png b/ktux/hi32-app-ktux.png Binary files differnew file mode 100644 index 0000000..4ecd9ce --- /dev/null +++ b/ktux/hi32-app-ktux.png diff --git a/ktux/ktux.desktop b/ktux/ktux.desktop new file mode 100644 index 0000000..9895467 --- /dev/null +++ b/ktux/ktux.desktop @@ -0,0 +1,212 @@ +[Desktop Entry] +Name=KTux +Name[af]=Ktux +Name[bg]=Тъкс +Name[bn]=কে-টাক্স +Name[eo]=Tuĉjo +Name[hi]=के-टक्स +Name[ne]=केडीई टक्स +Name[ta]= KTux +Name[tg]=KТукс +Name[th]=ตุ๊กซ์ +Exec=ktux %i %m -caption "%c" +Icon=ktux +Type=Application +Actions=Setup;InWindow;Root; +X-KDE-Category=Flying Things +Terminal=false + +[Desktop Action Setup] +Exec=ktux -setup +Name=Setup... +Name[af]=Opstelling... +Name[ar]=اعداد... +Name[az]=Qurulum... +Name[be]=Настаўленні... +Name[bg]=Настройване... +Name[bn]=প্রস্তুতি... +Name[br]=Kefluniadur ... +Name[bs]=Postavke... +Name[ca]=Configuració... +Name[cs]=Nastavení... +Name[cy]=Gosod ... +Name[da]=Opsætning... +Name[de]=Einrichtung ... +Name[el]=Ρύθμιση... +Name[eo]=Agordo... +Name[es]=Configuración... +Name[et]=Seadistused... +Name[eu]=Konfigurazioa... +Name[fa]=برپایی... +Name[fi]=Asetukset... +Name[fr]=Configuration... +Name[ga]=Socraigh... +Name[gl]=Configuración... +Name[he]=הגדרות... +Name[hi]=सेटअप... +Name[hr]=Postavke... +Name[hu]=Beállítás... +Name[id]=Aturan... +Name[is]=Stillingar... +Name[it]=Impostazioni... +Name[ja]=セットアップ... +Name[km]=រៀបចំ... +Name[ko]=설정... +Name[lt]=Nustatymas... +Name[lv]=Uzstādījumi... +Name[mk]=Поставување... +Name[ms]=Tetapan... +Name[nb]=Oppsett … +Name[nds]=Instellen... +Name[ne]=सेटअप... +Name[nl]=Instellingen... +Name[nn]=Oppsett … +Name[pa]=ਸੈੱਟਅੱਪ... +Name[pl]=Ustawienia... +Name[pt]=Configurar... +Name[pt_BR]=Configurar... +Name[ro]=Setări... +Name[ru]=Настройка... +Name[rw]=Iboneza... +Name[sk]=Nastavenie... +Name[sl]=Nastavitve ... +Name[sr]=Подеси... +Name[sr@Latn]=Podesi... +Name[sv]=Inställningar... +Name[ta]=அமைப்பு... +Name[tg]=Соз кардан... +Name[th]=ติดตั้ง... +Name[tr]=Kurulum... +Name[uk]=Встановити... +Name[uz]=Oʻrnatish +Name[uz@cyrillic]=Ўрнатиш +Name[ven]=Vhekanya... +Name[wa]=Apontyî... +Name[xh]=Iyacwangciswa... +Name[zh_CN]=设置... +Name[zh_TW]=設定... +Name[zu]=Iyalungiselela... +Icon=kscreensaver + +[Desktop Action InWindow] +Exec=ktux -window-id %w +Name=Display in Specified Window +Name[be]=Паказваць у зададзеным вакне +Name[bg]=Стартиране в избран прозорец +Name[bn]=উল্লেখকৃত উইন্ডোতে দেখাও +Name[br]=Diskwel er prenestr spisaet +Name[bs]=Prikaži u navedenom prozoru +Name[ca]=Mostra a la finestra especificada +Name[cs]=Zobrazit v určeném okně +Name[cy]=Dangos mewn Ffenestr Benodol +Name[da]=Visning i angivet vindue +Name[de]=In vorgegebenem Fenster anzeigen +Name[el]=Εμφάνιση σε προκαθορισμένο παράθυρο +Name[eo]=Montru en indikita fenestro +Name[es]=Mostrar en la ventana especificada +Name[et]=Määratud aknas näitamine +Name[eu]=Zehaztutako lehioan erakutsi +Name[fa]=نمایش در پنجرۀ مشخصشده +Name[fi]=Näytä määrätyssä ikkunassa +Name[fr]=Affichage dans la fenêtre indiquée +Name[ga]=Taispeáin san Fhuinneog Sonraithe +Name[gl]=Mostrar na fiestra indicada +Name[he]=הצג בחלון המצויין +Name[hr]=Prikazianje u određenom prozoru +Name[hu]=Megjelenítés a megadott ablakban +Name[id]=Ditampilkan di Window Khusus +Name[is]=Birta í ákveðnum glugga +Name[it]=Mostra nella finestra specificata +Name[ja]=指定ウィンドウで表示 +Name[km]=បង្ហាញក្នុងបង្អួចជាក់លាក់ +Name[ko]=지정한 창에 표시하기 +Name[lt]=Rodyti nurodytame lange +Name[lv]=Rādīt norādītajā logā +Name[mk]=Приказ во зададениот прозорец +Name[mt]=Uri fil-window speċifikata +Name[nb]=Vis i det oppgitte vinduet +Name[nds]=In't angeven Finster wiesen +Name[ne]=निर्दिष्ट सञ्झ्यालमा प्रदर्शन गर्नुहोस् +Name[nl]=Weergeven in een gedefinieerd venster +Name[nn]=Vis i oppgjeve vindauge +Name[pl]=Wyświetl w zadanym oknie +Name[pt]=Mostrar na Janela Indicada +Name[pt_BR]=Mostrar em janela especificada +Name[ro]=Afişează în fereastra specificată +Name[ru]=Показывать в указанном окне +Name[rw]=Kwerekana mu Idirishya Ryihariye +Name[sk]=Zobraziť v zadanom okne +Name[sl]=Prikaz v določenemu oknu +Name[sr]=Прикажи у задатом прозору +Name[sr@Latn]=Prikaži u zadatom prozoru +Name[sv]=Visa i angivet fönster +Name[ta]= குறிப்பிட்ட சாளர காட்சியை காட்டு +Name[tg]=Дар Тирезаи Муайяншуда Намоиш додан +Name[tr]=Belirtilen Pencerede Göster +Name[uk]=Відобразити у вказаному вікні +Name[wa]=Håyner dins l' purnea specifyî +Name[zh_CN]=在指定的窗口中显示 +Name[zh_TW]=在指定的視窗中顯示 +NoDisplay=true + +[Desktop Action Root] +Exec=ktux -root +Name=Display in Root Window +Name[be]=Паказваць у фанавым вакне +Name[bg]=Стартиране в главния прозорец +Name[bn]=রুট উইন্ডোতে দেখাও +Name[br]=Diskwel er prenestr gwrizienn +Name[bs]=Prikaži u korijenskom prozoru +Name[ca]=Mostra a la finestra arrel +Name[cs]=Zobrazit na pozadí plochy +Name[cy]=Dangos mewn Ffenestr Wraidd +Name[da]=Visning i root-vindue +Name[de]=Im Hintergrundfenster anzeigen +Name[el]=Προβολή στο βασικό παράθυρο +Name[eo]=Montru en radika fenestro +Name[es]=Mostrar en la ventana raíz +Name[et]=Juuraknas näitamine +Name[eu]=Lehio nagusian erakutsi +Name[fa]=نمایش در پنجرۀ ریشه +Name[fi]=Näytä juuri-ikkunassa +Name[fr]=Affichage dans la fenêtre principale +Name[ga]=Taispeáin sa bhFréamhfhuinneog +Name[gl]=Mostrar na fiestra raiz +Name[he]=הצג בחלון השורש +Name[hr]=Prikazivanje u korijenskom prozoru +Name[hu]=Megjelenítés a gyökérablakban +Name[id]=Ditampilkan di Root Window +Name[is]=Birta í rótarglugga +Name[it]=Mostra sullo sfondo +Name[ja]=ルートウィンドウで表示 +Name[km]=បង្ហាញក្នុងបង្អួច Root +Name[ko]=주 창에 표시하기 +Name[lt]=Rodyti root lange +Name[lv]=Rādīt galvenajā logā +Name[mk]=Приказ во коренскиот прозорец +Name[mt]=Uri fil-window ewlenija +Name[nb]=Vis i rotvinduet +Name[nds]=In't Hööftfinster wiesen +Name[ne]=मूल सञ्झ्यालमा प्रदर्शन गर्नुहोस् +Name[nl]=Weergeven in hoofdvenster +Name[nn]=Vis i rotvindauget +Name[pl]=Wyświetl w oknie głównym +Name[pt]=Mostrar na Janela de Fundo +Name[pt_BR]=Mostrar na janela raiz +Name[ro]=Afişează în fereastra rădăcină +Name[ru]=Показывать на фоне рабочего стола +Name[rw]=Kwerekana mu Idirishya Umuzi +Name[sk]=Zobraziť v koreňovom okne +Name[sl]=Prikaz v korenskem oknu +Name[sr]=Прикажи у кореном прозору +Name[sr@Latn]=Prikaži u korenom prozoru +Name[sv]=Visa i rotfönster +Name[ta]=மூல சாளரத்தில் காட்டு +Name[tg]=Дар Тирезаи Решавӣ Намоиш додан +Name[tr]=Kök Pencerede Göster +Name[uk]=Відобразити на тлі екрана +Name[wa]=Håyner e purnea raecene (li fond do scribanne) +Name[zh_CN]=在根窗口中显示 +Name[zh_TW]=在根視窗中顯示 +NoDisplay=true +X-DCOP-ServiceType=Multi diff --git a/ktux/sprite.cpp b/ktux/sprite.cpp new file mode 100644 index 0000000..205c754 --- /dev/null +++ b/ktux/sprite.cpp @@ -0,0 +1,254 @@ +//----------------------------------------------------------------------------- +// +// KTux - QCanvas based screensaver +// +// Copyright (c) Martin R. Jones 1999 +// + +#include <stdlib.h> +#include <time.h> +#include <qlabel.h> +#include <qmessagebox.h> +#include <qlayout.h> +#include <qslider.h> +#include <kstandarddirs.h> +#include <klocale.h> +#include <kdebug.h> +#include <kstdguiitem.h> +#include <kbuttonbox.h> + +#include "spritepm.h" +#include "spritemisc.h" +#include "sprite.h" +#include "sprite.moc" + + +// libkscreensaver interface +extern "C" +{ + KDE_EXPORT const char *kss_applicationName = "ktux"; + KDE_EXPORT const char *kss_description = I18N_NOOP( "Tux Screen Saver" ); + KDE_EXPORT const char *kss_version = "1.0.0"; + + KDE_EXPORT KScreenSaver *kss_create( WId id ) + { + return new KSpriteSaver( id ); + } + + KDE_EXPORT QDialog *kss_setup() + { + return new KSpriteSetup(); + } +} + +//----------------------------------------------------------------------------- + +KSpriteSetup::KSpriteSetup( QWidget *parent, const char *name ) + : QDialog( parent, name, TRUE ) +{ + KGlobal::locale()->insertCatalogue("ktux"); + saver = 0; + + readSettings(); + + setCaption(i18n("Setup KTux") ); + + QVBoxLayout *tl = new QVBoxLayout(this, 10, 10); + QHBoxLayout *tl1 = new QHBoxLayout; + tl->addLayout(tl1); + QVBoxLayout *tl11 = new QVBoxLayout(5); + tl1->addLayout(tl11); + + QLabel *label = new QLabel( i18n("Speed:"), this ); + label->setMinimumSize(label->sizeHint()); + tl11->addStretch(1); + tl11->addWidget(label); + + QSlider *sb = new QSlider(0, 100, 10, speed, QSlider::Horizontal, this ); + tl11->addWidget(sb); + connect( sb, SIGNAL( valueChanged( int ) ), SLOT( slotSpeed( int ) ) ); + + preview = new QWidget( this ); + preview->setFixedSize( 220, 170 ); + preview->setBackgroundColor( black ); + preview->show(); // otherwise saver does not get correct size + saver = new KSpriteSaver( preview->winId() ); + tl1->addWidget(preview); + + KButtonBox *bbox = new KButtonBox(this); + QButton *button = bbox->addButton( i18n("About")); + connect( button, SIGNAL( clicked() ), SLOT(slotAbout() ) ); + bbox->addStretch(1); + + button = bbox->addButton( KStdGuiItem::ok()); + connect( button, SIGNAL( clicked() ), SLOT( slotOkPressed() ) ); + + button = bbox->addButton(KStdGuiItem::cancel()); + connect( button, SIGNAL( clicked() ), SLOT( reject() ) ); + bbox->layout(); + tl->addWidget(bbox); + + tl->freeze(); +} + +KSpriteSetup::~KSpriteSetup() +{ + delete saver; +} + +// read settings from config file +void KSpriteSetup::readSettings() +{ + KConfig *config = KGlobal::config(); + config->setGroup( "Settings" ); + + speed = config->readNumEntry( "Speed", 50 ); + if (speed > 100) + speed = 100; + else if (speed < 0) + speed = 0; +} + +void KSpriteSetup::slotSpeed(int s) +{ + speed = s; + if (saver) + saver->setSpeed(speed); +} + +// Ok pressed - save settings and exit +void KSpriteSetup::slotOkPressed() +{ + KConfig *config = KGlobal::config(); + config->setGroup("Settings"); + config->writeEntry("Speed", speed); + config->sync(); + accept(); +} + +void KSpriteSetup::slotAbout() +{ + QMessageBox::message(i18n("About KTux"), + i18n("KTux Version 1.0\n\nWritten by Martin R. Jones 1999\[email protected]"), + i18n("OK")); +} + + +//----------------------------------------------------------------------------- + +KSpriteSaver::KSpriteSaver( WId id ) : KScreenSaver( id ) +{ + KGlobal::dirs()->addResourceType("sprite", KStandardDirs::kde_default("data") + "ktux/sprites/"); + + initialise(); + readSettings(); + blank(); + + connect(&mTimer, SIGNAL(timeout()), SLOT(slotTimeout())); + mTimer.start(120-mSpeed, true); +} + +//----------------------------------------------------------------------------- +KSpriteSaver::~KSpriteSaver() +{ + mTimer.stop(); + delete mView; + delete mCanvas; +} + +//----------------------------------------------------------------------------- +// +void KSpriteSaver::setSpeed(int speed) +{ + mSpeed = speed; + mTimer.changeInterval(120-mSpeed); +} + +//----------------------------------------------------------------------------- +// read settings from config file +// +void KSpriteSaver::readSettings() +{ + QString str; + + KConfig *config = KGlobal::config(); + config->setGroup("Settings"); + + mSpeed = config->readNumEntry("Speed", 50); + + QString path = KGlobal::dirs()->findResourceDir( "sprite", "bg.png" ); + + SpritePixmapManager::manager()->setPixmapDir(path); + + path += "spriterc"; + + KSimpleConfig *mConfig = new KSimpleConfig(path, true); + mConfig->setGroup("Config"); + QStrList list; + int groups = mConfig->readListEntry("Groups", list); + mTimerIds.resize(groups); + for (int i = 0; i < groups; i++) + { + kdDebug() << "Group: " << list.at(i) << endl;; + mConfig->setGroup(list.at(i)); + SpriteGroup *obj = new SpriteGroup(mCanvas, *mConfig); + mTimerIds[i] = startTimer(obj->refreshTime()); + mGroups.append(obj); + } + delete mConfig; +} + +//----------------------------------------------------------------------------- +void KSpriteSaver::initialise() +{ + mCanvas = new QCanvas(); + QPixmap pm( locate("sprite", "bg.png") ); + mCanvas->setBackgroundPixmap( pm ); + mCanvas->resize( width(), height() ); + mView = new QCanvasView(mCanvas); + mView->viewport()->setBackgroundColor( black ); + mView->resize( size()); + mView->setFrameStyle( QFrame::NoFrame ); + mView->setVScrollBarMode( QScrollView::AlwaysOff ); + mView->setHScrollBarMode( QScrollView::AlwaysOff ); + embed( mView ); + mView->show(); + SpriteRange::setFieldSize(mView->size()); +} + +//----------------------------------------------------------------------------- +void KSpriteSaver::slotTimeout() +{ + mTimer.start(120-mSpeed, true); + SpriteGroup *grp; + + for (grp = mGroups.first(); grp; grp = mGroups.next()) + { + grp->next(); + } + + mCanvas->advance(); +} + +//----------------------------------------------------------------------------- +void KSpriteSaver::timerEvent(QTimerEvent *ev) +{ + for (unsigned i = 0; i < mTimerIds.size(); i++) + { + if (mTimerIds[i] == ev->timerId()) + { + mGroups.at(i)->refresh(); + killTimer(ev->timerId()); + mTimerIds[i] = startTimer(mGroups.at(i)->refreshTime()); + break; + } + } +} + +//----------------------------------------------------------------------------- +void KSpriteSaver::blank() +{ + setBackgroundColor( black ); + erase(); +} + diff --git a/ktux/sprite.h b/ktux/sprite.h new file mode 100644 index 0000000..d93e285 --- /dev/null +++ b/ktux/sprite.h @@ -0,0 +1,72 @@ +//----------------------------------------------------------------------------- +// +// ksprite - QCanvas based screensaver +// +// Copyright (c) Martin R. Jones 1996 +// + +#ifndef __SPRITE_H__ +#define __SPRITE_H__ + +#include <qtimer.h> +#include <qpushbutton.h> +#include <qptrlist.h> +#include <qstrlist.h> +#include <qcanvas.h> +#include <kscreensaver.h> +#include "spriteanim.h" + +//----------------------------------------------------------------------------- +class KSpriteSaver : public KScreenSaver +{ + Q_OBJECT +public: + KSpriteSaver( WId id ); + virtual ~KSpriteSaver(); + + void setSpeed(int speed); + +private: + void readSettings(); + void initialise(); + void blank(); + +protected slots: + void slotTimeout(); + +protected: + virtual void timerEvent(QTimerEvent *); + +protected: + QCanvas *mCanvas; + QCanvasView *mView; + QTimer mTimer; + int mSpeed; + QPtrList<SpriteGroup> mGroups; + QMemArray<int> mTimerIds; +}; + +class KSpriteSetup : public QDialog +{ + Q_OBJECT +public: + KSpriteSetup( QWidget *parent = NULL, const char *name = NULL ); + ~KSpriteSetup(); + +protected: + void readSettings(); + +private slots: + void slotSpeed(int s); + void slotOkPressed(); + void slotAbout(); + +private: + int speed; + QWidget *preview; + KSpriteSaver *saver; +}; + + +#endif + diff --git a/ktux/spriteanim.cpp b/ktux/spriteanim.cpp new file mode 100644 index 0000000..2c21838 --- /dev/null +++ b/ktux/spriteanim.cpp @@ -0,0 +1,161 @@ +//--------------------------------------------------------------------------- +// +// spriteanim.cpp +// +// Copyright (c) 1999 Martin R. Jones <[email protected]> +// + +#include "spritemisc.h" +#include "spritepm.h" +#include "spriteanim.h" +#include <kdebug.h> + +//=========================================================================== +// +// SpriteObject stores the animations that create an object +// +SpriteObject::SpriteObject(SpritePixmapSequence *seq, QCanvas *c ) + : QCanvasSprite(seq, c), + mCycle(0), + mLifeSpan(-1), + mSeq(seq) +{ +} + +//--------------------------------------------------------------------------- +void SpriteObject::age() +{ + if (mLifeSpan > 0) + { + mLifeSpan--; + } + mCycle++; + if (mCycle > mSeq->delay(frame())) + { + setFrame((frame()+1)%frameCount()); + mCycle = 0; + } +} + +void SpriteObject::setBounds( int x1, int y1, int x2, int y2 ) +{ + mBound = QRect( x1, y1, x2-x1, y2-y1 ); +} + +bool SpriteObject::outOfBounds() const +{ + bool in = mBound.contains( static_cast<int>(x()), static_cast<int>(y()) ); + return !in; +} + +//=========================================================================== +// +// SpriteDef stores the animations that create an object +// +SpriteDef::SpriteDef(KConfigBase &config) +{ + read(config); +} + +//--------------------------------------------------------------------------- +SpriteObject *SpriteDef::create( QCanvas *c ) +{ + SpriteObject *sprite = 0; + if (mSeq) + { + int startX = mStartX.random(); + int startY = mStartY.random(); + sprite = new SpriteObject(mSeq, c); + sprite->setVelocity(mDirX.random(), mDirY.random()); + if ( mDirX.min() != 0 || mDirX.max() != 0 || + mDirY.min() != 0 || mDirY.max() != 0 ) { + sprite->setAnimated( true ); + } + sprite->move(startX, startY); + sprite->setBounds(startX-1, startY-1, mEndX.random()+1, mEndY.random()+1); + sprite->setLifeSpan(mLifeSpan); + sprite->setZ(mZ); + sprite->show(); + } + + return sprite; +} + +//--------------------------------------------------------------------------- +void SpriteDef::read(KConfigBase &config) +{ + mDirX.set(config.readEntry("DirectionX", "0")); + mDirY.set(config.readEntry("DirectionY", "0")); + mStartX.set(config.readEntry("StartX", "0")); + mStartY.set(config.readEntry("StartY", "0")); + mEndX.set(config.readEntry("EndX", "10000")); + mEndY.set(config.readEntry("EndY", "10000")); + mLifeSpan = config.readNumEntry("LifeSpan", -1); + mZ = config.readNumEntry("Z", 1); + QString animation = config.readEntry("Animation", ""); + mSeq = SpriteSequenceManager::manager()->load(config, animation); + kdDebug() << "Set Z = " << mZ << endl; +} + +//=========================================================================== +// +// SpriteGroup +// +SpriteGroup::SpriteGroup(QCanvas *c, KConfigBase &config) + : mCanvas(c) +{ + mAvailable.setAutoDelete(true); + mActive.setAutoDelete(true); + read(config); +} + +//--------------------------------------------------------------------------- +void SpriteGroup::next() +{ + QPtrListIterator<SpriteObject> it(mActive); + + for (; it.current(); ++it) + { + SpriteObject *sprite = it.current(); + if (sprite->outOfBounds() || sprite->dead()) + { + mActive.removeRef(sprite); + } + else + { +// sprite->forward(1); + sprite->age(); + } + } +} + +//--------------------------------------------------------------------------- +void SpriteGroup::refresh() +{ + if (((int) mActive.count()) < mCount) + { + SpriteObject *sprite = mAvailable.first()->create(mCanvas); + mActive.append(sprite); + } +} + + +//--------------------------------------------------------------------------- +void SpriteGroup::read(KConfigBase &config) +{ + SpriteRange countRange(config.readEntry("Count", "1")); + mCount = countRange.random(); + + mRefresh.set(config.readEntry("Refresh", "1000")); + + QStrList anims; + config.readListEntry("Animations", anims); + + for (anims.first(); anims.current(); anims.next()) + { + config.setGroup(anims.current()); + SpriteDef *obj = new SpriteDef(config); + mAvailable.append(obj); + } +} + diff --git a/ktux/spriteanim.h b/ktux/spriteanim.h new file mode 100644 index 0000000..9d5417b --- /dev/null +++ b/ktux/spriteanim.h @@ -0,0 +1,96 @@ +//--------------------------------------------------------------------------- +// +// spriteanim.h +// +// Copyright (c) 1999 Martin R. Jones <[email protected]> +// + +#ifndef SPRITEANIM_H +#define SPRITEANIM_H + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#include <qpixmap.h> +#include <qdict.h> +#include <qptrlist.h> +#include <qstrlist.h> +#include <qcanvas.h> +#include <kconfigbase.h> +#include <ksimpleconfig.h> + +//--------------------------------------------------------------------------- +// +// SpriteObject stores the animations that create an object +// +class SpriteObject : public QCanvasSprite +{ +public: + SpriteObject(SpritePixmapSequence *seq, QCanvas *c); + + void setLifeSpan(int l) { mLifeSpan = l; } + void age(); + bool dead() const { return (mLifeSpan == 0); } + void setBounds( int x1, int y1, int x2, int y2 ); + bool outOfBounds() const; + +protected: + int mCycle; + int mLifeSpan; + SpritePixmapSequence *mSeq; + QRect mBound; +}; + +//--------------------------------------------------------------------------- +// +// SpriteDef stores the definition of a sprite +// +class SpriteDef +{ +public: + SpriteDef(KConfigBase &config); + + SpriteObject *create( QCanvas *c ); + +protected: + void read(KConfigBase &config); + +protected: + SpriteRange mDirX; + SpriteRange mDirY; + SpriteRange mStartX; + SpriteRange mStartY; + SpriteRange mEndX; + SpriteRange mEndY; + int mLifeSpan; + int mZ; + SpritePixmapSequence *mSeq; +}; + +//--------------------------------------------------------------------------- +// +// SpriteGroup +// +class SpriteGroup +{ +public: + SpriteGroup(QCanvas *c, KConfigBase &config); + + void next(); + void refresh(); + int refreshTime() const { return mRefresh.random(); } + +protected: + void read(KConfigBase &config); + +protected: + QPtrList<SpriteDef> mAvailable; + QPtrList<SpriteObject> mActive; + int mCount; + SpriteRange mRefresh; + QCanvas *mCanvas; +}; + +#endif // SPRITEANIM_H + diff --git a/ktux/spritemisc.cpp b/ktux/spritemisc.cpp new file mode 100644 index 0000000..f3a9a73 --- /dev/null +++ b/ktux/spritemisc.cpp @@ -0,0 +1,69 @@ +//----------------------------------------------------------------------------- +// +// spritemisc +// +// Copyright (c) Martin R. Jones 1999 +// + +#include <kapplication.h> +#include "spritemisc.h" + +QSize SpriteRange::mFieldSize; + +SpriteRange::SpriteRange(const QString &str) +{ + set(str); +} + +int SpriteRange::random() const +{ + int val = mMin; + + if (mMax != mMin) + { + val = (KApplication::random()%(mMax-mMin)) + mMin; + } + + return val; +} + +void SpriteRange::set(const QString &str) +{ + int r = str.find(".."); + + if (r > 0) + { + mMin = parse(str.left(r)); + mMax = parse(str.mid(r+2, 10)); + } + else + { + mMin = mMax = parse(str); + } +} + +void SpriteRange::setFieldSize(const QSize &size) +{ + mFieldSize = size; +} + +int SpriteRange::parse(const QString &str) +{ + int val = 0; + + if (str == "WIDTH") + { + val = mFieldSize.width(); + } + else if (str == "HEIGHT") + { + val = mFieldSize.height(); + } + else + { + val = str.toInt(); + } + + return val; +} + diff --git a/ktux/spritemisc.h b/ktux/spritemisc.h new file mode 100644 index 0000000..0a0d058 --- /dev/null +++ b/ktux/spritemisc.h @@ -0,0 +1,41 @@ +//----------------------------------------------------------------------------- +// +// spritemisc +// +// Copyright (c) Martin R. Jones 1999 +// + +#ifndef __SPRITEMISC_H__ +#define __SPRITEMISC_H__ + +#include <qstring.h> +#include <qsize.h> + +class SpriteRange +{ +public: + SpriteRange(const QString &str); + SpriteRange(int l=0, int h=0) : mMin(l), mMax(h) {} + + int min() const { return mMin; } + int max() const { return mMax; } + + int random() const; + + void set(int l, int h) { mMin=l; mMax=h; } + void set(const QString &str); + + static void setFieldSize(const QSize &size); + static QSize fieldSize() { return mFieldSize; } + +protected: + int parse(const QString &str); + +protected: + int mMin; + int mMax; + static QSize mFieldSize; +}; + +#endif + diff --git a/ktux/spritepm.cpp b/ktux/spritepm.cpp new file mode 100644 index 0000000..ec9ba47 --- /dev/null +++ b/ktux/spritepm.cpp @@ -0,0 +1,176 @@ +//--------------------------------------------------------------------------- +// +// spritepm.cpp +// +// Copyright (c) 1999 Martin R. Jones <[email protected]> +// + +#include <stdlib.h> +#include <kdebug.h> +#include "spritepm.h" + +// static +SpritePixmapManager *SpritePixmapManager::mManager = 0; + +//--------------------------------------------------------------------------- +// +// Constructor +// +SpritePixmapManager::SpritePixmapManager() + : mPixmapDir(".") +{ + mPixmaps.setAutoDelete(true); +} + +//--------------------------------------------------------------------------- +// +// Destructor +// +SpritePixmapManager::~SpritePixmapManager() +{ +} + +//--------------------------------------------------------------------------- +// +// Load an image into the image manager +// +// Returns: +// pointer to pixmap if loaded successfully, 0 otherwise. +// +const QPixmap *SpritePixmapManager::load(const QString & img) +{ + QPixmap *pixmap = mPixmaps.find(img); + + if (!pixmap) + { + // pixmap has not yet been loaded. + kdDebug() << "Reading pixmap: " << img << endl; + QString path = mPixmapDir + QString("/") + img; + pixmap = new QPixmap(path); + + if (!pixmap->isNull()) + { + mPixmaps.insert(img,pixmap); + } + else + { + delete pixmap; + pixmap = 0; + kdDebug() << "read failed" << endl;; + } + } + + return pixmap; +} + +//--------------------------------------------------------------------------- +// +// returns a pointer to the pixmap manager. +// +SpritePixmapManager *SpritePixmapManager::manager() +{ + if (!mManager) + { + mManager = new SpritePixmapManager(); + } + + return mManager; +} + +//=========================================================================== +// +SpritePixmapSequence::SpritePixmapSequence(QPtrList<QPixmap> pm, QPtrList<QPoint> hs, + QMemArray<int> d) + : QCanvasPixmapArray(pm, hs), mDelays(d) +{ +} + +// static +SpriteSequenceManager *SpriteSequenceManager::mManager = 0; + +//=========================================================================== +// +// Constructor +// +SpriteSequenceManager::SpriteSequenceManager() +{ + mSprites.setAutoDelete(true); +} + +//--------------------------------------------------------------------------- +// +// Destructor +// +SpriteSequenceManager::~SpriteSequenceManager() +{ +} + +//--------------------------------------------------------------------------- +// +// Load an image into the sprite manager +// +// Returns: +// pointer to sprite if loaded successfully, 0 otherwise. +// +SpritePixmapSequence *SpriteSequenceManager::load(KConfigBase &config, + const QString & name) +{ + SpritePixmapSequence *sprite = mSprites.find(name); + + if (!sprite) + { + kdDebug() << "Reading sprite: " << name << endl; + config.setGroup(name); + sprite = read(config); + if (sprite) + { + mSprites.insert(name, sprite); + } + } + + return sprite; +} + +//--------------------------------------------------------------------------- +// +SpritePixmapSequence *SpriteSequenceManager::read(KConfigBase &config) +{ + QStrList strImages; + QStrList strDelays; + QPtrList<QPixmap> pixmaps; + QPtrList<QPoint> hotspots; + + int frames = config.readListEntry("Images", strImages); + config.readListEntry("Delays", strDelays); + + QMemArray<int> delays(frames); + + for (int i = 0; i < frames; i++) + { + const QPixmap *pixmap = + SpritePixmapManager::manager()->load(strImages.at(i)); + if (pixmap) + { + pixmaps.append(pixmap); + hotspots.append(new QPoint(0,0)); + delays[i] = atoi(strDelays.at(i)); + } + } + + return new SpritePixmapSequence(pixmaps, hotspots, delays); +} + +//--------------------------------------------------------------------------- +// +// returns a pointer to the sprite manager. +// +SpriteSequenceManager *SpriteSequenceManager::manager() +{ + if (!mManager) + { + mManager = new SpriteSequenceManager(); + } + + return mManager; +} + diff --git a/ktux/spritepm.h b/ktux/spritepm.h new file mode 100644 index 0000000..e9f24be --- /dev/null +++ b/ktux/spritepm.h @@ -0,0 +1,85 @@ +//--------------------------------------------------------------------------- +// +// spritepm.h +// +// Copyright (c) 1999 Martin R. Jones <[email protected]> +// + +#ifndef SPRITEPM_H +#define SPRITEPM_H + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#include <qdict.h> +#include <qpixmap.h> +#include <qcanvas.h> +#include <kconfigbase.h> +#include <ksimpleconfig.h> + +//--------------------------------------------------------------------------- +// +// SpritePixmapManager stores the frames used in animations. +// +class SpritePixmapManager +{ +public: + SpritePixmapManager(); + virtual ~SpritePixmapManager(); + + void setPixmapDir(const QString &dir) + { mPixmapDir = dir; } + void reset() + { mPixmapDir = "."; mPixmaps.clear(); } + const QPixmap *load(const QString & img); + const QPixmap *pixmap(const char *img) const + { return mPixmaps.find(img); } + + static SpritePixmapManager *manager(); + +public: + QString mPixmapDir; // get pixmaps from here + QDict<QPixmap> mPixmaps; // list of pixmaps + static SpritePixmapManager *mManager; // static pointer to instance +}; + +//--------------------------------------------------------------------------- +// +class SpritePixmapSequence : public QCanvasPixmapArray +{ +public: + SpritePixmapSequence(QPtrList<QPixmap> pm, QPtrList<QPoint> hs, QMemArray<int> d); + + int delay(int i) const { return mDelays[i]; } + +protected: + QMemArray<int> mDelays; +}; + +//--------------------------------------------------------------------------- +// +// SpriteManager stores the animation sequences +// +class SpriteSequenceManager +{ +public: + SpriteSequenceManager(); + ~SpriteSequenceManager(); + + SpritePixmapSequence *load(KConfigBase &config, const QString & name); + SpritePixmapSequence *sprite(const char *name) + { return mSprites.find(name); } + + static SpriteSequenceManager *manager(); + +protected: + SpritePixmapSequence *read(KConfigBase &config); + +protected: + QDict<SpritePixmapSequence> mSprites; + static SpriteSequenceManager *mManager; +}; + +#endif // SPRITEPM_H + diff --git a/ktux/sprites/Makefile.am b/ktux/sprites/Makefile.am new file mode 100644 index 0000000..8f27a80 --- /dev/null +++ b/ktux/sprites/Makefile.am @@ -0,0 +1,8 @@ +# Add all of your pixmaps here +sprite_DATA = anim0001.png anim0002.png anim0003.png anim0004.png \ + anim0005.png anim0006.png anim0007.png anim0008.png \ + anim0009.png anim0010.png bg.png flare0001.png \ + flare0002.png spriterc star0001.png star0002.png + +# This is where it will all be installed +spritedir = $(kde_datadir)/ktux/sprites diff --git a/ktux/sprites/anim0001.png b/ktux/sprites/anim0001.png Binary files differnew file mode 100644 index 0000000..f53aef7 --- /dev/null +++ b/ktux/sprites/anim0001.png diff --git a/ktux/sprites/anim0002.png b/ktux/sprites/anim0002.png Binary files differnew file mode 100644 index 0000000..ca06fe3 --- /dev/null +++ b/ktux/sprites/anim0002.png diff --git a/ktux/sprites/anim0003.png b/ktux/sprites/anim0003.png Binary files differnew file mode 100644 index 0000000..15c604c --- /dev/null +++ b/ktux/sprites/anim0003.png diff --git a/ktux/sprites/anim0004.png b/ktux/sprites/anim0004.png Binary files differnew file mode 100644 index 0000000..b48da81 --- /dev/null +++ b/ktux/sprites/anim0004.png diff --git a/ktux/sprites/anim0005.png b/ktux/sprites/anim0005.png Binary files differnew file mode 100644 index 0000000..3c308ec --- /dev/null +++ b/ktux/sprites/anim0005.png diff --git a/ktux/sprites/anim0006.png b/ktux/sprites/anim0006.png Binary files differnew file mode 100644 index 0000000..debe245 --- /dev/null +++ b/ktux/sprites/anim0006.png diff --git a/ktux/sprites/anim0007.png b/ktux/sprites/anim0007.png Binary files differnew file mode 100644 index 0000000..48ce5c8 --- /dev/null +++ b/ktux/sprites/anim0007.png diff --git a/ktux/sprites/anim0008.png b/ktux/sprites/anim0008.png Binary files differnew file mode 100644 index 0000000..2a299a4 --- /dev/null +++ b/ktux/sprites/anim0008.png diff --git a/ktux/sprites/anim0009.png b/ktux/sprites/anim0009.png Binary files differnew file mode 100644 index 0000000..11c4ea6 --- /dev/null +++ b/ktux/sprites/anim0009.png diff --git a/ktux/sprites/anim0010.png b/ktux/sprites/anim0010.png Binary files differnew file mode 100644 index 0000000..2d5cbf8 --- /dev/null +++ b/ktux/sprites/anim0010.png diff --git a/ktux/sprites/bg.png b/ktux/sprites/bg.png Binary files differnew file mode 100644 index 0000000..2ddefdb --- /dev/null +++ b/ktux/sprites/bg.png diff --git a/ktux/sprites/flare0001.png b/ktux/sprites/flare0001.png Binary files differnew file mode 100644 index 0000000..0e7b146 --- /dev/null +++ b/ktux/sprites/flare0001.png diff --git a/ktux/sprites/flare0002.png b/ktux/sprites/flare0002.png Binary files differnew file mode 100644 index 0000000..46c9366 --- /dev/null +++ b/ktux/sprites/flare0002.png diff --git a/ktux/sprites/spriterc b/ktux/sprites/spriterc new file mode 100644 index 0000000..16e3929 --- /dev/null +++ b/ktux/sprites/spriterc @@ -0,0 +1,62 @@ +[Config] +Groups=G_Ship,G_Star,G_Flare +Background=bg.ppm + +# Ship +[G_Ship] +Animations=O_Fly +Count=1 +Refresh=4000 + +[O_Fly] +Animation=A_Base +DirectionX=5 +DirectionY=2 +StartX=-250 +StartY=-300..HEIGHT +EndX=WIDTH +EndY=HEIGHT +Z=100 + +[A_Base] +Images=anim0001.png,anim0002.png,anim0003.png,anim0004.png,anim0005.png,anim0006.png,anim0007.png,anim0008.png,anim0009.png,anim0010.png +Delays=1,1,1,1,1,1,1,1,1,1 + +# Star +[G_Star] +Animations=O_Star +Count=10 +Refresh=100..500 + +[O_Star] +Animation=A_Star +DirectionX=0 +DirectionY=0 +StartX=0..WIDTH +StartY=0..HEIGHT +LifeSpan=2000 +Z=5 + +[A_Star] +Images=star0001.png,star0002.png +Delays=3,3 + +# Flare +[G_Flare] +Animations=O_Flare +Count=2 +Refresh=500..5000 + +[O_Flare] +Animation=A_Flare +DirectionX=0 +DirectionY=0 +StartX=0..WIDTH +StartY=0..HEIGHT +LifeSpan=110 +Z=10 + +[A_Flare] +Images=flare0001.png,flare0002.png,flare0001.png +Delays=5,100,5 + diff --git a/ktux/sprites/star0001.png b/ktux/sprites/star0001.png Binary files differnew file mode 100644 index 0000000..9913b17 --- /dev/null +++ b/ktux/sprites/star0001.png diff --git a/ktux/sprites/star0002.png b/ktux/sprites/star0002.png Binary files differnew file mode 100644 index 0000000..a42d0e7 --- /dev/null +++ b/ktux/sprites/star0002.png |