File indexing completed on 2024-09-08 06:47:09

0001 /*
0002     This file is part of the KDE games kwin4 program
0003     SPDX-FileCopyrightText: 2006 Martin Heni <kde@heni-online.de>
0004 
0005     SPDX-License-Identifier: LGPL-2.0-or-later
0006 */
0007 
0008 #ifndef KWIN4_KWIN4VIEW_H
0009 #define KWIN4_KWIN4VIEW_H
0010 
0011 // own
0012 #include "kwin4global.h"
0013 #include "thememanager.h"
0014 // KDEGames
0015 #define USE_UNSTABLE_LIBKDEGAMESPRIVATE_API
0016 #include <libkdegamesprivate/kgame/kgameio.h>
0017 // Qt
0018 #include <QDataStream>
0019 #include <QGraphicsPixmapItem>
0020 #include <QGraphicsView>
0021 #include <QLinearGradient>
0022 #include <QMouseEvent>
0023 #include <QPoint>
0024 #include <QRect>
0025 #include <QResizeEvent>
0026 #include <QSize>
0027 #include <QTimer>
0028 #include <QWidget>
0029 
0030 // Forward declaration
0031 class DisplayIntro;
0032 class DisplayGame;
0033 class Score;
0034 class ReflectionGraphicsScene;
0035 
0036 /**
0037  * The view object which shows the graphics for the game.
0038  */
0039 class KWin4View : public QGraphicsView, public virtual Themeable
0040 {
0041     Q_OBJECT
0042 
0043 public:
0044     /**
0045      * Constructor for the canvas view.
0046      * @param updateTime    The canvas advance rate
0047      * @param size          The canvas size
0048      * @param scene         The graphics scene
0049      * @param theme         The theme manager
0050      * @param parent        The parent window
0051      */
0052     KWin4View(int updateTime, const QSize &size, ReflectionGraphicsScene *scene, ThemeManager *theme, QWidget *parent = nullptr);
0053 
0054     /**
0055      * Destructor
0056      */
0057     ~KWin4View() override;
0058 
0059     /**
0060      * Main theme manager function. Called when any theme change like
0061      * a new theme or a theme size change occurs. This object needs to
0062      * resize and redraw then.
0063      */
0064     void changeTheme() override;
0065 
0066     /**
0067      * Initial setup of the game view.
0068      */
0069     void initGame(Score *scoreData);
0070 
0071     /**
0072      * Finalize (end) game.
0073      */
0074     void endGame();
0075 
0076     /**
0077      * Displays a move on the game board. This means a piece of
0078      * the given number is moved to the given position, the move
0079      * indicator arrow is switched on and any hints are disabed.
0080      * The move can be performed animated or not.
0081      * @param x          The x position on the game board [0-6]
0082      * @param y          The y position on the game board [0-5]
0083      * @param color      The color [Red,Yellow,Nobody]
0084      * @param xarrow     The x position of the arrow [0-6]
0085      * @param colorarrow The color or the arrow [Red,Yellow,Nobody]
0086      * @param no         The sprite number / move number
0087      * @param animation  True to make an animated move
0088      */
0089     void displayMove(int x, int y, int color, int xarrow, int colorarrow, int no, bool animation);
0090 
0091     /**
0092      * Displays a star on the game board to indicate victorious pieces.
0093      * @param x          The x position on the game board [0-6]
0094      * @param y          The y position on the game board [0-5]
0095      * @param no         The sprite number / move number
0096      */
0097     void displayStar(int x, int y, int no);
0098 
0099     /**
0100      * Displays a hint on the game board to indicate a good move.
0101      * @param x          The x position on the game board [0-6]
0102      * @param y          The y position on the game board [0-5]
0103      */
0104     void displayHint(int x, int y);
0105 
0106     /**
0107      * Enable reflections on the given position. If width or height is zero
0108      * the reflections are disabled.
0109      * @param x      The x position of the reflection  [screen coord]
0110      * @param y      The y position of the reflection  [screen coord]
0111      * @param width  The width of the reflection  [screen coord]
0112      * @param height The height of the reflection  [screen coord]
0113      */
0114     void setReflection(int x, int y, int width, int height);
0115 
0116 Q_SIGNALS:
0117     /**
0118      * Emit this signal if a sprite animation move is finished.
0119      * @param mode  A user-defined parameter.
0120      */
0121     void signalMoveDone(int mode);
0122 
0123     /**
0124      * Emit this signal if a new game is started from the intro display.
0125      * @param startPlayer Color of the starting player
0126      * @param input0      Input device of player 1
0127      * @param input1      Input device of player 2
0128      * @param aiLevel     Level for AI (-1: no change)
0129      */
0130     void signalQuickStart(COLOUR startPlayer, KGameIO::IOMode input0, KGameIO::IOMode input1, int aiLevel);
0131 
0132 public Q_SLOTS:
0133     /**
0134      * The update and advance for the canvas.
0135      *  This is called by a timer at regular intervals.
0136      */
0137     void updateAndAdvance();
0138 
0139     /**
0140      * Handle mouse inputs for the KGame framework.
0141      * @param input     The IO device
0142      * @param stream    The KGame message stream
0143      * @param mouse     The mouse event
0144      * @param eatevent  Set to true if the event was processed
0145      */
0146     void mouseInput(KGameIO *input, QDataStream &stream, QMouseEvent *mouse, bool *eatevent);
0147 
0148     /**
0149      * Handle key inputs for the KGame framework.
0150      * @param input     The IO device
0151      * @param stream    The KGame message stream
0152      * @param key       The key event
0153      * @param eatevent  Set to true if the event was processed
0154      */
0155     void keyInput(KGameIO *input, QDataStream &stream, QKeyEvent *key, bool *eatevent);
0156 
0157     /**
0158      * Animation of a sprite is finished.
0159      * @param item   The item
0160      * @param mode   A user defined mode
0161      */
0162     void moveDone(QGraphicsItem *item, int mode);
0163 
0164     /**
0165      * Rescale the theme (update theme SVG graphics).
0166      */
0167     void rescaleTheme();
0168 
0169 protected:
0170     /**
0171      * Will be called when the widgets contents
0172      * are resized. Resized and rescale game.
0173      * @param e The resize event
0174      */
0175     void resizeEvent(QResizeEvent *e) override;
0176 
0177     /**
0178      * Widget viewport event.
0179      * @param event The event.
0180      */
0181     bool viewportEvent(QEvent *event) override;
0182 
0183     /**
0184      * Overwritten Qt function.
0185      */
0186     void drawItems(QPainter *painter, int numItems, QGraphicsItem *items[], const QStyleOptionGraphicsItem options[]) override;
0187 
0188 private:
0189     // The theme manager
0190     ThemeManager *mTheme;
0191 
0192     // Theme queue
0193     QList<int> mThemeQueue;
0194     // Theme offset queque
0195     QList<QPoint> mThemeOffset;
0196 
0197     // The scene to plot to
0198     ReflectionGraphicsScene *mScene;
0199 
0200     // The advance period of the scene [ms]
0201     int mAdvancePeriod;
0202 
0203     // The intro display engine
0204     DisplayIntro *mIntroDisplay;
0205 
0206     // The game display engine
0207     DisplayGame *mGameDisplay;
0208 
0209     // Status of the game (running or not)
0210     bool mIsRunning;
0211 
0212     // Gradient for the reflection
0213     QLinearGradient mGradient;
0214     // Pixmap for the reflection
0215     QPixmap mGradientPixmap;
0216     // Reflection sprite
0217     QGraphicsPixmapItem *mReflectionSprite;
0218     // Refection size
0219     QRect mReflectionRect;
0220     // Paint pixmap of reflection
0221     QPixmap mReflectPixmap;
0222     // Phase of reflection drawing
0223     int mReflectPhase;
0224 
0225     // Debug frame rate sprite
0226     QGraphicsTextItem *mFrameSprite;
0227     // Average update times
0228     QList<int> mDrawTimes;
0229 
0230     // Update and advance timer
0231     QTimer *mTimer;
0232     // Default update time [ms]
0233     int mDefaultUpdateTime;
0234     // Update slow down factor
0235     double mSlowDownFactor;
0236     // Slow incident counter
0237     int mSlowCnt;
0238 };
0239 
0240 #endif // KWIN4_KWIN4VIEW_H